:root{--champagne: #F7E7CE;--champagne-light: #FAF4E6;--gold: #D4AF37;--gold-dark: #B8962E;--white: #FFFFFF;--text-dark: #2C2C2C;--text-medium: #666666;--shadow: rgba(0, 0, 0, .1);--shadow-hover: rgba(0, 0, 0, .15);--radius: 12px;--radius-sm: 8px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--champagner-light);color:var(--text-dark);line-height:1.6}h1,h2,h3,h4{font-family:Playfair Display,Georgia,serif;color:var(--text-dark)}.app{min-height:100vh;display:flex;flex-direction:column}.hero{background:linear-gradient(135deg,var(--champagne) 0%,var(--gold) 100%);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .8s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.hero-content{text-align:center;color:var(--white);max-width:600px}.hero-title{font-size:clamp(2rem,8vw,4rem);margin-bottom:1rem;text-shadow:2px 2px 4px var(--shadow)}.hero-date{font-size:1.5rem;margin-bottom:1.5rem;opacity:.95}.hero-welcome{font-size:1.2rem;margin-bottom:2rem;opacity:.9;line-height:1.8}.login-form{display:flex;flex-direction:column;gap:1rem;max-width:300px;margin:0 auto}.login-input{padding:12px 16px;border:2px solid var(--white);border-radius:var(--radius);font-size:1rem;text-align:center;text-transform:uppercase;outline:none;transition:all .3s}.login-input:focus{border-color:var(--white);box-shadow:0 0 0 3px #ffffff4d}.login-button{padding:14px 24px;background:var(--white);color:var(--gold);border:none;border-radius:var(--radius);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s;text-transform:uppercase;letter-spacing:1px}.login-button:hover{background:var(--gold-dark);color:var(--white);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-hover)}.main-content{flex:1;max-width:1200px;margin:0 auto;padding:20px;width:100%}.upload-section{background:var(--white);border-radius:var(--radius);padding:30px;margin-bottom:40px;box-shadow:0 4px 12px var(--shadow);animation:slideUp .6s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.uploader-name-section{margin-bottom:20px}.uploader-name-section label{display:block;font-weight:600;margin-bottom:8px;color:var(--text-dark)}.uploader-name-input{width:100%;padding:12px 16px;border:2px solid var(--champagner);border-radius:var(--radius-sm);font-size:1rem;outline:none;transition:all .3s}.uploader-name-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px #d4af3733}.upload-zone{border:3px dashed var(--champagner);border-radius:var(--radius);padding:40px 20px;text-align:center;transition:all .3s;cursor:pointer;background:var(--champagner-light)}.upload-zone.active{border-color:var(--gold);background:#d4af371a}.upload-zone-content{margin-bottom:20px}.upload-icon{width:64px;height:64px;margin:0 auto 16px;color:var(--gold)}.upload-text{font-size:1.3rem;font-weight:600;color:var(--text-dark);margin-bottom:8px}.upload-subtext{font-size:.9rem;color:var(--text-medium)}.upload-button{padding:12px 24px;background:var(--gold);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.upload-button:hover:not(:disabled){background:var(--gold-dark);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-hover)}.upload-button:disabled{opacity:.6;cursor:not-allowed}.progress-container{margin-top:20px}.progress-bar{height:8px;background:var(--champagner-light);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-dark));transition:width .3s}.progress-text{text-align:center;margin-top:8px;font-weight:600;color:var(--gold-dark)}.gallery-section{animation:slideUp .6s ease-out .2s both}.gallery-title{font-size:2rem;margin-bottom:20px;text-align:center;color:var(--text-dark)}.gallery-empty{text-align:center;padding:60px 20px;color:var(--text-medium);font-size:1.2rem}.gallery{position:relative}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;animation:fadeIn .6s ease-out}.photo-card{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;box-shadow:0 2px 8px var(--shadow);transition:all .3s;aspect-ratio:1}.photo-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px var(--shadow-hover)}.photo-image{width:100%;height:100%;object-fit:cover;transition:transform .3s}.photo-card:hover .photo-image{transform:scale(1.05)}.photo-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);padding:20px 12px 12px;opacity:0;transition:opacity .3s}.photo-card:hover .photo-overlay{opacity:1}.photo-info{color:var(--white)}.photo-uploader{font-weight:600;font-size:.9rem;margin-bottom:4px}.photo-time{font-size:.8rem;opacity:.8}.lightbox{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s}.lightbox-content{position:relative;max-width:90vw;max-height:90vh}.lightbox-close{position:absolute;top:-40px;right:0;background:none;border:none;color:var(--white);font-size:2.5rem;cursor:pointer;line-height:1;padding:10px}.lightbox-image{max-width:100%;max-height:80vh;object-fit:contain;border-radius:var(--radius-sm)}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;color:var(--white);font-size:3rem;cursor:pointer;padding:20px 15px;transition:all .3s}.lightbox-nav:hover{background:#fff3}.lightbox-prev{left:-50px}.lightbox-next{right:-50px}.lightbox-info{position:absolute;bottom:60px;left:0;right:0;text-align:center;color:var(--white)}.lightbox-uploader{font-weight:600;font-size:1.1rem;margin-bottom:4px}.lightbox-time{font-size:.9rem;opacity:.8}.lightbox-actions{display:flex;gap:10px;justify-content:center;margin-top:20px}.lightbox-button{padding:10px 20px;background:var(--gold);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s}.lightbox-button:hover{background:var(--gold-dark);transform:translateY(-2px)}.lightbox-button.delete{background:#ff6b6b}.lightbox-button.delete:hover{background:#ee5a5a}.admin-toggle{position:fixed;top:20px;right:20px;background:var(--gold);color:var(--white);border:none;padding:12px 16px;border-radius:var(--radius-sm);cursor:pointer;font-size:.9rem;z-index:100;transition:all .3s;box-shadow:0 4px 12px var(--shadow)}.admin-toggle:hover{background:var(--gold-dark);transform:translateY(-2px)}.admin-panel{position:fixed;top:0;right:0;width:400px;max-width:100%;height:100vh;background:var(--white);box-shadow:-4px 0 20px var(--shadow);z-index:200;padding:30px;overflow-y:auto;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.admin-close{position:absolute;top:20px;right:20px;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-dark)}.admin-title{font-size:1.5rem;margin-bottom:24px;color:var(--text-dark)}.admin-login{display:flex;flex-direction:column;gap:12px}.admin-password-input{padding:12px 16px;border:2px solid var(--champagner);border-radius:var(--radius-sm);font-size:1rem;outline:none}.admin-password-input:focus{border-color:var(--gold)}.admin-login-button{padding:12px 24px;background:var(--gold);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;cursor:pointer}.admin-login-button:hover{background:var(--gold-dark)}.admin-error{color:#ff6b6b;font-size:.9rem}.admin-content{display:flex;flex-direction:column;gap:24px}.admin-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;text-align:center}.stat-item{background:var(--champagner-light);padding:16px;border-radius:var(--radius-sm)}.stat-number{display:block;font-size:1.8rem;font-weight:700;color:var(--gold);margin-bottom:4px}.stat-label{font-size:.85rem;color:var(--text-medium);text-transform:uppercase}.admin-button{width:100%;padding:14px 20px;background:var(--gold);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.admin-button:hover:not(:disabled){background:var(--gold-dark);transform:translateY(-2px)}.admin-button:disabled{opacity:.6;cursor:not-allowed}.admin-delete-section{padding:16px;background:#fff5f5;border-radius:var(--radius-sm);border-left:4px solid #ff6b6b}.admin-delete-section h4{font-size:1.1rem;margin-bottom:8px;color:#ff6b6b}.admin-delete-hint{font-size:.9rem;color:var(--text-medium);line-height:1.5}.footer{background:var(--champagner);padding:20px;text-align:center;color:var(--text-dark);font-size:.9rem}.error-message{background:#fff5f5;color:#ff6b6b;padding:12px 20px;border-radius:var(--radius-sm);text-align:center;margin:20px 0;border-left:4px solid #ff6b6b}@media (max-width: 768px){.hero-title{font-size:2rem}.hero-date{font-size:1.2rem}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.lightbox-prev{left:10px}.lightbox-next{right:10px}.admin-panel{width:100%}.admin-stats{grid-template-columns:1fr}}@media (max-width: 480px){.gallery-grid{grid-template-columns:repeat(2,1fr)}.upload-zone{padding:30px 16px}.lightbox-nav{padding:15px 10px;font-size:2rem}}
