*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#080808;--bg-2:#111;--bg-3:#1a1a1a;--bg-4:#222;--border:#2a2a2a;--border-light:#333;--text:#f0ede8;--text-2:#a09890;--text-3:#6b6460;--accent:#c9a96e;--accent-2:#e8d5b0;--accent-dark:#8a6f42;--red:#c0392b;--green:#27ae60;--radius:4px;--radius-lg:8px;--shadow:0 4px 24px #0009;--shadow-lg:0 16px 64px #000c;--font-display:"Cormorant Garamond", Georgia, serif;--font-body:"DM Sans", -apple-system, sans-serif;--transition:.2s cubic-bezier(.4, 0, .2, 1)}html{-webkit-font-smoothing:antialiased;font-size:16px}body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.6}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-2)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-.01em;font-weight:300;line-height:1.2}a{color:inherit;text-decoration:none}button{font-family:var(--font-body);cursor:pointer;border:none;outline:none}input,textarea{font-family:var(--font-body);outline:none}.container{max-width:1200px;margin:0 auto;padding:0 24px}.btn{border-radius:var(--radius);letter-spacing:.04em;text-transform:uppercase;transition:all var(--transition);cursor:pointer;white-space:nowrap;align-items:center;gap:8px;padding:10px 20px;font-size:13px;font-weight:500;display:inline-flex}.btn-primary{background:var(--accent);color:#080808}.btn-primary:hover{background:var(--accent-2);transform:translateY(-1px);box-shadow:0 8px 24px #c9a96e4d}.btn-secondary{color:var(--text);border:1px solid var(--border-light);background:0 0}.btn-secondary:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.btn-ghost{color:var(--text-2);background:0 0;padding:8px 12px}.btn-ghost:hover{color:var(--text);background:var(--bg-3)}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{opacity:.85}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);font-size:11px;font-weight:500}.form-input{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);transition:border-color var(--transition);width:100%;padding:12px 16px;font-size:14px}.form-input:focus{border-color:var(--accent);background:var(--bg-4)}.form-input::placeholder{color:var(--text-3)}.card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition);overflow:hidden}.card:hover{border-color:var(--border-light);box-shadow:var(--shadow)}.divider{background:var(--border);height:1px;margin:24px 0}.badge{letter-spacing:.04em;text-transform:uppercase;border-radius:999px;align-items:center;padding:3px 10px;font-size:11px;font-weight:500;display:inline-flex}.badge-gold{color:var(--accent);background:#c9a96e26;border:1px solid #c9a96e4d}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:.4s fadeIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000d9;justify-content:center;align-items:center;padding:24px;animation:.2s fadeOverlay;display:flex;position:fixed;inset:0}@keyframes fadeOverlay{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-2);border:1px solid var(--border-light);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:var(--shadow-lg);padding:32px;animation:.25s cubic-bezier(.34,1.56,.64,1) slideModal}@keyframes slideModal{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.react-hot-toast{font-family:var(--font-body)!important}.empty-state{text-align:center;color:var(--text-3);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:80px 24px;display:flex}.empty-state svg{opacity:.3}.empty-state h3{font-family:var(--font-display);color:var(--text-2);font-size:28px}.empty-state p{max-width:320px;font-size:14px}@media (width<=768px){.container{padding:0 16px}.modal{padding:24px}.btn{padding:10px 16px;font-size:12px}}.landing{flex-direction:column;min-height:100vh;display:flex}.landing-nav{z-index:50;background:0 0;padding:20px 0;transition:background .3s;position:fixed;top:0;left:0;right:0}.landing-nav-inner{justify-content:space-between;align-items:center;display:flex}.landing-brand{font-family:var(--font-display);color:var(--text);align-items:center;gap:10px;font-size:22px;display:flex}.landing-brand svg{color:var(--accent)}.landing-hero{align-items:center;min-height:100vh;padding:120px 0 80px;display:flex;position:relative;overflow:hidden}.landing-hero-bg{pointer-events:none;background:radial-gradient(60% 60% at 70%,#c9a96e0f 0%,#0000 70%),radial-gradient(40% 80% at 20% 80%,#c9a96e0a 0%,#0000 60%);position:absolute;inset:0}.landing-hero-content{max-width:640px}.landing-title{font-family:var(--font-display);color:var(--text);letter-spacing:-.02em;margin-bottom:28px;font-size:clamp(52px,8vw,88px);font-weight:300;line-height:1.05}.landing-title em{color:var(--accent);font-style:italic}.landing-subtitle{color:var(--text-2);max-width:440px;margin-bottom:48px;font-size:17px;font-weight:300;line-height:1.7}.landing-cta{flex-wrap:wrap;gap:16px;display:flex}.landing-features{border-top:1px solid var(--border);background:var(--bg-2);padding:100px 0}.features-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:2px;display:grid}.feature-card{border:1px solid var(--border);background:var(--bg);transition:all var(--transition);padding:48px 36px}.feature-card:hover{background:var(--bg-2);border-color:var(--border-light)}.feature-icon{border-radius:var(--radius);width:48px;height:48px;color:var(--accent);background:#c9a96e1a;justify-content:center;align-items:center;margin-bottom:24px;display:flex}.feature-card h3{font-family:var(--font-display);color:var(--text);margin-bottom:12px;font-size:24px;font-weight:400}.feature-card p{color:var(--text-2);font-size:14px;line-height:1.7}.landing-footer{border-top:1px solid var(--border);text-align:center;color:var(--text-3);margin-top:auto;padding:32px 0;font-size:13px}@media (width<=768px){.landing-hero{padding:100px 0 60px}.landing-cta{flex-direction:column}.features-grid{grid-template-columns:1fr}.feature-card{padding:32px 24px}}.auth-page{min-height:100vh;display:flex}.auth-left{background:var(--bg-2);border-right:1px solid var(--border);flex:1;justify-content:center;align-items:center;padding:60px;display:flex;position:relative;overflow:hidden}.auth-left:before{content:"";background:radial-gradient(80% 80% at 30% 70%,#c9a96e14 0%,#0000 70%);position:absolute;inset:0}.auth-left-content{z-index:1;position:relative}.auth-brand{font-family:var(--font-display);color:var(--text);align-items:center;gap:10px;margin-bottom:60px;font-size:20px;display:flex}.auth-brand svg{color:var(--accent)}.auth-tagline{font-family:var(--font-display);color:var(--text);font-size:clamp(40px,5vw,64px);font-weight:300;line-height:1.1}.auth-tagline em{color:var(--accent);font-style:italic}.auth-right{justify-content:center;align-items:center;width:480px;padding:60px 48px;display:flex}.auth-form-wrap{width:100%}.auth-tabs{border-bottom:1px solid var(--border);margin-bottom:36px;display:flex}.auth-tab{color:var(--text-3);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-1px;padding:12px;font-size:13px;font-weight:500}.auth-tab:hover{color:var(--text-2)}.auth-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.auth-form{flex-direction:column;gap:20px;display:flex}.auth-submit{justify-content:center;width:100%;margin-top:8px;padding:14px;font-size:13px}.auth-switch{text-align:center;color:var(--text-3);margin-top:24px;font-size:13px}.auth-switch-btn{color:var(--accent);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;font-size:13px;text-decoration:underline}.auth-switch-btn:hover{color:var(--accent-2)}@media (width<=900px){.auth-left{display:none}.auth-right{width:100%;padding:48px 24px}}.dashboard{padding:48px 0 80px}.dashboard-header{justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:40px;display:flex}.dashboard-title{font-family:var(--font-display);color:var(--text);margin-bottom:4px;font-size:42px;font-weight:300}.dashboard-sub{color:var(--text-3);font-size:13px}.albums-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.album-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition);cursor:pointer;display:block;overflow:hidden}.album-card:hover{border-color:var(--accent-dark);transform:translateY(-2px);box-shadow:0 12px 40px #00000080}.album-card-body{align-items:flex-start;gap:20px;padding:28px;display:flex}.album-card-icon{border-radius:var(--radius);width:52px;min-width:52px;height:52px;color:var(--accent);background:#c9a96e14;border:1px solid #c9a96e26;justify-content:center;align-items:center;display:flex}.album-card-info{flex:1;min-width:0}.album-card-name{font-family:var(--font-display);color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:6px;font-size:22px;font-weight:400;overflow:hidden}.album-card-desc{color:var(--text-3);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:16px;font-size:13px;line-height:1.5;display:-webkit-box;overflow:hidden}.album-card-meta{flex-wrap:wrap;gap:12px;display:flex}.album-meta-item{color:var(--text-3);letter-spacing:.02em;align-items:center;gap:4px;font-size:11px;display:flex}.album-shared{color:var(--accent)!important}@media (width<=600px){.dashboard{padding:32px 0 60px}.dashboard-header{flex-direction:column;align-items:flex-start}.dashboard-title{font-size:32px}.albums-grid{grid-template-columns:1fr}}.dropzone{border:2px dashed var(--border-light);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:all var(--transition);background:var(--bg-2);padding:48px 24px}.dropzone:hover:not(.dropzone-uploading){border-color:var(--accent-dark);background:#c9a96e08}.dropzone-active{transform:scale(1.01);border-color:var(--accent)!important;background:#c9a96e0f!important}.dropzone-uploading{cursor:default;opacity:.7}.dropzone-content{flex-direction:column;align-items:center;gap:16px;display:flex}.dropzone-icon{color:var(--text-3);transition:color var(--transition)}.dropzone-icon.active{color:var(--accent)}.dropzone:hover .dropzone-icon{color:var(--accent-dark)}.dropzone-text p{color:var(--text-2);font-size:15px}.dropzone-text p strong{color:var(--text)}.dropzone-hint{margin-top:6px;color:var(--text-3)!important;font-size:12px!important}@media (width<=480px){.dropzone{padding:32px 16px}}.media-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;display:grid}.media-item{aspect-ratio:1;border-radius:var(--radius);cursor:pointer;background:var(--bg-3);border:1px solid var(--border);transition:all var(--transition);position:relative;overflow:hidden}.media-item:hover{border-color:var(--accent-dark);z-index:2;transform:scale(1.01)}.media-item:hover .media-overlay{opacity:1}.media-thumb{object-fit:cover;width:100%;height:100%;display:block}.media-thumb-video,.media-thumb-file{background:var(--bg-3);height:100%;color:var(--text-3);flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex}.media-thumb-video{color:var(--accent-dark)}.media-type-label,.media-ext{letter-spacing:.08em;text-transform:uppercase;font-size:11px;font-weight:600}.media-overlay{opacity:0;transition:opacity var(--transition);background:linear-gradient(#0000 50%,#000000d9 100%);flex-direction:column;justify-content:flex-end;padding:12px;display:flex;position:absolute;inset:0}.media-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:12px;display:block;overflow:hidden}.media-size{color:#fff9;font-size:11px}.lightbox{z-index:200;background:#040404f7;flex-direction:column;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.lightbox-toolbar{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.lightbox-info{flex-direction:column;gap:2px;min-width:0;display:flex}.lightbox-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:400px;font-size:14px;overflow:hidden}.lightbox-meta{color:var(--text-3);font-size:12px}.lightbox-actions{align-items:center;gap:4px;display:flex}.lightbox-btn{border-radius:var(--radius);justify-content:center;align-items:center;width:36px;height:36px;padding:0;display:flex}.lightbox-body{flex:1;justify-content:center;align-items:center;padding:16px;display:flex;position:relative;overflow:hidden}.lightbox-media{justify-content:center;align-items:center;max-width:100%;max-height:100%;display:flex}.lightbox-img{object-fit:contain;border-radius:var(--radius);max-width:100%;max-height:calc(100vh - 160px)}.lightbox-video{border-radius:var(--radius);max-width:100%;max-height:calc(100vh - 160px)}.lightbox-file{color:var(--text-3);text-align:center;flex-direction:column;align-items:center;gap:20px;display:flex}.lightbox-file p{color:var(--text-2);font-size:14px}.lightbox-nav{border-radius:var(--radius);color:#fff;cursor:pointer;width:44px;height:44px;transition:all var(--transition);z-index:10;background:#ffffff14;border:1px solid #ffffff1f;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.lightbox-nav:hover{background:#ffffff29}.lightbox-prev{left:12px}.lightbox-next{right:12px}.lightbox-counter{text-align:center;color:var(--text-3);letter-spacing:.06em;flex-shrink:0;padding:12px;font-size:12px}@media (width<=768px){.media-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:4px}.lightbox-media{padding:8px}.lightbox-name{max-width:200px}.lightbox-nav{display:none}}@media (width<=480px){.media-grid{grid-template-columns:repeat(3,1fr)}}.album-page{padding:32px 0 80px}.album-back{color:var(--text-3);margin-bottom:24px;padding-left:0}.album-back:hover{color:var(--text);background:0 0}.album-header{margin-bottom:40px}.album-title-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:20px;display:flex}.album-title{font-family:var(--font-display);color:var(--text);margin-bottom:6px;font-size:48px;font-weight:300}.album-description{color:var(--text-3);max-width:500px;margin-bottom:8px;font-size:14px}.album-stats{color:var(--text-3);letter-spacing:.04em;text-transform:uppercase;font-size:12px}.album-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.share-banner{border-radius:var(--radius);color:var(--accent);background:#c9a96e14;border:1px solid #c9a96e33;align-items:center;gap:10px;padding:10px 16px;font-size:13px;display:flex}.share-url{text-overflow:ellipsis;white-space:nowrap;color:var(--text-2);flex:1;font-family:monospace;font-size:12px;overflow:hidden}.upload-section{margin-bottom:40px}@media (width<=768px){.album-title{font-size:32px}.album-title-row{flex-direction:column}.album-actions{width:100%}.album-actions .btn{flex:1;justify-content:center}}@media (width<=480px){.album-actions{flex-direction:column}}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-dialog{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);width:90%;max-width:500px;animation:.3s ease-out slideUp;box-shadow:0 20px 60px #0000004d}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px;display:flex}.modal-header h2{color:var(--text);margin:0;font-size:20px;font-weight:500}.modal-body{flex-direction:column;gap:12px;padding:20px;display:flex}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:16px 20px;display:flex}.form-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-2);width:100%;color:var(--text);padding:10px 12px;font-family:inherit;font-size:14px;transition:all .2s}.form-input:focus{border-color:var(--accent);background:var(--bg);outline:none}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.shared-page{background:var(--bg);min-height:100vh}.shared-header{z-index:50;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#080808eb;height:60px;position:sticky;top:0}.shared-header-inner{justify-content:space-between;align-items:center;height:100%;display:flex}.shared-brand{font-family:var(--font-display);color:var(--text);align-items:center;gap:10px;font-size:20px;display:flex}.shared-brand svg{color:var(--accent)}.shared-header-right{align-items:center;gap:10px;display:flex}.shared-content{padding:48px 0 80px}.shared-album-info{margin-bottom:48px}.shared-title{font-family:var(--font-display);color:var(--text);margin-bottom:12px;font-size:clamp(36px,6vw,64px);font-weight:300}.shared-desc{color:var(--text-2);max-width:560px;margin-bottom:16px;font-size:16px;line-height:1.6}.shared-meta{color:var(--text-3);flex-wrap:wrap;align-items:center;gap:8px;font-size:13px;display:flex}.shared-notfound{text-align:center;background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;padding:24px;display:flex}.shared-notfound h2{font-family:var(--font-display);color:var(--text);font-size:32px;font-weight:300}.shared-notfound p{color:var(--text-3);font-size:14px}@media (width<=768px){.shared-content{padding:32px 0 60px}.shared-header-right .btn span{display:none}}.navbar{z-index:50;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#080808eb;height:60px;position:sticky;top:0}.navbar-inner{justify-content:space-between;align-items:center;height:100%;display:flex}.navbar-brand{font-family:var(--font-display);letter-spacing:.02em;color:var(--text);transition:color var(--transition);align-items:center;gap:10px;font-size:22px;font-weight:400;display:flex}.navbar-brand:hover,.navbar-brand svg{color:var(--accent)}.navbar-right{align-items:center;gap:8px;display:flex}.navbar-username{color:var(--text-3);padding:0 8px;font-size:13px}@media (width<=480px){.navbar-username{display:none}}
