:root{--bg: #0a0a0a;--bg2: #141414;--bg3: #1e1e1e;--text: #f5f5f5;--text-secondary: #a0a0a0;--hint: #6b6b6b;--accent: #f4bd03;--accent-hover: #ffd000;--accent-text: #000000;--accent-glow: rgba(244,189,3,.15);--accent-border: rgba(244,189,3,.12);--glass-bg: rgba(8,8,16,.75);--glass-border: rgba(244,189,3,.15);--link: #f4bd03;--danger: #ff2357;--success: #30d158;--header-h: 0px;--radius: 14px;--radius-sm: 10px}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html{background:#0a0a0a;color:#f5f5f5;color-scheme:dark}body{font-family:Inter Tight,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);height:100vh;overflow:hidden;display:flex;flex-direction:column}@keyframes glassShine{0%{transform:translate(-100%) translateY(-100%) rotate(35deg)}to{transform:translate(200%) translateY(200%) rotate(35deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{box-shadow:0 0 16px #f4bd0326}50%{box-shadow:0 0 24px #f4bd0340}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulse-text{0%,to{opacity:.6}50%{opacity:1}}.app-header{position:fixed;top:0;left:0;right:0;z-index:100;padding-top:env(safe-area-inset-top,0)}.header-bg{position:absolute;inset:0;background:url(/sidebar-bg.png) center/cover no-repeat;z-index:-2}.header-bg:after{content:"";position:absolute;inset:0;background:#06060cd1;backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4)}.header-shine{position:absolute;inset:0;overflow:hidden;z-index:-1;pointer-events:none}.header-shine:after{content:"";position:absolute;top:-50%;left:-50%;width:40%;height:200%;background:linear-gradient(90deg,transparent,rgba(244,189,3,.04),transparent);animation:glassShine 12s linear infinite}.header-content{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;padding:12px 16px}.header-row{display:flex;align-items:center;justify-content:center;position:relative;width:100%}.header-logo{height:22px;object-fit:contain;cursor:pointer;filter:brightness(1.1)}.header-badges{position:absolute;right:16px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:8px}.header-tab{flex:1;padding:6px 12px;border-radius:20px;background:#ffffff0f;color:var(--text-secondary);border:1px solid rgba(255,255,255,.06);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;text-align:center;font-family:inherit;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.header-tab.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.tab-page{flex:1;overflow-y:auto;padding:12px 14px calc(env(safe-area-inset-bottom,0px) + 16px);padding-top:calc(var(--header-h) + 12px);animation:fadeIn .3s ease}.top-nav{position:relative;z-index:1;display:flex;background:var(--bg2);border-bottom:1px solid var(--accent-border)}.top-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 0;background:none;border:none;color:var(--hint);font-size:10px;font-weight:600;cursor:pointer;transition:color .2s;position:relative;font-family:inherit}.top-nav-btn svg{width:20px;height:20px}.top-nav-btn.active{color:var(--accent)}.top-nav-btn.active:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:24px;height:2px;background:var(--accent);border-radius:2px 2px 0 0}.sub-tabs-drawer{position:relative;z-index:1;overflow:hidden;max-height:0;transition:max-height .3s ease;background:var(--bg);border-bottom:1px solid transparent}.sub-tabs-drawer.open{max-height:48px;border-bottom-color:var(--accent-border)}.sub-tabs-inner{display:flex;gap:6px;padding:6px 14px 8px}.section{margin-bottom:16px}.section-title{font-family:Bebas Neue,Inter Tight,sans-serif;font-size:16px;font-weight:400;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px;margin-top:8px}.content-group{margin-bottom:20px}.content-divider{border-bottom:1px solid rgba(255,255,255,.04);padding-bottom:20px;margin-bottom:20px}.btn-primary{width:100%;padding:15px;background:var(--accent);color:var(--accent-text);border:none;border-radius:var(--radius);font-size:16px;font-weight:700;cursor:pointer;margin-top:8px;transition:all .2s;font-family:inherit;animation:pulse 3s ease-in-out infinite}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;animation:none}.btn-secondary{width:100%;padding:15px;background:transparent;color:var(--accent);border:2px solid var(--accent);border-radius:var(--radius);font-size:16px;font-weight:700;cursor:pointer;margin-top:12px;transition:all .2s;font-family:inherit}.btn-secondary:hover{background:#f4bd0314}.btn-sm{padding:7px 12px;background:var(--bg2);color:var(--text);border:1px solid rgba(255,255,255,.12);border-radius:8px;font-size:13px;cursor:pointer;font-family:inherit}.btn-danger{background:var(--danger);color:#fff;border:none;border-radius:8px;padding:7px 12px;font-size:13px;cursor:pointer}.ref-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;min-height:68px;align-items:center}.ref-row::-webkit-scrollbar{display:none}.ref-thumb{position:relative;width:60px;height:60px;flex-shrink:0;border-radius:10px;overflow:hidden;border:2px solid var(--accent);box-shadow:0 0 10px #f4bd0326}.ref-thumb img{width:100%;height:100%;object-fit:cover}.ref-remove{position:absolute;top:2px;right:2px;width:16px;height:16px;background:#000000b3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;color:#fff;cursor:pointer;border:none}.ref-empty{color:var(--hint);font-size:13px;width:100%;text-align:center;padding:16px 0;display:flex;flex-direction:column;align-items:center;gap:2px}.ref-add-btn{width:60px;height:60px;flex-shrink:0;border-radius:10px;border:2px dashed var(--hint);background:none;color:var(--hint);font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s,color .2s}.ref-add-btn:hover{border-color:var(--accent);color:var(--accent)}.ref-counter{font-size:12px;color:var(--text-secondary);margin-left:4px}.format-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.format-card{background:var(--bg3);border-radius:var(--radius-sm);padding:10px 6px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;border:2px solid rgba(255,255,255,.04);transition:border-color .2s,background .2s,box-shadow .2s}.format-card.selected{border-color:var(--accent);background:#f4bd0314;box-shadow:0 0 12px #f4bd031a}.format-shape{background:var(--hint);opacity:.5;flex-shrink:0}.format-card.selected .format-shape{background:var(--accent);opacity:1}.format-label{font-size:11px;font-weight:600;text-align:center;line-height:1.2;color:var(--text-secondary)}.format-card:active{transform:scale(.96)}.format-card.selected .format-label{color:var(--text)}.format-ratio{font-size:9px;color:var(--hint)}.batch-row{display:flex;gap:8px}.batch-btn{flex:1;padding:10px;background:var(--bg3);color:var(--hint);border:2px solid rgba(255,255,255,.04);border-radius:var(--radius-sm);font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit}.batch-btn:active{transform:scale(.96)}.batch-btn.active{background:#f4bd031a;color:var(--accent);border-color:var(--accent)}.freestyle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0}.freestyle-label{display:flex;flex-direction:column;gap:2px}.freestyle-label span:first-child{font-size:14px;font-weight:600;color:var(--text)}.freestyle-label span:last-child{font-size:12px;color:var(--hint)}.toggle-switch{position:relative;width:44px;height:24px;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;inset:0;background:var(--bg3);border-radius:12px;border:1px solid rgba(255,255,255,.1);transition:all .2s}.toggle-slider:before{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--hint);transition:all .2s}.toggle-switch input:checked+.toggle-slider{background:var(--accent);border-color:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px);background:var(--accent-text)}textarea{width:100%;background:var(--bg3);color:var(--text);border:1px solid var(--accent-border);border-radius:var(--radius-sm);padding:12px 14px;font-size:14px;resize:none;font-family:inherit;line-height:1.5;transition:border-color .2s}textarea:focus{outline:none;border-color:#f4bd0366;box-shadow:0 0 12px #f4bd0314}textarea::placeholder{color:var(--hint)}.campaign-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#f4bd031a;border:1px solid rgba(244,189,3,.25);border-radius:20px;font-size:12px;font-weight:600;color:var(--accent);margin-bottom:8px}.campaign-chip-close{width:16px;height:16px;border-radius:50%;background:#f4bd0333;border:none;color:var(--accent);font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center}.accordion-trigger{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.accordion-body{display:none;margin-top:10px}.accordion-body.open{display:block}.results-grid{display:flex;flex-direction:column;gap:14px;margin-top:14px}.result-card{border-radius:var(--radius);overflow:hidden;background:var(--bg2);border:1px solid var(--accent-border)}.result-card img{width:100%;display:block}.result-actions{padding:10px;display:flex;flex-direction:column;gap:6px}.result-actions-row{display:flex;gap:6px}.result-btn{flex:1;padding:10px 8px;background:var(--bg3);color:var(--text);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}.result-btn:active{transform:scale(.97)}.result-btn.accent{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.result-btn .btn-icon{font-size:15px;line-height:1}.dl-btn{flex:1;padding:8px;background:var(--accent);color:var(--accent-text);border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}.skeleton{border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--bg2) 25%,var(--bg3) 50%,var(--bg2) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;aspect-ratio:1}.collection-bar{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;margin-bottom:12px;scrollbar-width:none}.collection-bar::-webkit-scrollbar{display:none}.col-chip{flex-shrink:0;padding:6px 14px;border-radius:20px;background:var(--bg2);color:var(--text-secondary);border:1px solid rgba(255,255,255,.06);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s;font-family:inherit}.col-chip.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.col-chip.new{background:none;border:1.5px dashed var(--hint);color:var(--hint)}.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.product-item{position:relative;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;border:2.5px solid transparent;transition:border-color .2s}.product-item.selected{border-color:var(--accent)}.product-item img{width:100%;height:100%;object-fit:cover;display:block}.product-check{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;background:var(--accent);color:#000;font-size:11px;font-weight:700;display:none;align-items:center;justify-content:center}.product-item.selected .product-check{display:flex}.product-delete{position:absolute;bottom:4px;right:4px;width:20px;height:20px;border-radius:50%;background:#0009;color:#fff;font-size:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none}.fab{position:fixed;bottom:calc(env(safe-area-inset-bottom,0px) + 16px);right:16px;width:52px;height:52px;border-radius:50%;background:var(--accent);color:var(--accent-text);font-size:28px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #f4bd0366;z-index:100;transition:transform .15s}.fab:active{transform:scale(.92)}.history-card{background:var(--bg2);border:1px solid var(--accent-border);border-radius:var(--radius);margin-bottom:12px;overflow:hidden}.history-outputs{display:grid;grid-template-columns:repeat(2,1fr);gap:2px}.history-output{position:relative}.history-output img{width:100%;display:block;aspect-ratio:1;object-fit:cover;cursor:pointer}.history-output .dl-btn{position:absolute;bottom:6px;right:6px;width:30px;height:30px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:14px}.history-outputs.single .history-output img{aspect-ratio:unset;max-height:260px}.history-meta{padding:10px 12px 6px}.history-scene{font-size:14px;margin-bottom:6px;line-height:1.4;color:var(--text)}.badges{display:flex;gap:6px;flex-wrap:wrap}.badge{padding:3px 8px;background:var(--bg3);border-radius:6px;font-size:11px;color:var(--text-secondary);font-weight:500}.history-refs{padding:6px 12px;display:flex;gap:6px;overflow-x:auto;scrollbar-width:none}.history-refs::-webkit-scrollbar{display:none}.ref-mini{width:36px;height:36px;border-radius:6px;object-fit:cover;flex-shrink:0;border:1px solid rgba(255,255,255,.08)}.history-footer{padding:8px 12px 12px;display:flex;gap:8px}.rerun-btn{flex:1;padding:9px;background:transparent;color:var(--accent);border:1.5px solid var(--accent);border-radius:9px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}.del-gen-btn{width:40px;padding:9px 0;background:transparent;color:var(--danger);border:1.5px solid rgba(255,69,58,.3);border-radius:9px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fav-btn{position:absolute;top:6px;left:6px;width:30px;height:30px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:16px;background:#00000080;border:none;cursor:pointer;color:#ffffffb3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.fav-btn.active{color:#ff2d55}.filter-bar{display:flex;gap:8px;margin-bottom:12px}.filter-chip{padding:6px 14px;border-radius:20px;background:var(--bg2);color:var(--text-secondary);border:1px solid rgba(255,255,255,.06);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}.filter-chip.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.compare-overlay{display:none;position:fixed;inset:0;background:#000000f2;z-index:400;flex-direction:column;align-items:center;justify-content:center;padding:20px}.compare-overlay.open{display:flex}.compare-close{position:absolute;top:calc(env(safe-area-inset-top,0px) + 16px);right:16px;width:36px;height:36px;border-radius:50%;background:#ffffff1a;border:none;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.compare-label{font-size:12px;font-weight:600;color:#fff6;text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}.compare-container{position:relative;width:100%;max-width:400px;aspect-ratio:1;border-radius:12px;overflow:hidden;touch-action:none}.compare-container img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.compare-container .compare-after{clip-path:inset(0 0 0 50%)}.compare-slider{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;z-index:2;cursor:ew-resize}.compare-slider:after{content:"◀▶";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:36px;height:36px;border-radius:50%;background:#fff;color:#1a1a1a;display:flex;align-items:center;justify-content:center;font-size:10px;letter-spacing:2px;box-shadow:0 2px 8px #0000004d}.compare-labels{display:flex;justify-content:space-between;width:100%;max-width:400px;margin-top:12px}.compare-labels span{font-size:12px;color:#fff6;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.booking-overlay{display:none;position:fixed;inset:0;background:#000000b3;z-index:500;align-items:flex-end;justify-content:center}.booking-overlay.open{display:flex}.booking-sheet{background:var(--bg);border-radius:16px 16px 0 0;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;padding:20px 16px env(safe-area-inset-bottom,16px)}.booking-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.booking-header h3{font-size:18px;font-weight:700}.booking-close{width:32px;height:32px;border-radius:50%;background:var(--bg2);border:none;color:var(--text);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}.booking-steps{display:flex;gap:6px;margin-bottom:18px}.booking-step{flex:1;height:3px;border-radius:2px;background:var(--bg3)}.booking-step.active{background:var(--accent)}.booking-step.done{background:var(--success)}.pkg-card{background:var(--bg2);border-radius:var(--radius);padding:14px;margin-bottom:10px;cursor:pointer;border:2px solid rgba(255,255,255,.04);transition:border-color .2s,box-shadow .2s}.pkg-card.selected{border-color:var(--accent);box-shadow:0 0 16px #f4bd031a}.pkg-card h4{font-size:16px;margin-bottom:4px}.pkg-card .pkg-price{color:var(--accent);font-weight:700;font-size:18px}.pkg-card .pkg-deposit{color:var(--hint);font-size:13px}.pkg-card .pkg-desc{color:var(--text-secondary);font-size:13px;margin:6px 0;line-height:1.4}.pkg-card .pkg-includes{list-style:none;padding:0}.pkg-card .pkg-includes li{font-size:12px;color:var(--text-secondary);padding:2px 0}.pkg-card .pkg-includes li:before{content:"✓";color:var(--success)}.slot-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.slot-day-label{grid-column:1 / -1;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-top:8px}.slot-btn{padding:10px 8px;background:var(--bg2);color:var(--text);border:2px solid rgba(255,255,255,.04);border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;text-align:center;transition:all .2s;font-family:inherit}.slot-btn.selected{border-color:var(--accent);background:#f4bd0314;color:var(--accent)}.booking-input{width:100%;background:var(--bg2);color:var(--text);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);padding:12px 14px;font-size:15px;margin-bottom:10px;font-family:inherit}.booking-input::placeholder{color:var(--hint)}.capture-tip{background:#f4bd030f;border-left:3px solid var(--accent);padding:10px 12px;border-radius:0 8px 8px 0;margin-bottom:12px;font-size:13px;color:var(--text-secondary);line-height:1.5}.capture-tip strong{color:var(--accent)}.summary-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px;border-bottom:1px solid rgba(255,255,255,.04)}.summary-row:last-child{border-bottom:none}.summary-label{color:var(--text-secondary)}.summary-value{font-weight:600}.btn-back{padding:12px 20px;background:var(--bg2);color:var(--text);border:none;border-radius:var(--radius);font-size:15px;font-weight:600;cursor:pointer;font-family:inherit}.booking-actions{display:flex;gap:10px;margin-top:16px}.booking-actions .btn-primary{flex:2;margin:0;animation:none}.booking-actions .btn-back{flex:1}.empty-state{text-align:center;color:var(--text-secondary);font-size:14px;padding:40px 20px;line-height:1.6}.error-msg{background:#ff453a1a;color:var(--danger);border:1px solid rgba(255,69,58,.2);border-radius:var(--radius-sm);padding:12px;font-size:13px;text-align:center}.toast{position:fixed;bottom:calc(env(safe-area-inset-bottom,0px) + 16px);left:50%;transform:translate(-50%) translateY(20px);background:var(--glass-bg);color:#fff;padding:10px 18px;border-radius:20px;font-size:13px;font-weight:500;opacity:0;transition:all .25s;white-space:nowrap;z-index:999;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--glass-border)}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.modal-overlay{display:none;position:fixed;inset:0;background:#0009;z-index:300;align-items:flex-end;justify-content:center}.modal-overlay.open{display:flex}.modal-sheet{background:var(--bg2);border-radius:16px 16px 0 0;padding:20px 16px;width:100%;max-width:480px;border-top:1px solid var(--accent-border)}.modal-sheet h3{font-size:16px;margin-bottom:14px}.modal-sheet input[type=text]{width:100%;background:var(--bg);color:var(--text);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);padding:11px 14px;font-size:15px;margin-bottom:12px;font-family:inherit}.modal-row{display:flex;gap:8px}.campaign-cards{display:flex;flex-direction:column;gap:10px}.campaign-card{border-radius:var(--radius);padding:16px;cursor:pointer;transition:all .3s;border:1px solid rgba(255,255,255,.04);background:var(--bg2);opacity:.4}.campaign-card.active-campaign{opacity:1;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(244,189,3,.25);box-shadow:0 0 20px #f4bd031f}.campaign-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.campaign-card-name{font-size:16px;font-weight:700;color:var(--text)}.campaign-card-badge{font-size:10px;font-weight:800;padding:3px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.05em;background:#f4bd0333;color:var(--accent)}.campaign-card-scene{font-size:13px;color:var(--text-secondary);line-height:1.4;margin-bottom:10px}.campaign-card:not(.active-campaign) .campaign-card-scene{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.campaign-card-meta{display:flex;gap:8px;flex-wrap:wrap}.campaign-card-tag{padding:3px 8px;background:var(--bg3);border-radius:6px;font-size:11px;color:var(--text-secondary);font-weight:500}.campaign-card-load{margin-top:10px;width:100%;padding:10px;background:var(--accent);color:var(--accent-text);border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:700;cursor:pointer;font-family:inherit}.token-badge{display:flex;align-items:center;gap:4px;background:#f4bd031f;color:#f4bd03;font-size:12px;font-weight:700;padding:4px 10px;border-radius:20px;border:1px solid rgba(244,189,3,.25)}.token-badge.low{background:#ef44441f;color:#ef4444;border-color:#ef444440}.token-badge svg{width:14px;height:14px}.gen-progress{margin-top:12px}.gen-progress-bar{height:4px;background:#ffffff0f;border-radius:4px;overflow:hidden;margin-bottom:8px}.gen-progress-fill{height:100%;background:linear-gradient(90deg,#f4bd03,#ffd000);border-radius:4px;transition:width .8s ease;width:0%}.gen-progress-text{font-size:12px;color:var(--text-secondary);text-align:center;animation:pulse-text 2s ease-in-out infinite}.account-section{margin-bottom:16px}.account-profile{display:flex;align-items:center;gap:14px;margin-bottom:14px}.account-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#ffd000);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;color:var(--accent-text);flex-shrink:0}.account-info{flex:1}.account-name{font-size:16px;font-weight:700;color:var(--text)}.account-plan{font-size:13px;color:var(--text-secondary);margin-top:2px}.account-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}.account-stat{background:var(--bg3);border-radius:var(--radius-sm);padding:12px;text-align:center}.account-stat-value{font-size:22px;font-weight:800;color:var(--accent)}.account-stat-label{font-size:11px;color:var(--hint);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.account-btn{width:100%;padding:13px;background:var(--bg3);color:var(--text);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;margin-top:8px;text-align:center;transition:all .2s;font-family:inherit}.account-btn:hover{border-color:var(--accent-border)}.account-btn.accent{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.booking-item{background:var(--bg3);border-radius:var(--radius);padding:14px;margin-bottom:10px;border:1px solid rgba(255,255,255,.04)}.booking-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.booking-item-title{font-weight:700;font-size:15px;color:var(--text)}.booking-status{font-size:11px;font-weight:700;padding:3px 8px;border-radius:10px;text-transform:uppercase}.booking-status.confirmed{background:#22c55e1f;color:#22c55e}.booking-status.pending{background:#f4bd031f;color:#f4bd03}.booking-status.cancelled{background:#ef44441f;color:#ef4444}.booking-status.expired{background:#9ca3af1f;color:#9ca3af}.booking-status.completed{background:#3b82f61f;color:#3b82f6}.booking-detail{font-size:13px;color:var(--text-secondary);margin-top:4px}.booking-detail span{color:var(--text)}.tier-badge{display:flex;align-items:center;gap:4px;font-size:10px;font-weight:800;padding:3px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.06em}.tier-badge.trial{background:#8b5cf61f;color:#a78bfa;border:1px solid rgba(139,92,246,.25)}.tier-badge.starter{background:#3b82f61f;color:#60a5fa;border:1px solid rgba(59,130,246,.25)}.tier-badge.pro{background:#f4bd031f;color:#f4bd03;border:1px solid rgba(244,189,3,.25)}.tier-badge.studio{background:#f4bd0333;color:#f4bd03;border:1px solid rgba(244,189,3,.4)}.tier-badge.expired{background:#ef44441f;color:#ef4444;border:1px solid rgba(239,68,68,.25)}.locked-overlay{position:relative}.locked-overlay:after{content:"🔒";position:absolute;inset:0;background:#00000080;border-radius:inherit;display:flex;align-items:center;justify-content:center;font-size:16px;pointer-events:none}.locked-overlay.clickable:after{pointer-events:auto;cursor:pointer}.premium-badge{display:inline-block;font-size:9px;font-weight:800;padding:2px 6px;border-radius:4px;background:#f4bd0326;color:#f4bd03;text-transform:uppercase;letter-spacing:.05em;margin-left:6px;vertical-align:middle}.pin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.pin-item{position:relative;aspect-ratio:.75;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;border:2px solid transparent;transition:border-color .2s,box-shadow .2s}.pin-item.selected{border-color:var(--accent);box-shadow:0 0 12px #f4bd0326}.pin-item img{width:100%;height:100%;object-fit:cover;display:block}.pin-fav{position:absolute;top:6px;right:6px;width:28px;height:28px;border-radius:50%;background:#00000080;border:none;cursor:pointer;color:#fff9;font-size:14px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:transform .15s}.pin-fav:active{transform:scale(1.2)}.pin-fav.active{color:#ff2d55}.pin-tabs{display:flex;gap:6px;margin-bottom:10px}.pin-tab{padding:6px 14px;border-radius:20px;background:var(--bg3);color:var(--text-secondary);border:1px solid rgba(255,255,255,.04);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s}.pin-tab.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.pin-detail-overlay{display:none;position:fixed;inset:0;background:#000000e6;z-index:400;flex-direction:column;align-items:center;justify-content:center;padding:20px}.pin-detail-overlay.open{display:flex}.pin-detail-img{max-width:100%;max-height:65vh;border-radius:var(--radius);object-fit:contain}.pin-detail-actions{display:flex;gap:10px;margin-top:16px;width:100%;max-width:300px}.pin-detail-actions button{flex:1;padding:12px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;border:none}.upgrade-banner{background:linear-gradient(135deg,#f4bd0314,#f4bd0308);border:1px solid rgba(244,189,3,.15);border-radius:var(--radius);padding:12px 14px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;gap:10px}.upgrade-banner-text{font-size:12px;color:var(--text-secondary);line-height:1.4}.upgrade-banner-text strong{color:#f4bd03}.upgrade-banner-btn{flex-shrink:0;padding:8px 16px;background:var(--accent);color:var(--accent-text);border:none;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer}.profile-sheet{display:none;position:fixed;inset:0;background:#000000b3;z-index:500;align-items:flex-end;justify-content:center}.profile-sheet.open{display:flex}.profile-content{background:var(--bg);border-radius:16px 16px 0 0;width:100%;max-width:480px;padding:20px 16px env(safe-area-inset-bottom,16px);border-top:1px solid var(--accent-border)}.profile-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.04)}.profile-row-label{font-size:14px;color:var(--text-secondary)}.profile-row-value{font-size:14px;font-weight:600;color:var(--text)}
