*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0f;--sf: #13131a;--sf2: #1a1a24;--sf3: #22222f;--bd: #2a2a3a;--tx: #e8e6f0;--tx2: #9896a8;--tx3: #5d5b6e;--ac: #f97316;--acg: rgba(249,115,22,.15);--gn: #22c55e;--pk: #ec4899;--pp: #a855f7;--rd: 16px;--rs: 10px}body{font-family:DM Sans,sans-serif;background:var(--bg);color:var(--tx);min-height:100vh;-webkit-font-smoothing:antialiased}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes glow{0%,to{box-shadow:0 0 20px var(--acg)}50%{box-shadow:0 0 40px var(--acg)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.93)}to{opacity:1;transform:scale(1)}}.bp{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--rs);font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;border:none;cursor:pointer;transition:all .25s;background:linear-gradient(135deg,var(--ac),#ea580c);color:#fff;box-shadow:0 4px 20px #f973164d}.bp:hover{transform:translateY(-2px);box-shadow:0 8px 30px #f9731666}.bp:active{transform:scale(.97)}.bs{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--rs);font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;border:1px solid var(--bd);cursor:pointer;background:var(--sf2);color:var(--tx);transition:all .25s}.bs:hover{background:var(--sf3);border-color:var(--tx3)}.blg{padding:13px 26px;font-size:15px;border-radius:var(--rd)}.sm{padding:6px 12px;font-size:12px}.full{width:100%;justify-content:center;padding:13px;font-size:15px;margin-top:8px}.inp{width:100%;padding:11px 15px;background:var(--sf2);border:1px solid var(--bd);border-radius:var(--rs);color:var(--tx);font-size:15px;font-family:DM Sans,sans-serif;outline:none;transition:border .2s;margin-bottom:14px}.inp:focus{border-color:var(--ac);box-shadow:0 0 0 3px var(--acg)}.inp::placeholder{color:var(--tx3)}.inp.sm{padding:5px 10px;font-size:12px;width:110px;margin-bottom:0}.inp.code-input{font-family:Space Mono,monospace;font-size:22px;text-align:center;letter-spacing:8px;padding:14px}.header{position:sticky;top:0;z-index:100;background:#0a0a0fd9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--bd);padding:12px 20px}.header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.logo{display:flex;align-items:center;gap:10px;cursor:pointer}.logo-icon{width:34px;height:34px;background:linear-gradient(135deg,#f97316,#ec4899);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:15px}.logo-text{font-family:"Instrument Serif",serif;font-size:22px}.logo-text em{color:var(--ac);font-style:italic}.header-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-dot.ok{background:var(--gn)}.status-dot.err{background:#ef4444;animation:pulse 2s infinite}.status-dot.loading{background:var(--ac);animation:pulse 1s infinite}.toast{position:fixed;bottom:30px;left:50%;transform:translate(-50%) translateY(80px);background:var(--gn);color:#fff;padding:10px 20px;border-radius:var(--rs);font-size:14px;font-weight:600;z-index:300;transition:transform .4s cubic-bezier(.22,1,.36,1);pointer-events:none;white-space:nowrap}.toast.show{transform:translate(-50%) translateY(0)}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400;background:#000000f2;display:flex;align-items:center;justify-content:center;cursor:zoom-out}.lightbox img{max-width:92vw;max-height:92vh;object-fit:contain;border-radius:8px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:#0a0a0ff5;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px}.spinner{width:72px;height:72px;position:relative}.spinner div{position:absolute;border:3px solid var(--bd);border-radius:50%;animation:spin 1s linear infinite}.spinner div:nth-child(1){top:0;right:0;bottom:0;left:0;border-top-color:var(--ac)}.spinner div:nth-child(2){top:8px;right:8px;bottom:8px;left:8px;border-top-color:var(--pk);animation-duration:1.5s;animation-direction:reverse}.spinner div:nth-child(3){top:16px;right:16px;bottom:16px;left:16px;border-top-color:var(--pp);animation-duration:2s}.overlay-text{font-size:17px;font-weight:500}.overlay-sub{font-size:14px;color:var(--tx3);text-align:center;max-width:400px;line-height:1.5}.progress{width:300px;height:6px;background:var(--sf2);border-radius:3px;overflow:hidden}.progress div{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--ac),var(--pk));transition:width .5s}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:var(--sf);border:1px solid var(--bd);border-radius:var(--rd);padding:36px;width:100%;max-width:440px;box-shadow:0 24px 80px #0009;animation:scaleIn .3s;position:relative}.modal h2{font-family:"Instrument Serif",serif;font-size:24px;margin-bottom:6px}.modal-sub{color:var(--tx2);margin-bottom:18px;font-size:14px}.modal label{display:block;font-size:13px;color:var(--tx2);margin-bottom:5px;font-weight:500}.modal-close{position:absolute;top:14px;right:18px;background:none;border:none;color:var(--tx3);cursor:pointer;font-size:18px}.hero{padding:70px 20px 50px;text-align:center;position:relative;max-width:820px;margin:0 auto}.hero-glow{position:absolute;top:-200px;left:50%;transform:translate(-50%);width:600px;height:400px;background:radial-gradient(ellipse,rgba(249,115,22,.08),transparent 70%);pointer-events:none}.badge{display:inline-flex;align-items:center;gap:8px;padding:5px 14px 5px 8px;background:var(--sf2);border:1px solid var(--bd);border-radius:100px;font-size:13px;color:var(--tx2);margin-bottom:24px;animation:fadeUp .6s both}.badge-dot{width:8px;height:8px;border-radius:50%;background:var(--gn);animation:pulse 2s infinite;display:inline-block}.hero h1{font-family:"Instrument Serif",serif;font-size:clamp(40px,8vw,72px);line-height:1;letter-spacing:-2px;margin-bottom:18px;background:linear-gradient(180deg,var(--tx) 40%,var(--tx3));-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:fadeUp .6s .1s both}.hero h1 em{-webkit-text-fill-color:var(--ac);font-style:italic}.hero p{font-size:16px;line-height:1.6;color:var(--tx2);max-width:500px;margin:0 auto 36px;animation:fadeUp .6s .2s both}.hero-cta{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;animation:fadeUp .6s .3s both}.backend-warning{margin-top:24px;padding:14px 20px;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--rs);font-size:13px;color:#ef4444;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.6}.backend-warning code{background:#ffffff0f;padding:2px 6px;border-radius:4px;font-family:Space Mono,monospace;font-size:11px}.firebase-warning{margin-top:12px;padding:14px 20px;background:#f9731614;border:1px solid rgba(249,115,22,.2);border-radius:var(--rs);font-size:13px;color:var(--ac);max-width:600px;margin-left:auto;margin-right:auto;line-height:1.6}.features{max-width:1000px;margin:0 auto;padding:12px 20px 70px;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}.feature-card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--rd);padding:26px;transition:all .3s;position:relative;overflow:hidden;animation:fadeUp .5s both}.feature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--ac),transparent);opacity:0;transition:opacity .3s}.feature-card:hover{border-color:var(--tx3);transform:translateY(-3px)}.feature-card:hover:before{opacity:1}.feature-icon{width:40px;height:40px;border-radius:10px;background:#f973161f;display:flex;align-items:center;justify-content:center;font-size:19px;margin-bottom:12px}.feature-card h3{font-size:15px;margin-bottom:4px;font-weight:600}.feature-card p{color:var(--tx2);font-size:12px;line-height:1.5}.dashboard{max-width:1200px;margin:0 auto;padding:28px 20px 60px}.dash-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.dash-header h1{font-family:"Instrument Serif",serif;font-size:30px}.dash-meta{color:var(--tx2);margin-top:3px;font-size:13px}.code-badge{display:flex;align-items:center;gap:10px;background:var(--sf);border:1px solid var(--bd);border-radius:var(--rs);padding:8px 14px;cursor:pointer;transition:all .2s}.code-badge:hover{border-color:var(--ac);background:var(--acg)}.code-label{display:block;font-size:9px;color:var(--tx3)}.code-value{display:block;font-family:Space Mono,monospace;font-size:15px;color:var(--ac);letter-spacing:3px}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:9px;margin-bottom:24px}.stat{background:var(--sf);border:1px solid var(--bd);border-radius:var(--rs);padding:12px}.stat-num{font-family:"Instrument Serif",serif;font-size:24px;background:linear-gradient(135deg,var(--tx),var(--tx2));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.stat-label{font-size:9px;color:var(--tx3);text-transform:uppercase;letter-spacing:1px}.tabs{display:flex;gap:3px;background:var(--sf);border:1px solid var(--bd);border-radius:var(--rs);padding:3px;margin-bottom:20px;width:fit-content;flex-wrap:wrap}.tab{padding:9px 18px;border-radius:6px;font-size:14px;font-weight:500;color:var(--tx2);border:none;background:none;cursor:pointer;transition:all .2s;font-family:DM Sans,sans-serif}.tab:hover{color:var(--tx)}.tab.on{background:var(--ac);color:#fff}.upload-zone{border:2px dashed var(--bd);border-radius:var(--rd);padding:44px 24px;text-align:center;cursor:pointer;transition:all .3s}.upload-zone.drag{border-color:var(--ac);background:var(--acg)}.upload-icon{font-size:38px;margin-bottom:8px;animation:float 3s ease-in-out infinite}.upload-zone h3{font-size:16px;margin-bottom:4px}.upload-zone p{color:var(--tx2);font-size:12px}.log-controls{margin-top:14px;display:flex;gap:6px;flex-wrap:wrap}.log-panel{background:var(--sf);border:1px solid var(--bd);border-radius:var(--rs);padding:14px;margin-top:10px;max-height:250px;overflow-y:auto;font-family:Space Mono,monospace;font-size:11px;line-height:1.6;color:var(--tx3)}.log-entry{padding:2px 0;border-bottom:1px solid rgba(255,255,255,.03);word-break:break-all}.log-entry.ok{color:var(--gn)}.log-entry.err{color:#ef4444}.log-entry.info{color:var(--ac)}.log-time{color:var(--tx3);margin-right:8px}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px;margin-top:16px}.photo-grid.sm{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:7px}.photo-card{position:relative;border-radius:var(--rs);overflow:hidden;aspect-ratio:1;background:var(--sf2);cursor:pointer;transition:transform .3s}.photo-card:hover{transform:scale(1.04);z-index:1}.photo-card img{width:100%;height:100%;object-fit:cover;display:block}.photo-badges{position:absolute;bottom:4px;left:4px;display:flex;gap:2px;flex-wrap:wrap}.badge-tag{padding:2px 6px;border-radius:100px;font-size:9px;font-weight:700;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff}.badge-tag.scene{color:#888}.badge-tag.group{background:#f97316cc}.face-box{position:absolute;border:2px solid var(--ac);border-radius:4px;opacity:0;transition:opacity .3s;pointer-events:none}.photo-card:hover .face-box{opacity:1}.person-section{margin-bottom:28px}.person-header{display:flex;align-items:center;gap:11px;margin-bottom:11px;padding-bottom:11px;border-bottom:1px solid var(--bd);flex-wrap:wrap}.person-avatar{width:44px;height:44px;border-radius:50%;overflow:hidden;border:3px solid;flex-shrink:0}.person-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px;border-radius:50%}.person-name{font-size:15px;font-weight:600}.person-count{font-size:11px;color:var(--tx2)}.person-actions{margin-left:auto;display:flex;gap:5px;align-items:center;flex-wrap:wrap}.members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:9px}.member-card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--rs);padding:14px;display:flex;align-items:center;gap:10px}.member-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;flex-shrink:0}.member-name{font-weight:600;font-size:13px}.member-role{font-size:10px;color:var(--tx2)}.download-all{background:linear-gradient(135deg,var(--sf),var(--sf2));border:1px solid var(--bd);border-radius:var(--rd);padding:20px;margin-top:14px;display:flex;align-items:center;gap:12px;animation:glow 3s ease-in-out infinite;flex-wrap:wrap}.dl-icon{font-size:28px}.download-all h3{font-size:14px;margin-bottom:2px}.download-all p{font-size:11px;color:var(--tx2)}.download-all .bp{margin-left:auto}.empty{text-align:center;padding:50px 20px;color:var(--tx3)}.empty-icon{font-size:44px;opacity:.5;margin-bottom:8px}.empty h3{font-size:16px;color:var(--tx2);margin-bottom:4px}.empty p{font-size:12px}@media(max-width:640px){.photo-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.person-header{flex-direction:column;align-items:flex-start}.person-actions{margin-left:0;width:100%}.dash-header{flex-direction:column}}
