*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg-deep:#0a0a12;--bg-primary:#0e0e11;--bg-elevated:#151519;--bg-surface:#1a1a20;--bg-hover:#222229;
  --border:#2a2a33;--border-subtle:#1e1e26;
  --text-primary:#e8e6e3;--text-secondary:#a8a5a1;--text-muted:#5a5856;
  --accent:#8B5CF6;--accent-dim:#7C3AED;--accent-glow:rgba(139,92,246,0.18);
  --accent-light:#A78BFA;--accent-violet:#C4B5FD;
  --success:#4ade80;--error:#f87171;--processing:#60a5fa;--queued:#a78bfa;
  --radius:8px;--radius-sm:4px;--radius-lg:14px;
  --accent-rgb:139,92,246;
  --font-display:'Instrument Serif',Georgia,serif;
  --font-body:'DM Sans',system-ui,sans-serif;
  --font-mono:'Geist Mono',monospace;
  --gradient-brand:linear-gradient(135deg, #8B5CF6 0%, #A78BFA 50%, #C4B5FD 100%);
  --glass-bg:rgba(21,21,25,0.6);
  --glass-border:rgba(139,92,246,0.18);
  --glass-blur:blur(20px);
}
html{font-size:15px;scrollbar-width:thin;scrollbar-color:#2a2a33 transparent}
body{font-family:var(--font-body);background:var(--bg-deep);color:var(--text-primary);min-height:100vh;overflow-x:hidden}
::selection{background:var(--accent);color:var(--bg-deep)}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#2a2a33;border-radius:3px}

input,select,textarea,button{font-family:inherit;font-size:inherit;color:inherit;border:none;outline:none;background:none}
a{color:inherit;text-decoration:none}

@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideIn{from{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:translateX(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes glow{0%,100%{box-shadow:0 0 20px var(--accent-glow)}50%{box-shadow:0 0 40px var(--accent-glow),0 0 60px rgba(139,92,246,0.05)}}
@keyframes float{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(2deg)}}
@keyframes revealUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes borderGlow{0%,100%{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 0 30px var(--accent-glow)}50%{border-color:var(--accent-light);box-shadow:0 0 0 1px var(--accent-light),0 0 50px rgba(139,92,246,.2),0 0 80px rgba(139,92,246,.06)}}
@keyframes textGlow{0%,100%{text-shadow:0 0 30px rgba(139,92,246,.2)}50%{text-shadow:0 0 60px rgba(139,92,246,.4),0 0 100px rgba(139,92,246,.12)}}
@keyframes ringPulse{0%,100%{transform:scale(1);opacity:.3}50%{transform:scale(1.08);opacity:.6}}

.layout{display:grid;grid-template-columns:220px 1fr;min-height:100vh}

.sidebar{
  background:var(--bg-primary);border-right:1px solid var(--border-subtle);
  padding:24px 0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;
}
.sidebar-logo{padding:0 24px;margin-bottom:36px}
.sidebar-logo h1{font-family:var(--font-display);font-size:1.6rem;font-weight:400;letter-spacing:-.02em;line-height:1}
.sidebar-logo h1 em{color:var(--accent);font-style:italic}
.sidebar-logo span{font-family:var(--font-mono);font-size:.65rem;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;display:block;margin-top:6px}

.nav-section{margin-bottom:8px}
.nav-section-title{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);padding:0 24px;margin-bottom:6px}
.nav-item{
  display:flex;align-items:center;gap:10px;padding:12px 24px;min-height:44px;cursor:pointer;
  transition:all .2s;font-size:.85rem;color:var(--text-secondary);position:relative;
}
.nav-item:hover{color:var(--text-primary);background:var(--bg-hover)}
.nav-item.active{color:var(--accent);background:var(--accent-glow)}
.nav-item.active::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent)}
.nav-item svg{width:16px;height:16px;flex-shrink:0;opacity:.7}
.nav-item.active svg{opacity:1}
.nav-badge{
  margin-left:auto;font-family:var(--font-mono);font-size:.6rem;
  background:var(--bg-surface);padding:2px 6px;border-radius:10px;color:var(--text-muted);
}

.credit-warning{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:.82rem;line-height:1.5}
.credit-warning strong{display:block}
.credit-warning a{color:var(--accent);text-decoration:underline;font-size:.78rem}
.credit-warning-empty{background:rgba(220,53,69,.08);border:1px solid rgba(220,53,69,.2)}
.credit-warning-low{background:rgba(230,168,23,.08);border:1px solid rgba(230,168,23,.2)}
.sidebar-credits{display:flex;align-items:center;gap:8px;padding:10px 14px;margin-bottom:12px;border-radius:8px;background:var(--bg-elevated);border:1px solid var(--border-subtle);text-decoration:none;transition:border-color .2s,background .2s}
.sidebar-credits:hover{border-color:var(--accent);background:var(--bg-surface)}
.sidebar-credits-count{font-family:var(--font-mono);font-size:.95rem;font-weight:600;color:var(--accent)}
.sidebar-credits-label{font-size:.72rem;color:var(--text-muted);letter-spacing:.02em}
.sidebar-footer{margin-top:auto;padding:16px 24px;border-top:1px solid var(--border-subtle)}
.user-info{display:flex;align-items:center;gap:10px}
.user-avatar{
  width:32px;height:32px;border-radius:50%;background:var(--accent-dim);
  display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.7rem;color:var(--bg-deep);font-weight:600;
}
.user-email{font-size:.75rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:120px}
.user-logout{font-size:.7rem;color:var(--text-muted);cursor:pointer;transition:color .2s}
.user-logout:hover{color:var(--error)}

.main{padding:32px 40px;overflow-y:auto}
.main-header{margin-bottom:32px;animation:fadeIn .5s ease}
.main-header h2{font-family:var(--font-display);font-size:2rem;font-weight:400;margin-bottom:4px}
.main-header p{color:var(--text-muted);font-size:.85rem}

.auth-page{
  display:flex;align-items:center;justify-content:center;min-height:100vh;
  padding-top:60px;
  background:var(--bg-deep);
}
.auth-card{
  width:380px;padding:40px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);
  animation:fadeIn .5s ease;
}
.auth-card h2{font-family:var(--font-display);font-size:2rem;font-weight:400;margin-bottom:6px;text-align:center}
.auth-card h2 em{color:var(--accent);font-style:italic}
.auth-subtitle{text-align:center;color:var(--text-muted);font-size:.82rem;margin-bottom:28px}

.form-group{margin-bottom:16px}
.form-label{display:block;font-family:var(--font-mono);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}
.form-input{
  width:100%;padding:10px 14px;background:var(--bg-elevated);border:1px solid var(--border-subtle);
  border-radius:var(--radius);font-size:.85rem;transition:all .2s;
}
.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.form-input::placeholder{color:var(--text-muted)}
textarea.form-input{resize:vertical;min-height:100px;font-family:var(--font-body)}
select.form-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%235a5856' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}

/* Custom select dropdown */
.studio-model-select{position:relative}
.custom-select-trigger{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  text-align:left;
}
.custom-select-trigger.open{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.custom-select-chevron{flex-shrink:0;transition:transform .2s;color:var(--text-muted)}
.custom-select-trigger.open .custom-select-chevron{transform:rotate(180deg)}
.custom-select-dropdown{
  display:none;position:absolute;bottom:100%;left:0;right:0;
  margin-bottom:6px;background:var(--bg-elevated);border:1px solid var(--border);
  border-radius:var(--radius);box-shadow:0 -8px 24px rgba(0,0,0,.4);
  max-height:280px;overflow-y:auto;z-index:100;
  scrollbar-width:thin;scrollbar-color:#2a2a33 transparent;
}
.custom-select-dropdown.open{display:block;animation:fadeIn .15s ease}
.custom-select-group-label{
  padding:8px 14px 4px;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--text-muted);
}
.custom-select-option{
  padding:8px 14px;font-size:.82rem;cursor:pointer;transition:background .12s;
  color:var(--text-secondary);
}
.custom-select-option:hover{background:var(--bg-hover);color:var(--text-primary)}
.custom-select-option.active{color:var(--accent);background:rgba(201,168,76,0.06)}

.btn{
  padding:10px 20px;border-radius:var(--radius);font-size:.82rem;font-weight:500;
  cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px;justify-content:center;
}
.btn-primary{
  background:var(--accent);color:var(--bg-deep);width:100%;
}
.btn-primary:hover{background:var(--accent-light);box-shadow:0 0 20px var(--accent-glow)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}
.btn-secondary{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--bg-hover);border-color:var(--accent-dim)}
.btn-ghost{color:var(--text-secondary);padding:6px 12px}
.btn-ghost:hover{color:var(--text-primary);background:var(--bg-hover)}

.alert{padding:10px 14px;border-radius:var(--radius);font-size:.8rem;margin-bottom:16px;border:1px solid}
.alert-error{background:rgba(248,113,113,.08);border-color:rgba(248,113,113,.2);color:var(--error)}
.alert-success{background:rgba(74,222,128,.08);border-color:rgba(74,222,128,.2);color:var(--success)}

.model-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.model-card{
  background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);
  padding:20px;cursor:pointer;transition:all .25s;position:relative;overflow:hidden;
}
.model-card:hover{border-color:var(--accent-dim);transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.3)}
.model-card.selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.model-card-type{
  font-family:var(--font-mono);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;
  padding:3px 8px;border-radius:10px;display:inline-block;margin-bottom:10px;
}
.model-card-type.image{background:rgba(201,168,76,.15);color:var(--accent)}
.model-card-type.video{background:rgba(162,89,255,.15);color:#a78bfa}
.model-card h3{font-size:.95rem;font-weight:500;margin-bottom:4px}
.model-card .model-key{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted)}

.main:has(.studio-page){padding:0;overflow:hidden}
.studio-page{display:flex;flex-direction:column;height:calc(100vh - 64px)}
.studio-content{flex:1;overflow:hidden;display:grid;grid-template-columns:1fr 200px;gap:0}
.studio-board{padding:24px;display:flex;flex-direction:column;overflow:hidden;align-items:center}
.studio-board-header{margin-bottom:16px;animation:fadeIn .5s ease;flex-shrink:0;width:100%;max-width:800px;text-align:center}
.studio-board-header h2{font-family:var(--font-display);font-size:2rem;font-weight:400;margin-bottom:4px}
.studio-board-header p{color:var(--text-muted);font-size:.85rem}
.board-feed{flex:1;overflow-y:auto;display:flex;flex-direction:column-reverse;gap:12px;padding-bottom:8px;width:100%;align-items:center}
.board-card{
  background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);
  padding:14px;width:100%;max-width:800px;animation:fadeIn .4s ease;transition:border-color .2s;flex-shrink:0;
}
.board-card:hover{border-color:var(--border)}
.board-card-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.board-card-model{font-size:.78rem;font-weight:500}
.board-card-time{font-family:var(--font-mono);font-size:.6rem;color:var(--text-muted);margin-left:auto}
.board-card-body{margin-bottom:8px}
.board-card-body:empty{display:none}
.board-card-body img{max-width:500px;width:100%;border-radius:var(--radius);cursor:pointer;transition:transform .2s}
.board-card-body img:hover{transform:scale(1.02)}
.board-card-body video{max-width:400px;width:100%;border-radius:var(--radius)}
.board-card-prompt{font-size:.75rem;color:var(--text-muted);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.board-card-spinner{display:flex;align-items:center;gap:8px;padding:16px 0}
.board-card-spinner::before{content:'';width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}
.board-card-spinner span{font-size:.72rem;color:var(--text-muted)}
.board-card-error{font-size:.75rem;color:var(--error);background:rgba(248,113,113,.06);padding:8px 12px;border-radius:var(--radius)}
.board-empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;
  color:var(--text-muted);font-size:.85rem;text-align:center;
}
.studio-history{border-left:1px solid var(--border-subtle);padding:16px 12px;overflow-y:auto}
.history-title{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-dim);margin-bottom:12px}
.history-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.history-thumb{aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;border:1px solid var(--border-subtle);transition:all .2s}
.history-thumb:hover{border-color:var(--accent);transform:scale(1.05)}
.history-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.studio-form-bar{
  flex-shrink:0;position:relative;
  background:rgba(14,14,17,.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  padding:16px 40px;
}
.studio-form-bar::before{
  content:'';position:absolute;top:0;right:0;left:-220px;height:1px;background:var(--border-subtle);
}
.studio-form-row{display:flex;align-items:center;gap:12px}
.studio-form-row .form-group{margin-bottom:0}
.studio-form-row .studio-model-select{width:160px;flex-shrink:0}
.studio-form-row .studio-model-select .form-input{height:42px}
.studio-form-row .studio-prompt-group{flex:1;min-width:0}
.studio-form-row textarea.form-input{resize:none;height:42px;min-height:42px;max-height:120px;padding:10px 14px;font-size:.85rem}
.studio-form-row .btn{flex-shrink:0;height:42px;padding:0 24px;white-space:nowrap;width:auto}
.studio-advanced{
  max-height:0;overflow:hidden;transition:max-height .4s ease,opacity .3s ease,margin .3s ease;
  opacity:0;margin-top:0;
}
.studio-advanced.open{max-height:800px;opacity:1;margin-top:12px;overflow:visible}
.studio-advanced-inner{
  background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius);
  padding:20px;
}
.file-upload{position:relative}
.file-upload input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer;z-index:1}
.file-upload-label{
  display:flex;align-items:center;gap:8px;padding:10px 12px;
  border:1px dashed var(--border);border-radius:var(--radius-sm);
  font-size:.75rem;color:var(--text-muted);cursor:pointer;transition:all .2s;
}
.file-upload:hover .file-upload-label{border-color:var(--accent-dim);background:rgba(201,168,76,.03)}
.studio-advanced-toggle{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-muted);cursor:pointer;padding:8px 0;transition:color .2s;border:none;background:none;
}
.studio-advanced-toggle:hover{color:var(--text-secondary)}
.studio-advanced-toggle svg{transition:transform .2s}
.studio-advanced-toggle.open svg{transform:rotate(180deg)}
.studio-form-section{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border-subtle)}
.studio-form-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.studio-form-section-title{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-dim);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.model-params{display:none}
.model-params.active{display:block}
.params-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.params-grid .full-width{grid-column:1/-1}
.form-row{display:flex;gap:12px}
.form-row .form-group{flex:1}

.form-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;padding:8px 0}
.form-toggle input[type="checkbox"]{display:none}
.toggle-track{
  width:36px;height:20px;border-radius:10px;background:var(--bg-surface);border:1px solid var(--border);
  position:relative;transition:all .2s;flex-shrink:0;
}
.toggle-track::after{
  content:'';position:absolute;top:2px;left:2px;width:14px;height:14px;
  border-radius:50%;background:var(--text-muted);transition:all .2s;
}
.form-toggle input[type="checkbox"]:checked~.toggle-track{background:var(--accent);border-color:var(--accent)}
.form-toggle input[type="checkbox"]:checked~.toggle-track::after{left:18px;background:var(--bg-deep)}
.toggle-label{font-size:.82rem;color:var(--text-secondary)}

.form-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.form-label-row .form-label{margin-bottom:0}
.form-hint{font-family:var(--font-mono);font-size:.65rem;color:var(--text-muted)}
.file-dropzone{
  border:1px dashed var(--border);border-radius:var(--radius);padding:20px;text-align:center;
  cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:8px;
}
.file-dropzone:hover,.file-dropzone.dragover{border-color:var(--accent-dim);background:var(--accent-glow)}
.file-dropzone svg{opacity:.4}
.file-dropzone span{font-size:.75rem;color:var(--text-muted)}
.upload-previews{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.upload-previews:empty{margin-bottom:0}
.upload-thumb{position:relative;width:72px;height:72px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border-subtle)}
.upload-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.upload-thumb-remove{
  position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;
  background:rgba(0,0,0,.7);color:#fff;border:none;cursor:pointer;font-size:12px;
  display:flex;align-items:center;justify-content:center;line-height:1;padding:0;
}
.upload-thumb-remove:hover{background:rgba(200,50,50,.9)}
.upload-thumb.uploading img{opacity:.4}
.upload-thumb-check{
  position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;
  background:rgba(40,167,69,.85);color:#fff;font-size:11px;
  display:flex;align-items:center;justify-content:center;line-height:1;
}
.upload-progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:rgba(0,0,0,.3)}
.upload-progress-bar{height:100%;background:var(--accent);transition:width .15s}


.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.template-card{
  background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);
  overflow:hidden;transition:all .25s;display:flex;flex-direction:column;
}
.template-card:hover{border-color:var(--accent-dim);box-shadow:0 8px 30px rgba(0,0,0,.3)}
.template-card-img{width:100%;aspect-ratio:4/3;object-fit:cover;background:var(--bg-surface);display:block}
.template-card-body{padding:14px;display:flex;flex-direction:column;flex:1}
.template-card-body h4{font-size:.85rem;font-weight:500;margin-bottom:6px}
.template-prompt-preview{font-size:.72rem;color:var(--text-muted);line-height:1.5;margin-bottom:12px}
.template-prompt-preview strong{color:var(--accent);font-weight:500}
.template-form-fields{display:flex;flex-direction:column;gap:10px;margin-top:auto}
.template-keyword-input{font-size:.78rem;padding:8px 10px}
.template-upload-area{
  border:1px dashed var(--border-subtle);border-radius:var(--radius-sm);
  cursor:pointer;transition:all .2s;overflow:hidden;
}
.template-upload-area:hover{border-color:var(--accent-dim);background:rgba(201,168,76,.03)}
.template-upload-area.has-file{border-style:solid;border-color:var(--accent-dim)}
.template-upload-placeholder{
  display:flex;align-items:center;gap:8px;padding:10px 12px;
  font-size:.72rem;color:var(--text-muted);
}
.template-upload-area.has-file .template-upload-placeholder{display:none}
.template-upload-preview{width:100%;max-height:120px;overflow:hidden}
.template-upload-preview img{width:100%;height:100%;object-fit:cover;display:block}
.template-submit-btn{font-size:.75rem;padding:8px 14px;width:100%}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-4px)}40%,80%{transform:translateX(4px)}}
.shake{animation:shake .4s ease}

.photoshoot-tabs{display:flex;gap:4px;margin-bottom:24px}
.photoshoot-tab{
  font-family:var(--font-mono);font-size:.75rem;letter-spacing:.06em;
  padding:8px 18px;border-radius:20px;cursor:pointer;transition:all .2s;
  background:var(--bg-surface);border:1px solid var(--border-subtle);color:var(--text-secondary);
}
.photoshoot-tab:hover{border-color:var(--accent-dim);color:var(--text-primary)}
.photoshoot-tab.active{background:var(--accent-glow);color:var(--accent);border-color:var(--accent-dim)}
.tab-count{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:18px;height:18px;padding:0 5px;border-radius:9px;
  font-size:.6rem;background:var(--bg-hover);margin-left:6px;
}
.photoshoot-tab.active .tab-count{background:rgba(201,168,76,.2)}

.photoshoot-create-layout{display:grid;grid-template-columns:1fr 340px;gap:28px;align-items:start}
.theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.theme-tile{
  background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius);
  overflow:hidden;cursor:pointer;transition:all .2s;
}
.theme-tile:hover{border-color:var(--accent-dim);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.3)}
.theme-tile.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent),0 6px 20px rgba(201,168,76,.15)}
.theme-tile-img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.theme-tile-placeholder{
  width:100%;aspect-ratio:16/10;
  background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-hover) 50%,var(--bg-surface) 100%);
  display:flex;align-items:center;justify-content:center;
}
.theme-tile-placeholder svg{opacity:.15;width:32px;height:32px;stroke:var(--text-muted)}
.theme-tile-body{padding:10px 12px}
.theme-tile-body h4{font-size:.78rem;font-weight:500;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.theme-tile-body p{font-size:.68rem;color:var(--text-muted);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.theme-tile-meta{font-family:var(--font-mono);font-size:.6rem;color:var(--text-muted);margin-top:4px}

.photoshoot-form-sidebar{
  position:sticky;top:32px;
  background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);
  padding:16px;
}
.photoshoot-form-sidebar .sidebar-title{
  font-family:var(--font-mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--accent-dim);margin-bottom:12px;
}
.photoshoot-form-sidebar .form-group{margin-bottom:10px}
.photoshoot-form-sidebar .form-label{font-size:.6rem}
.photoshoot-form-sidebar .file-dropzone{padding:12px;gap:6px}
.photoshoot-form-sidebar .file-dropzone svg{width:16px;height:16px}
.photoshoot-form-sidebar .file-dropzone span{font-size:.7rem}
.photoshoot-form-sidebar .upload-thumb{width:56px;height:56px}
.photoshoot-form-sidebar .chip-controls{margin-top:10px;gap:6px;flex-wrap:wrap}
.photoshoot-form-sidebar .chip-stepper-group{width:100%}
.photoshoot-form-sidebar .chip-group{display:flex;flex-wrap:wrap;gap:4px}
.photoshoot-form-sidebar .chip{padding:6px 9px;min-height:30px;font-size:.68rem;border-radius:16px;gap:4px}
.photoshoot-form-sidebar .chip svg{width:9px;height:9px}
.photoshoot-form-sidebar .chip-stepper{border-radius:16px}
.photoshoot-form-sidebar .chip-stepper button{width:30px;height:30px;font-size:.78rem}
.photoshoot-form-sidebar .chip-stepper span{font-size:.7rem;min-width:18px}
.photoshoot-form-sidebar .stepper-label{font-size:.65rem}
.photoshoot-form-sidebar .chip-dropdown .chip{padding:6px 9px}
.photoshoot-form-sidebar .btn-primary{padding:8px 16px;font-size:.78rem;margin-top:10px}
.form-empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:40px 16px;text-align:center;color:var(--text-muted);gap:12px;
}
.form-empty svg{opacity:.2;width:40px;height:40px}
.form-empty p{font-size:.82rem}

.photoshoot-history-tab{display:none}
.photoshoot-history-tab.active{display:block}

.photoshoot-form{
  max-width:560px;background:var(--bg-primary);border:1px solid var(--border-subtle);
  border-radius:var(--radius-lg);padding:24px;
}

.jobs-list{display:flex;flex-direction:column;gap:12px}
.job-card{
  background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);
  padding:18px;transition:all .2s;animation:fadeIn .3s ease;
}
.job-card:hover{border-color:var(--border)}
.job-card-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.job-card-model{font-weight:500;font-size:.88rem}
.job-card-time{font-family:var(--font-mono);font-size:.68rem;color:var(--text-muted);margin-left:auto}

.status-badge{
  font-family:var(--font-mono);font-size:.6rem;letter-spacing:.06em;text-transform:uppercase;
  padding:3px 8px;border-radius:10px;display:inline-flex;align-items:center;gap:4px;
}
.status-badge.queued{background:rgba(167,139,250,.12);color:var(--queued)}
.status-badge.processing{background:rgba(96,165,250,.12);color:var(--processing)}
.status-badge.processing::before{content:'';width:6px;height:6px;border-radius:50%;border:1.5px solid;border-color:var(--processing) transparent var(--processing) transparent;animation:spin .8s linear infinite}
.status-badge.succeeded{background:rgba(74,222,128,.12);color:var(--success)}
.status-badge.failed{background:rgba(248,113,113,.12);color:var(--error)}
.status-badge.partial{background:rgba(201,168,76,.12);color:var(--accent)}
.status-badge.pending{background:rgba(167,139,250,.12);color:var(--queued)}

.job-prompt{font-size:.8rem;color:var(--text-secondary);line-height:1.5;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.job-output{display:flex;gap:8px;flex-wrap:wrap}
.job-output img{max-width:280px;border-radius:var(--radius);border:1px solid var(--border-subtle)}
.job-output video{max-width:400px;border-radius:var(--radius);border:1px solid var(--border-subtle)}
.job-error{font-size:.78rem;color:var(--error);background:rgba(248,113,113,.06);padding:8px 12px;border-radius:var(--radius)}

.photoshoot-card{
  background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);
  padding:20px;margin-bottom:16px;
}
.photoshoot-card-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.photoshoot-card-theme{font-weight:500;font-size:.92rem}
.photoshoot-card-count{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted)}
.photoshoot-jobs{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.photoshoot-job{background:var(--bg-surface);border-radius:var(--radius);padding:12px}
.photoshoot-job img{width:100%;border-radius:6px;margin-top:8px}

.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}
.empty-state svg{margin-bottom:16px;opacity:.3}
.empty-state h3{font-family:var(--font-display);font-size:1.3rem;color:var(--text-secondary);margin-bottom:6px;font-weight:400}
.empty-state p{font-size:.82rem}

.loading-spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;display:inline-block}

.toast-container{position:fixed;top:20px;right:20px;z-index:1000;display:flex;flex-direction:column;gap:8px}
.toast{
  background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:12px 16px;font-size:.82rem;animation:fadeIn .3s ease;min-width:260px;
  box-shadow:0 8px 30px rgba(0,0,0,.4);display:flex;align-items:center;gap:10px;
}
.toast.success{border-color:rgba(74,222,128,.3)}
.toast.error{border-color:rgba(248,113,113,.3)}
.toast-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.toast.success .toast-dot{background:var(--success)}
.toast.error .toast-dot{background:var(--error)}

.category-label{
  font-family:var(--font-display);font-size:1.2rem;font-weight:400;margin-bottom:16px;
  padding-bottom:10px;border-bottom:1px solid var(--border-subtle);
}
.chip-stepper-group{display:flex;align-items:center;gap:10px}
.stepper-label{font-size:.72rem;color:var(--text-muted);white-space:nowrap}

.bg-grain{
  position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.auth-links{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:16px}
.auth-links a{font-size:.78rem;color:var(--text-muted);transition:color .2s}
.auth-links a:hover{color:var(--accent)}

.specialty-options{display:flex;flex-wrap:wrap;gap:8px}
.specialty-btn{
  padding:8px 16px;font-size:.78rem;font-family:var(--font-mono);
  background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border-subtle);
  border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;
}
.specialty-btn:hover{border-color:var(--accent-dim);color:var(--text-primary)}
.specialty-btn.active{background:var(--accent);color:var(--bg-primary);border-color:var(--accent);font-weight:500}
.form-specialty .form-label{margin-bottom:8px}

.photoshoot-transition{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  background:rgba(10,10,12,.92);backdrop-filter:blur(20px);
  opacity:0;pointer-events:none;transition:opacity .4s ease;
}
.photoshoot-transition.active{opacity:1;pointer-events:all}
.photoshoot-transition-content{display:flex;flex-direction:column;align-items:center;gap:28px}

.transition-lens{
  position:relative;width:80px;height:80px;
}
.transition-lens-ring{
  position:absolute;inset:0;border-radius:50%;
  border:2px solid var(--accent);opacity:.3;
}
.transition-lens-ring:nth-child(1){
  animation:lens-pulse 2s ease-in-out infinite;
}
.transition-lens-ring:nth-child(2){
  inset:12px;border-color:var(--accent);opacity:.5;
  animation:lens-pulse 2s ease-in-out .4s infinite;
}
.transition-lens-ring:nth-child(3){
  inset:24px;border-color:var(--accent);opacity:.8;
  animation:lens-pulse 2s ease-in-out .8s infinite;
}

@keyframes lens-pulse{
  0%,100%{transform:scale(1);opacity:.3}
  50%{transform:scale(1.12);opacity:.8}
}

.transition-text{
  font-size:1.1rem;font-weight:500;color:var(--text-primary);
  letter-spacing:.02em;
}
.transition-dots::after{
  content:"";animation:dots 1.5s steps(4,end) infinite;
}
@keyframes dots{
  0%{content:""}
  25%{content:"."}
  50%{content:".."}
  75%{content:"..."}
}
.transition-sub{
  font-size:.78rem;color:var(--text-muted);font-family:var(--font-mono);
  animation:sub-fade 3s ease-in-out infinite;
}
@keyframes sub-fade{
  0%,100%{opacity:.4}
  50%{opacity:.8}
}

.photoshoot-detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.photoshoot-photo{
  background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);
  overflow:hidden;
}
.photoshoot-photo-header{padding:12px 14px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:between;gap:8px}
.photoshoot-photo-header span:first-child{font-size:.82rem;font-weight:500}
.photoshoot-photo-content{aspect-ratio:3/4;background:var(--bg-surface);display:flex;align-items:center;justify-content:center;position:relative}
.photo-edit-btn{
  position:absolute;bottom:8px;right:8px;width:32px;height:32px;border-radius:50%;
  background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.15);color:var(--text-primary);
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  opacity:0;transition:opacity .2s;z-index:1;backdrop-filter:blur(4px);
}
.photoshoot-photo-content:hover .photo-edit-btn{opacity:1}
.photo-edit-btn:hover{background:var(--accent);color:var(--bg-deep);border-color:var(--accent)}
.photoshoot-photo-content img{width:100%;height:100%;object-fit:cover}
.photoshoot-photo-content .spinner-wrap{text-align:center}
.photoshoot-photo-content .spinner-wrap p{font-size:.75rem;color:var(--text-muted);margin-top:8px}

.quality-badge{font-size:.7rem;font-weight:600;padding:2px 7px;border-radius:10px;font-family:var(--font-mono)}
.quality-badge.high{background:rgba(74,222,128,.15);color:var(--success)}
.quality-badge.medium{background:rgba(201,168,76,.15);color:var(--accent)}
.quality-badge.low{background:rgba(248,113,113,.15);color:var(--error)}

.back-link{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text-muted);transition:color .2s;margin-bottom:16px}
.back-link:hover{color:var(--accent)}

.lightbox{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center}
.lightbox-overlay{position:absolute;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(8px)}
.lightbox-content{position:relative;max-width:92vw;max-height:90vh;z-index:1;display:flex;gap:20px;align-items:center}
.lightbox-image-wrap{position:relative;flex-shrink:1;min-width:0}
.lightbox-content img{max-width:60vw;max-height:80vh;object-fit:contain;border-radius:var(--radius-lg);box-shadow:0 20px 60px rgba(0,0,0,.5);display:block}
.lightbox-close{position:absolute;top:8px;right:8px;width:36px;height:36px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border-subtle);color:var(--text-primary);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:2}
.lightbox-close:hover{background:var(--accent);color:var(--bg-deep)}

.lightbox-analysis{width:320px;max-height:85vh;overflow-y:auto;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.lightbox-analysis:empty{display:none}
.lightbox-score-big{text-align:center;margin-bottom:20px}
.lightbox-score-big .score-value{font-family:var(--font-mono);font-size:2.4rem;font-weight:700;line-height:1}
.lightbox-score-big .score-label{font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-top:4px}
.lightbox-score-big .score-value.high{color:var(--success)}
.lightbox-score-big .score-value.medium{color:var(--accent)}
.lightbox-score-big .score-value.low{color:var(--error)}

.lightbox-dimensions{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.lightbox-dim{display:flex;align-items:center;gap:10px}
.lightbox-dim-label{font-family:var(--font-mono);font-size:.68rem;color:var(--text-secondary);width:110px;flex-shrink:0;text-transform:uppercase;letter-spacing:.04em}
.lightbox-dim-bar{flex:1;height:6px;background:var(--bg-surface);border-radius:3px;overflow:hidden}
.lightbox-dim-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}
.lightbox-dim-bar-fill.high{background:var(--success)}
.lightbox-dim-bar-fill.medium{background:var(--accent)}
.lightbox-dim-bar-fill.low{background:var(--error)}
.lightbox-dim-score{font-family:var(--font-mono);font-size:.72rem;font-weight:600;width:20px;text-align:right;flex-shrink:0}
.lightbox-dim-score.high{color:var(--success)}
.lightbox-dim-score.medium{color:var(--accent)}
.lightbox-dim-score.low{color:var(--error)}

.lightbox-section{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border-subtle)}
.lightbox-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.lightbox-section-title{font-family:var(--font-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:8px}
.lightbox-section-text{font-size:.8rem;color:var(--text-secondary);line-height:1.5}
.lightbox-top-issue{background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.15);border-radius:var(--radius);padding:10px 12px;font-size:.78rem;color:var(--error);line-height:1.5}
.lightbox-prompt-text{font-size:.78rem;color:var(--text-muted);line-height:1.5;max-height:200px;overflow-y:auto}
.lightbox-info{width:280px;max-height:80vh;overflow-y:auto;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;flex-shrink:0}
.lightbox-info-actions{display:flex;flex-direction:column;gap:8px;margin-top:16px}
.lightbox-action-btn{
  display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;border-radius:var(--radius);
  font-size:.78rem;color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border-subtle);
  cursor:pointer;transition:all .2s;
}
.lightbox-action-btn:hover{border-color:var(--accent-dim);color:var(--text-primary);background:var(--bg-hover)}
.lightbox-action-btn svg{flex-shrink:0;opacity:.6}
.lightbox-action-btn:hover svg{opacity:1}

@media(max-width:900px){
  .lightbox-content{flex-direction:column;align-items:center;max-height:95vh;overflow-y:auto}
  .lightbox-content img{max-width:90vw;max-height:50vh}
  .lightbox-analysis{width:90vw;max-height:none}
  .lightbox-info{width:90vw;max-height:none}
  .lightbox-info-actions{flex-direction:row}
}

.analyses-list{display:flex;flex-direction:column;gap:20px}
.analysis-card{
  background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);
  overflow:hidden;animation:fadeIn .3s ease;
}
.analysis-card-layout{display:grid;grid-template-columns:280px 1fr;min-height:0}
.analysis-card-image{position:relative;aspect-ratio:3/4;overflow:hidden;cursor:pointer}
.analysis-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.analysis-card-image:hover img{transform:scale(1.03)}
.analysis-card-image-overlay{position:absolute;top:12px;left:12px}
.quality-badge-lg{
  font-family:var(--font-mono);font-size:1.4rem;font-weight:700;
  padding:6px 14px;border-radius:var(--radius);backdrop-filter:blur(8px);
}
.quality-badge-lg.high{background:rgba(74,222,128,.2);color:var(--success)}
.quality-badge-lg.medium{background:rgba(201,168,76,.2);color:var(--accent)}
.quality-badge-lg.low{background:rgba(248,113,113,.2);color:var(--error)}

.analysis-card-details{padding:20px;display:flex;flex-direction:column;gap:16px;overflow-y:auto;max-height:500px}
.analysis-card-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

.analysis-dimensions{display:flex;flex-direction:column;gap:8px}
.analysis-dim{display:flex;align-items:center;gap:8px}
.analysis-dim-label{font-family:var(--font-mono);font-size:.68rem;color:var(--text-secondary);width:120px;flex-shrink:0;text-transform:uppercase;letter-spacing:.04em}
.analysis-dim-bar{flex:1;height:6px;background:var(--bg-surface);border-radius:3px;overflow:hidden}
.analysis-dim-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}
.analysis-dim-bar-fill.high{background:var(--success)}
.analysis-dim-bar-fill.medium{background:var(--accent)}
.analysis-dim-bar-fill.low{background:var(--error)}
.analysis-dim-score{font-family:var(--font-mono);font-size:.72rem;font-weight:600;width:16px;text-align:right;flex-shrink:0}
.analysis-dim-score.high{color:var(--success)}
.analysis-dim-score.medium{color:var(--accent)}
.analysis-dim-score.low{color:var(--error)}
.analysis-dim-weight{font-family:var(--font-mono);font-size:.6rem;color:var(--text-muted);width:28px;text-align:right;flex-shrink:0}

.analysis-section{padding-top:12px;border-top:1px solid var(--border-subtle)}
.analysis-section-title{font-family:var(--font-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:6px}
.analysis-section-text{font-size:.8rem;color:var(--text-secondary);line-height:1.5}
.analysis-top-issue{background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.15);border-radius:var(--radius);padding:10px 12px;font-size:.78rem;color:var(--error);line-height:1.5}
.analysis-prompt-text{font-size:.78rem;color:var(--text-muted);line-height:1.5}

@media(max-width:800px){
  .analysis-card-layout{grid-template-columns:1fr}
  .analysis-card-image{aspect-ratio:4/3;max-height:300px}
  .analysis-card-details{max-height:none}
}

.chip-controls{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:14px}
.chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:10px 14px;border-radius:20px;min-height:38px;
  background:var(--bg-surface);border:1px solid var(--border);
  color:var(--text-secondary);font-family:var(--font-mono);font-size:.75rem;
  cursor:pointer;transition:all .15s;white-space:nowrap;
}
.chip:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border)}
.chip.active{background:var(--accent-glow);color:var(--accent);border-color:var(--accent-dim)}
.chip svg{opacity:.6;flex-shrink:0}
.chip.active svg{opacity:1;stroke:var(--accent)}

.chip-stepper{
  display:inline-flex;align-items:center;gap:0;
  border-radius:20px;border:1px solid var(--border);overflow:hidden;
  background:var(--bg-surface);
}
.chip-stepper button{
  width:38px;height:38px;
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;color:var(--text-secondary);cursor:pointer;
  transition:all .15s;background:none;border:none;
}
.chip-stepper button:hover{background:var(--bg-hover);color:var(--text-primary)}
.chip-stepper span{
  font-family:var(--font-mono);font-size:.8rem;font-weight:600;
  min-width:24px;text-align:center;color:var(--text-primary);
}

.chip-group{display:inline-flex;gap:6px}

.chip-dropdown{position:relative}
.chip-dropdown-menu{
  display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);
  background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);
  padding:4px;min-width:120px;z-index:10;
  box-shadow:0 8px 24px rgba(0,0,0,.4);
}
.chip-dropdown-menu.open{display:block}
.chip-dropdown-menu button{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  width:100%;padding:8px 12px;border-radius:6px;
  font-family:var(--font-mono);font-size:.78rem;color:var(--text-secondary);
  cursor:pointer;transition:all .15s;background:none;border:none;text-align:left;
}
.chip-dropdown-menu button:hover{background:var(--bg-hover);color:var(--text-primary)}
.chip-hint{color:var(--text-muted);font-size:.68rem}

.collection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.collection-photo{
  position:relative;aspect-ratio:3/4;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;
  background:var(--bg-surface);transition:transform .25s ease,box-shadow .25s ease;
}
.collection-photo:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 40px rgba(0,0,0,.4)}
.collection-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}
.collection-photo:hover img{transform:scale(1.05)}
.collection-photo-overlay{
  position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 50%);
  display:flex;align-items:flex-end;justify-content:space-between;padding:12px;
  opacity:0;transition:opacity .25s ease;
}
.collection-photo:hover .collection-photo-overlay{opacity:1}
.collection-photo-model{font-family:var(--font-mono);font-size:.68rem;color:var(--text-primary);letter-spacing:.04em}
.collection-photo-user{font-family:var(--font-mono);font-size:.6rem;color:var(--accent);opacity:.8;display:block;margin-top:2px}
.collection-photo-reveal{animation:photoReveal .45s ease both}
@keyframes photoReveal{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.collection-sentinel{display:flex;justify-content:center;padding:40px 0}
.collection-loader{display:flex;gap:8px;align-items:center}
.collection-loader-dot{
  width:6px;height:6px;border-radius:50%;background:var(--accent);
  animation:loaderPulse 1.4s ease infinite;
}
.collection-loader-dot:nth-child(2){animation-delay:.2s}
.collection-loader-dot:nth-child(3){animation-delay:.4s}
@keyframes loaderPulse{0%,100%{opacity:.15;transform:scale(.7)}50%{opacity:1;transform:scale(1.3)}}

.lightbox-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:var(--bg-surface);border-radius:var(--radius-lg);z-index:1}
.lightbox-content img{transition:opacity .25s ease}
.lightbox-content img.loading{opacity:.3}

.lightbox-nav{
  z-index:2;width:44px;height:44px;border-radius:50%;
  background:rgba(30,30,38,.7);border:1px solid var(--border-subtle);
  color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all .2s ease;flex-shrink:0;backdrop-filter:blur(4px);
}
.lightbox-nav:hover{background:var(--accent);color:var(--bg-deep);border-color:var(--accent);box-shadow:0 0 20px var(--accent-glow)}
.lightbox-counter{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);letter-spacing:.06em}
.lightbox-bottom{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:12px}

.lightbox-action-btn{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);
  letter-spacing:.04em;cursor:pointer;transition:color .2s;padding:4px 0;
}
.lightbox-action-btn:hover{color:var(--accent)}

.lightbox-download-wrap{position:relative}
.lightbox-download-btn{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);
  letter-spacing:.04em;cursor:pointer;transition:color .2s;padding:4px 0;
}
.lightbox-download-btn:hover{color:var(--accent)}
.lightbox-download-menu{
  display:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);
  background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);
  padding:4px;min-width:160px;z-index:10;box-shadow:0 12px 32px rgba(0,0,0,.5);
}
.lightbox-download-menu.open{display:block}
.lightbox-download-menu button{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  width:100%;padding:9px 14px;border-radius:6px;
  font-family:var(--font-mono);font-size:.78rem;color:var(--text-secondary);
  cursor:pointer;transition:all .15s;background:none;border:none;text-align:left;
}
.lightbox-download-menu button:hover{background:var(--bg-hover);color:var(--text-primary)}
.lightbox-download-menu button span{font-size:.65rem;color:var(--text-muted)}

.mobile-hamburger{
  display:none;position:fixed;top:16px;left:16px;z-index:1001;
  width:44px;height:44px;border-radius:var(--radius);
  background:var(--bg-elevated);border:1px solid var(--border-subtle);
  color:var(--text-primary);cursor:pointer;
  align-items:center;justify-content:center;transition:all .2s;
}
.mobile-hamburger:hover{background:var(--bg-hover);border-color:var(--accent-dim)}

.sidebar-overlay{
  display:none;position:fixed;inset:0;z-index:998;
  background:rgba(0,0,0,.5);backdrop-filter:blur(4px);
}
.sidebar-overlay.open{display:block}

@media(max-width:1024px){
  .photoshoot-detail-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
  .collection-grid{grid-template-columns:repeat(3,1fr)}
  .photoshoot-create-layout{grid-template-columns:1fr}
  .photoshoot-form-sidebar{position:static}
  .theme-grid{grid-template-columns:repeat(2,1fr)}
  .studio-content{grid-template-columns:1fr}
  .studio-history{display:none}
  .studio-board{padding:24px 16px}
  .board-card{max-width:800px}
  .studio-form-bar{padding:14px 24px}
  .studio-form-row .studio-model-select{width:140px}
}

@media(max-width:768px){
  .layout{grid-template-columns:1fr}
  .sidebar{
    position:fixed;left:0;top:0;z-index:999;
    transform:translateX(-100%);transition:transform .3s ease;
    width:260px;
  }
  .sidebar.open{transform:translateX(0)}
  .mobile-hamburger{display:flex}
  .main{padding:16px;padding-top:68px}
  .main:has(.studio-page){padding:0;padding-top:68px}
  .main-header h2{font-size:1.4rem}
  .photoshoot-detail-grid{grid-template-columns:repeat(2,1fr)}
  .collection-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .collection-photo-overlay{opacity:1;background:linear-gradient(to top,rgba(0,0,0,.6) 0%,transparent 40%)}
  .model-grid{grid-template-columns:1fr}
  .photoshoot-create-layout{grid-template-columns:1fr}
  .theme-grid{grid-template-columns:repeat(2,1fr)}
  .theme-tile-body p{display:none}
  .photoshoot-form-sidebar{position:static}
  .chip-controls{gap:6px}
  .chip-stepper button{width:44px;height:44px}
  .chip{min-height:44px;padding:12px 14px}
  .upload-previews{gap:6px}
  .upload-thumb{width:60px;height:60px}
  .photoshoot-card-header{flex-wrap:wrap}
  .studio-page{height:calc(100vh - 68px)}
  .studio-board{padding:12px 8px}
  .board-card{max-width:none}
  .board-card-body img{max-width:none}
  .board-card-body video{max-width:none}
  .studio-board-header{max-width:none;text-align:left}
  .studio-form-bar{padding:12px 16px}
  .studio-form-bar::before{left:0}
  .studio-form-row{flex-wrap:wrap}
  .studio-form-row .studio-model-select{width:100%}
  .studio-form-row .studio-prompt-group{flex:1;min-width:0}
  .studio-form-row .btn{flex-shrink:0}
  .lightbox-content img{max-width:85vw;max-height:75vh}
  .lightbox-content{gap:8px;padding:0 8px}
  .lightbox-nav{width:44px;height:44px}
  .lightbox-download-menu{left:auto;right:0;transform:none}
  .lightbox-analysis{width:95vw}
  .analysis-card-layout{grid-template-columns:1fr}
}

@media(max-width:480px){
  .main{padding:12px;padding-top:64px}
  .main:has(.studio-page){padding:0;padding-top:64px}
  .studio-page{height:calc(100vh - 64px)}
  .studio-board{padding:8px 6px}
  .studio-form-bar{padding:10px 12px}
  .studio-form-row{flex-direction:column;align-items:stretch;gap:8px}
  .studio-form-row .studio-model-select{width:100%}
  .studio-form-row .studio-prompt-group{width:100%}
  .studio-form-row .btn{width:100%}
  .main-header h2{font-size:1.2rem}
  .collection-grid{grid-template-columns:1fr;gap:12px}
  .photoshoot-detail-grid{grid-template-columns:1fr}
  .lightbox-bottom{flex-direction:column;gap:10px}
}

.character-create-layout{display:grid;grid-template-columns:1fr 340px;gap:28px;align-items:start}
.character-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}
.character-card{
  background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);
  overflow:hidden;transition:all .25s;
}
.character-card:hover{border-color:var(--accent-dim);transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.3)}
.character-card-thumb{width:100%;aspect-ratio:3/4;object-fit:cover;display:block}
.character-card-thumb-wrap{
  width:100%;aspect-ratio:3/4;
  background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-hover) 50%,var(--bg-surface) 100%);
  display:flex;align-items:center;justify-content:center;
}
.character-card-placeholder svg{opacity:.15;width:40px;height:40px;stroke:var(--text-muted)}
.character-card-body{padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.character-card-name{font-size:.82rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.character-card-error{font-size:.68rem;color:var(--error);padding:0 14px 10px;display:none}
.character-form-sidebar{
  position:sticky;top:32px;
  background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);
  padding:16px;
}
.character-form-sidebar .sidebar-title{
  font-family:var(--font-mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--accent-dim);margin-bottom:12px;
}
.character-form-sidebar .form-group{margin-bottom:10px}
.character-form-sidebar .form-label{font-size:.6rem}
.character-form-sidebar .file-dropzone{padding:12px;gap:6px}
.character-form-sidebar .file-dropzone svg{width:16px;height:16px}
.character-form-sidebar .file-dropzone span{font-size:.7rem}
.character-form-sidebar .upload-thumb{width:56px;height:56px}
.character-form-sidebar .btn-primary{padding:8px 16px;font-size:.78rem;margin-top:10px}

@media(max-width:1024px){
  .character-create-layout{grid-template-columns:1fr}
  .character-form-sidebar{position:static}
}
@media(max-width:768px){
  .character-grid{grid-template-columns:repeat(2,1fr)}
  .character-create-layout{grid-template-columns:1fr}
  .character-form-sidebar{position:static}
}
@media(max-width:480px){
  .character-grid{grid-template-columns:1fr}
}

/* Character selector for multishoot sidebar */
.character-selector-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:8px;
  max-height:240px;overflow-y:auto;padding:2px;
}
.character-selector-item{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:10px 8px;border-radius:10px;cursor:pointer;
  border:1.5px solid var(--border-subtle);background:var(--bg-surface);
  transition:all .15s ease;position:relative;
}
.character-selector-item:hover{border-color:var(--accent-dim)}
.character-selector-checkbox{position:absolute;opacity:0;pointer-events:none}
.character-selector-checkbox:checked + .character-selector-thumb,
.character-selector-checkbox:checked ~ .character-selector-name{color:var(--accent)}
.character-selector-item:has(.character-selector-checkbox:checked){
  border-color:var(--accent);background:rgba(var(--accent-rgb),.08);
  box-shadow:0 0 0 1px var(--accent);
}
.character-selector-thumb{
  width:56px;height:56px;border-radius:50%;object-fit:cover;
  border:2px solid var(--border-subtle);
}
.character-selector-thumb-placeholder{
  display:flex;align-items:center;justify-content:center;
  background:var(--bg-elevated);
}
.character-selector-thumb-placeholder svg{width:24px;height:24px;opacity:.3}
.character-selector-name{
  font-size:.72rem;font-weight:500;text-align:center;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  max-width:100%;
}
.character-selector-empty{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:24px 16px;text-align:center;color:var(--text-muted);
}
.character-selector-empty svg{opacity:.2}
.character-selector-empty p{font-size:.75rem;margin:0}

.locale-selector{display:flex;gap:4px;padding:0 16px 12px}
.locale-option{
  font-family:var(--font-mono);font-size:.6rem;letter-spacing:.05em;
  padding:4px 8px;border-radius:6px;color:var(--text-muted);
  text-decoration:none;transition:all .15s ease;
}
.locale-option:hover{color:var(--text-primary);background:var(--bg-surface)}
.locale-option.active{color:var(--accent);background:var(--bg-surface)}

.landing-nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(8,8,10,.85);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border-subtle);
}
.landing-nav-inner{
  max-width:1100px;margin:0 auto;padding:16px 32px;
  display:flex;align-items:center;justify-content:space-between;
}
.landing-logo h1{font-family:var(--font-display);font-size:1.7rem;font-weight:400;letter-spacing:-.02em}
.landing-logo h1 em{color:var(--accent);font-style:italic}
.landing-nav-links{display:flex;align-items:center;gap:16px}
.landing-nav-link{font-size:.85rem;color:var(--text-secondary);transition:color .2s}
.landing-nav-link:hover{color:var(--text-primary)}

.landing-hero{
  padding:160px 32px 100px;text-align:center;position:relative;overflow:hidden;
  background:
    radial-gradient(ellipse at 50% -20%,rgba(139,92,246,.12) 0%,transparent 50%),
    radial-gradient(circle at 15% 80%,rgba(139,92,246,.04) 0%,transparent 40%),
    radial-gradient(circle at 85% 60%,rgba(139,92,246,.04) 0%,transparent 35%);
}
.landing-hero::before{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 60L60 0' stroke='%23ffffff' stroke-width='.3' opacity='.04'/%3E%3C/svg%3E");
  pointer-events:none;
}
.landing-hero-inner{max-width:750px;margin:0 auto;position:relative;z-index:2}
.landing-hero-video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
}
.landing-hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(10,10,18,.6) 0%,rgba(10,10,18,.75) 60%,rgba(10,10,18,.92) 100%);
}
.landing-hero-title{
  font-family:var(--font-display);font-size:3.8rem;font-weight:400;
  line-height:1.14;margin-bottom:20px;letter-spacing:-.03em;
  animation:revealUp .8s ease;
}
.landing-hero-title em{color:var(--accent);font-style:italic;animation:textGlow 4s ease-in-out infinite}
.landing-hero-subtitle{
  font-size:1.08rem;color:var(--text-secondary);line-height:1.65;
  max-width:520px;margin:0 auto 20px;
  animation:revealUp .8s ease .15s backwards;
}
.landing-social-proof{
  display:flex;align-items:center;justify-content:center;gap:12px;
  margin-bottom:28px;animation:revealUp .8s ease .25s backwards;
}
.landing-social-proof-stars{color:#FBBF24;font-size:.9rem}
.landing-social-proof-text{font-size:.82rem;color:var(--text-secondary)}
.landing-hero-btn{width:auto;padding:16px 40px;font-size:.95rem}
.landing-hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;animation:revealUp .8s ease .35s backwards}
.landing-hero-hint{
  font-family:var(--font-body);font-size:.85rem;color:var(--text-secondary);
  margin-top:20px;letter-spacing:.01em;
  animation:revealUp .8s ease .45s backwards;
}

.landing-section{padding:80px 32px}
.landing-section-alt{background:var(--bg-primary)}
.landing-section-inner{max-width:1000px;margin:0 auto}
.landing-section-title{
  font-family:var(--font-display);font-size:2.2rem;font-weight:400;
  text-align:center;margin-bottom:44px;
}
.landing-section-title em{color:var(--accent);font-style:italic}

.landing-section-subtitle{
  text-align:center;font-size:1rem;color:var(--text-secondary);
  max-width:500px;margin:-12px auto 32px;line-height:1.6;
}
.landing-themes-track{overflow:hidden;padding:0 32px;margin-top:40px}
.landing-themes-scroll{
  display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;
  scrollbar-width:none;padding-bottom:8px;
}
.landing-themes-scroll::-webkit-scrollbar{display:none}
.landing-theme-card{flex-shrink:0;width:200px;scroll-snap-align:start;cursor:pointer;transition:transform .2s}
.landing-theme-card:hover{transform:translateY(-4px)}
.landing-theme-image{
  width:200px;height:260px;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--border);transition:border-color .2s,box-shadow .2s;
}
.landing-theme-image img{width:100%;height:100%;object-fit:cover}
.landing-theme-card:hover .landing-theme-image{
  border-color:var(--accent);box-shadow:0 0 20px var(--accent-glow);
}
.landing-theme-placeholder{
  width:100%;height:100%;
  background:linear-gradient(135deg,var(--bg-elevated),var(--bg-surface));
  display:flex;align-items:center;justify-content:center;font-size:2.4rem;
}
.landing-theme-name{
  display:block;text-align:center;margin-top:10px;
  font-size:.85rem;color:var(--text-secondary);font-weight:500;
}

.landing-section-cta{text-align:center;margin-top:40px}

.landing-comparisons{display:flex;flex-direction:column;gap:40px;margin-top:48px}
.landing-comparison{display:flex;align-items:center;justify-content:center;gap:24px}
.landing-comparison-side{
  width:280px;height:350px;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--border);position:relative;
}
.landing-comparison-side img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.landing-comparison-side:last-child{
  border-color:var(--accent);box-shadow:0 0 30px var(--accent-glow);
}
.landing-comparison-placeholder{
  width:100%;height:100%;display:flex;align-items:flex-end;justify-content:center;padding-bottom:16px;
}
.landing-comparison-placeholder.before{
  background:linear-gradient(180deg,var(--bg-surface) 0%,var(--bg-hover) 100%);
}
.landing-comparison-placeholder.after{
  background:linear-gradient(135deg,rgba(139,92,246,.08),rgba(139,92,246,.08));
}
.landing-comparison-label{
  font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;
  letter-spacing:.1em;color:var(--text-muted);
  background:rgba(10,10,18,.8);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.08);
  padding:6px 14px;border-radius:var(--radius);
}
.landing-comparison-side:last-child .landing-comparison-label{
  background:var(--accent);color:#fff;font-weight:600;
}
.landing-comparison-arrow{flex-shrink:0;animation:pulse 2s ease-in-out infinite}

.landing-steps{
  display:flex;align-items:center;justify-content:center;gap:20px;
  flex-wrap:wrap;position:relative;
}
.landing-steps::before{
  content:'';position:absolute;top:50%;left:15%;right:15%;height:2px;
  background:var(--gradient-brand);opacity:.3;z-index:0;
}
.landing-step{
  flex:1;min-width:200px;text-align:center;position:relative;z-index:1;
  background:var(--glass-bg);backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-lg);padding:32px 20px;transition:all .3s;
}
.landing-step:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.3)}
.landing-step-number{
  width:52px;height:52px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;
  font-family:var(--font-mono);font-size:1.2rem;font-weight:600;
  color:var(--accent);background:rgba(139,92,246,.1);
  border:1px solid rgba(139,92,246,.25);
  box-shadow:0 0 20px var(--accent-glow);
}
.landing-step h4{font-size:.9rem;font-weight:500;margin-bottom:6px}
.landing-step p{font-size:.78rem;color:var(--text-secondary);line-height:1.5}
.landing-step-divider{flex-shrink:0;display:flex;align-items:center;z-index:1}

.landing-plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.landing-plan-card{
  background:var(--glass-bg);backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-lg);padding:28px;
  display:flex;flex-direction:column;transition:all .3s;
}
.landing-plan-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.3)}
.landing-plan-card.recommended{
  border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 8px 40px rgba(139,92,246,.15);
  transform:scale(1.04);z-index:1;position:relative;
}
.landing-plan-badge{
  display:inline-block;background:var(--accent);color:#fff;
  font-family:var(--font-mono);font-size:.65rem;letter-spacing:.05em;
  padding:4px 12px;border-radius:20px;margin-bottom:12px;text-transform:uppercase;
}
.landing-plan-card h4{font-size:1.1rem;font-weight:500;margin-bottom:6px}
.landing-plan-price{margin-bottom:4px}
.landing-plan-amount{font-family:var(--font-display);font-size:2.4rem;font-weight:400;letter-spacing:-.02em}
.landing-plan-interval{font-size:.82rem;color:var(--text-muted)}
.landing-plan-credits{font-size:.82rem;color:var(--text-secondary);margin-bottom:16px}
.landing-plan-features{list-style:none;margin-bottom:20px;display:flex;flex-direction:column;gap:8px;flex:1}
.landing-plan-features li{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--text-secondary)}

.landing-footer{
  border-top:1px solid var(--border-subtle);padding:48px 32px;
  background:linear-gradient(to bottom,var(--bg-primary),var(--bg-deep));
}
.landing-footer-inner{
  max-width:1000px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px;
}
.landing-footer-brand h1{font-family:var(--font-display);font-size:1.2rem;font-weight:400}
.landing-footer-brand h1 em{color:var(--accent);font-style:italic}
.landing-footer-brand p{font-size:.82rem;color:var(--text-secondary);margin-top:6px}
.landing-footer-links{display:flex;gap:20px}
.landing-footer-links a{font-size:.78rem;color:var(--text-muted);transition:color .2s}
.landing-footer-links a:hover{color:var(--accent)}

.landing-hero-orb{
  position:absolute;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(139,92,246,.12),transparent 70%);
  filter:blur(50px);animation:float 8s ease-in-out infinite;
}
.landing-cta-section{
  position:relative;overflow:hidden;
  background:radial-gradient(ellipse at 50% 50%,rgba(139,92,246,.08) 0%,var(--bg-deep) 70%);
}
.landing-cta-text{
  color:var(--text-secondary);font-size:1.08rem;max-width:520px;
  margin:0 auto 32px;line-height:1.65;
}
.btn-glow{
  width:auto;padding:16px 44px;font-size:1rem;
  box-shadow:0 0 20px var(--accent-glow);transition:all .2s;
}
.btn-glow:hover{box-shadow:0 0 40px rgba(139,92,246,.3),0 0 80px rgba(139,92,246,.1)}

.waitlist-wrap{width:100%;max-width:460px;margin:0 auto}
.waitlist-form{display:flex;gap:8px;width:100%}
.waitlist-input{
  flex:1;padding:12px 16px;background:var(--bg-elevated);border:1px solid var(--border);
  border-radius:var(--radius);color:var(--text-primary);font-size:.92rem;
  transition:border-color .2s;
}
.waitlist-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.waitlist-input::placeholder{color:var(--text-muted)}
.waitlist-btn{white-space:nowrap;padding:12px 20px;font-weight:500;font-size:.88rem;border-radius:var(--radius)}
.waitlist-success{
  color:var(--success);font-size:.92rem;text-align:center;padding:14px 0;
  animation:fadeIn .4s ease;
}
.waitlist-error{color:var(--error);font-size:.82rem;text-align:center;margin-top:6px}
.landing-plan-card .waitlist-wrap{max-width:none}
.landing-plan-card .waitlist-form{flex-direction:column}
.landing-plan-card .waitlist-btn{width:100%}

.legal-content h4{
  font-size:.92rem;font-weight:500;margin:24px 0 8px;color:var(--text-primary);
}
.legal-content p{
  font-size:.85rem;color:var(--text-secondary);line-height:1.6;margin-bottom:8px;
}

.pricing-toggle{
  display:flex;justify-content:center;gap:4px;margin-bottom:40px;
  background:var(--bg-elevated);border:1px solid var(--border-subtle);
  border-radius:24px;padding:4px;width:fit-content;margin-left:auto;margin-right:auto;
}
.pricing-toggle-btn{
  padding:10px 24px;border-radius:20px;font-size:.82rem;font-weight:500;
  color:var(--text-secondary);cursor:pointer;transition:all .2s;
  display:flex;align-items:center;gap:6px;
}
.pricing-toggle-btn:hover{color:var(--text-primary)}
.pricing-toggle-btn.active{background:var(--accent);color:var(--bg-deep)}
.pricing-save-badge{
  font-family:var(--font-mono);font-size:.6rem;font-weight:600;
  background:rgba(74,222,128,.15);color:var(--success);
  padding:2px 6px;border-radius:8px;
}

.pricing-plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pricing-plan-card{
  background:var(--bg-elevated);border:1px solid var(--border-subtle);
  border-radius:var(--radius-lg);padding:28px;position:relative;transition:all .3s;
  animation:revealUp .5s ease backwards;
  display:flex;flex-direction:column;
}
.pricing-plan-card:nth-child(1){animation-delay:.1s}
.pricing-plan-card:nth-child(2){animation-delay:.2s}
.pricing-plan-card:nth-child(3){animation-delay:.3s}
.pricing-plan-card:hover{border-color:var(--accent-dim);transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.3)}
.pricing-plan-card.recommended{animation:borderGlow 3s ease-in-out infinite}
.pricing-plan-badge{
  position:absolute;top:-10px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:var(--bg-deep);
  font-family:var(--font-mono);font-size:.62rem;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;
  padding:4px 12px;border-radius:10px;white-space:nowrap;
}
.pricing-plan-header{margin-bottom:16px}
.pricing-plan-header h3{font-size:1.1rem;font-weight:500;margin-bottom:2px}
.pricing-plan-credits{font-size:.82rem;color:var(--text-secondary)}
.pricing-plan-price{margin-bottom:20px}
.pricing-amount{font-family:var(--font-mono);font-size:2rem;font-weight:600}
.pricing-interval{font-size:.82rem;color:var(--text-muted)}
.pricing-annual-total{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);margin-top:2px}
.pricing-features-list{list-style:none;margin-bottom:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.pricing-features-list li{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--text-secondary)}

.pricing-packs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pricing-pack-card{
  background:var(--bg-elevated);border:1px solid var(--border-subtle);
  border-radius:var(--radius-lg);padding:24px;text-align:center;transition:all .3s;
  animation:revealUp .5s ease backwards;
}
.pricing-pack-card:nth-child(1){animation-delay:.1s}
.pricing-pack-card:nth-child(2){animation-delay:.2s}
.pricing-pack-card:nth-child(3){animation-delay:.3s}
.pricing-pack-card:hover{border-color:var(--accent-dim);transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.3)}
.pricing-pack-card h4{font-size:1rem;font-weight:500;margin-bottom:6px}
.pricing-pack-credits{
  font-family:var(--font-mono);font-size:.78rem;color:var(--accent);
  margin-bottom:12px;
}
.pricing-pack-price{font-family:var(--font-mono);font-size:1.6rem;font-weight:600;margin-bottom:4px}
.pricing-pack-per{font-size:.72rem;color:var(--text-muted);margin-bottom:16px}

.pricing-faq-list{
  max-width:700px;margin:0 auto;
  display:flex;flex-direction:column;gap:16px;
}
.pricing-faq-item{
  background:var(--bg-elevated);border:1px solid var(--border-subtle);
  border-radius:var(--radius-lg);padding:20px 24px;transition:border-color .3s;
}
.pricing-faq-item:hover{border-color:var(--accent-dim)}
.pricing-faq-item h4{font-size:.88rem;font-weight:500;margin-bottom:6px}
.pricing-faq-item p{font-size:.82rem;color:var(--text-secondary);line-height:1.5}

.checkout-layout{
  display:grid;grid-template-columns:340px 1fr;gap:28px;align-items:start;
}
.checkout-summary{
  background:var(--bg-primary);border:1px solid var(--border-subtle);
  border-radius:var(--radius-lg);padding:24px;position:sticky;top:32px;
  border-top:2px solid var(--accent-dim);animation:revealUp .5s ease;
}
.checkout-summary-title{
  font-family:var(--font-mono);font-size:.65rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--accent-dim);margin-bottom:16px;
}
.checkout-summary-item{
  display:flex;justify-content:space-between;align-items:center;
  font-size:.85rem;color:var(--text-secondary);padding:8px 0;
}
.checkout-summary-divider{
  height:1px;background:var(--border-subtle);margin:8px 0;
}
.checkout-summary-total{
  display:flex;justify-content:space-between;align-items:center;
  font-size:1rem;font-weight:500;padding:8px 0;
}
.checkout-features{
  list-style:none;margin-top:16px;padding-top:16px;border-top:1px solid var(--border-subtle);
  display:flex;flex-direction:column;gap:8px;
}
.checkout-features li{
  display:flex;align-items:center;gap:8px;
  font-size:.78rem;color:var(--text-secondary);
}
.checkout-payment{
  background:var(--bg-primary);border:1px solid var(--border-subtle);
  border-radius:var(--radius-lg);padding:24px;
  animation:revealUp .5s ease .15s backwards;
}
.checkout-payment-title{
  font-family:var(--font-mono);font-size:.65rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--accent-dim);margin-bottom:16px;
}
.checkout-brick-container{min-height:200px}

.checkout-result{
  text-align:center;padding:80px 20px;max-width:520px;margin:0 auto;
  animation:revealUp .7s ease;
}
.checkout-result-icon{
  margin-bottom:28px;position:relative;display:inline-block;
}
.checkout-result-icon::before,.checkout-result-icon::after{
  content:'';position:absolute;border-radius:50%;
  border:1px solid;animation:ringPulse 2.5s ease-in-out infinite;
}
.checkout-result-success::before{
  inset:-16px;border-color:rgba(74,222,128,.25);
}
.checkout-result-success::after{
  inset:-32px;border-color:rgba(74,222,128,.1);animation-delay:.4s;
}
.checkout-result-cancel::before{
  inset:-16px;border-color:rgba(201,168,76,.25);
}
.checkout-result-cancel::after{
  inset:-32px;border-color:rgba(201,168,76,.1);animation-delay:.4s;
}

.billing-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px}
.billing-card{
  background:var(--bg-elevated);border:1px solid var(--border-subtle);
  border-radius:var(--radius-lg);padding:24px;
  animation:revealUp .5s ease backwards;
}
.billing-card:nth-child(1){animation-delay:.1s}
.billing-card:nth-child(2){animation-delay:.2s}
.billing-card-title{
  font-family:var(--font-mono);font-size:.65rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--accent-dim);margin-bottom:16px;
}
.billing-plan-info{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.billing-plan-name{font-size:1.2rem;font-weight:500}
.billing-plan-details{
  display:flex;flex-direction:column;gap:4px;
  padding-top:12px;border-top:1px solid var(--border-subtle);
}
.billing-detail-row{
  display:flex;justify-content:space-between;align-items:center;
  font-size:.82rem;color:var(--text-secondary);padding:4px 0;
}
.billing-credits-display{text-align:center;margin-bottom:16px}
.billing-credits-total{
  font-family:var(--font-mono);font-size:3rem;font-weight:700;
  color:var(--accent);line-height:1;
  animation:textGlow 4s ease-in-out infinite;
}
.billing-credits-label{
  font-family:var(--font-mono);font-size:.68rem;color:var(--text-muted);
  letter-spacing:.06em;text-transform:uppercase;margin-top:8px;
}
.billing-credits-breakdown{
  padding-top:12px;border-top:1px solid var(--border-subtle);
  display:flex;flex-direction:column;gap:4px;
}

.billing-transactions{
  background:var(--bg-elevated);border:1px solid var(--border-subtle);
  border-radius:var(--radius-lg);padding:24px;
  animation:revealUp .5s ease .3s backwards;
}
.billing-table-wrap{overflow-x:auto}
.billing-table{width:100%;border-collapse:collapse}
.billing-table th{
  font-family:var(--font-mono);font-size:.62rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--text-muted);text-align:left;
  padding:8px 12px;border-bottom:1px solid var(--border-subtle);
}
.billing-table td{
  font-size:.82rem;color:var(--text-secondary);padding:10px 12px;
  border-bottom:1px solid var(--border-subtle);
}
.billing-table tbody tr:last-child td{border-bottom:none}
.billing-table tbody tr:hover td{background:var(--bg-hover)}
.billing-tx-type{
  font-family:var(--font-mono);font-size:.72rem;
  padding:2px 8px;border-radius:8px;background:var(--bg-surface);
}
.billing-tx-positive{color:var(--success);font-family:var(--font-mono);font-weight:500}
.billing-tx-negative{color:var(--error);font-family:var(--font-mono);font-weight:500}
.billing-tx-desc{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

[data-controller="scroll-reveal"]{opacity:0;transform:translateY(16px);transition:opacity .6s cubic-bezier(0.22,1,0.36,1),transform .6s cubic-bezier(0.22,1,0.36,1)}
[data-controller="scroll-reveal"].revealed{opacity:1;transform:translateY(0)}

@media(max-width:768px){
  .landing-hero{padding:100px 24px 56px;min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center}
  .landing-hero-video{display:block;opacity:.4}
  .landing-hero-overlay{background:linear-gradient(180deg,rgba(10,10,18,.55) 0%,rgba(10,10,18,.7) 50%,rgba(10,10,18,.88) 100%)}
  .landing-hero-title{font-size:2.4rem;line-height:1.12}
  .landing-hero-subtitle{font-size:1rem;line-height:1.6;margin-bottom:24px}
  .landing-hero-actions{flex-direction:column;align-items:center;gap:12px}
  .landing-hero-actions .btn{width:100%;max-width:320px;text-align:center}
  .landing-social-proof{margin-bottom:24px}
  .landing-section{padding:56px 24px}
  .landing-section-title{font-size:1.7rem;margin-bottom:12px}
  .landing-section-subtitle{font-size:.95rem;margin-bottom:28px}
  .landing-themes-track{padding:0 24px;margin-top:28px}
  .landing-theme-card{width:140px}
  .landing-theme-image{width:140px;height:186px}
  .landing-theme-name{font-size:.8rem;margin-top:8px}
  .landing-comparison{flex-direction:column;gap:12px}
  .landing-comparison-side{width:100%;max-width:300px;height:auto;aspect-ratio:3/4}
  .landing-comparison-arrow{transform:rotate(90deg)}
  .landing-comparison-arrow svg{width:24px;height:24px}
  .landing-comparisons{gap:32px;margin-top:32px}
  .landing-steps{flex-direction:column;gap:12px}
  .landing-steps::before{display:none}
  .landing-step-divider{transform:rotate(90deg)}
  .landing-step-divider svg{width:20px;height:20px}
  .landing-step{width:100%;padding:24px 20px}
  .landing-step-number{width:44px;height:44px;font-size:1rem;margin-bottom:12px}
  .landing-step h4{font-size:.95rem}
  .landing-step p{font-size:.85rem}
  .landing-plan-card.recommended{transform:none}
  .landing-plans-grid{grid-template-columns:1fr;gap:16px}
  .landing-plan-card{padding:24px}
  .landing-plan-card h4{font-size:1.05rem}
  .landing-plan-amount{font-size:2rem}
  .landing-plan-credits{font-size:.85rem}
  .landing-plan-features li{font-size:.85rem}
  .landing-nav-inner{padding:12px 16px}
  .landing-nav-links{gap:10px}
  .landing-nav-link{font-size:.8rem}
  .landing-footer{padding:40px 24px}
  .landing-footer-inner{flex-direction:column;text-align:center;gap:16px}
  .landing-footer-links{justify-content:center}
  .landing-footer-brand p{font-size:.85rem}
  .landing-footer-links a{font-size:.82rem}
  .landing-section-cta{margin-top:32px}
  .landing-section-cta .btn{width:100%;max-width:320px}
  .waitlist-form{flex-direction:column}
  .waitlist-btn{width:100%}
  .waitlist-wrap{max-width:100%}
  .landing-cta-section{padding:64px 24px}
  .landing-cta-text{font-size:.95rem}
  .landing-cta-section .landing-section-title{font-size:1.6rem}
  .landing-footer{padding-bottom:64px}
  .pricing-plans-grid{grid-template-columns:1fr}
  .pricing-packs-grid{grid-template-columns:1fr}
  .checkout-layout{grid-template-columns:1fr}
  .checkout-summary{position:static}
  .billing-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .landing-hero-title{font-size:2rem}
  .landing-hero-subtitle{font-size:.92rem}
  .landing-hero{padding:80px 20px 48px}
  .landing-nav-links{gap:8px}
  .landing-comparison-side{max-width:260px}
  .landing-social-proof{flex-direction:column;gap:4px}
  .landing-section-title{font-size:1.4rem}
  .landing-section{padding:48px 20px}
  .landing-theme-card{width:130px}
  .landing-theme-image{width:130px;height:172px}
}
@keyframes lpPulse{0%,100%{box-shadow:0 0 20px rgba(var(--lp-accent-rgb),.3)}50%{box-shadow:0 0 40px rgba(var(--lp-accent-rgb),.5),0 0 60px rgba(var(--lp-accent-rgb),.15)}}
@keyframes lpGradient{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

.lp-hero{
  min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:120px 32px 60px;text-align:center;position:relative;overflow:hidden;
}
.lp-hero-video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
}
.lp-hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(10,10,18,.65) 0%,rgba(10,10,18,.8) 60%,rgba(10,10,18,.95) 100%);
}
.lp-hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 50% -20%,rgba(var(--lp-accent-rgb),.15) 0%,transparent 50%),
    radial-gradient(circle at 15% 80%,rgba(var(--lp-accent-rgb),.06) 0%,transparent 40%),
    radial-gradient(circle at 85% 60%,rgba(var(--lp-accent-rgb),.06) 0%,transparent 35%);
  z-index:0;
}
.lp-hero-bg::before{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 60L60 0' stroke='%23ffffff' stroke-width='.3' opacity='.04'/%3E%3C/svg%3E");
  pointer-events:none;
}
.lp-hero-inner{max-width:800px;margin:0 auto;position:relative;z-index:2}
.lp-hero-badge{
  display:inline-block;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--lp-accent);
  background:rgba(var(--lp-accent-rgb),.1);border:1px solid rgba(var(--lp-accent-rgb),.25);
  padding:6px 16px;border-radius:20px;margin-bottom:24px;
  animation:revealUp .6s ease;
}
.lp-hero-title{
  font-family:var(--font-display);font-size:4.2rem;font-weight:400;
  line-height:1.1;margin-bottom:20px;letter-spacing:-.03em;
  animation:revealUp .8s ease .1s backwards;
}
.lp-hero-title em{color:var(--lp-accent);font-style:italic}
.lp-hero-subtitle{
  font-size:1.15rem;color:var(--text-secondary);line-height:1.65;
  max-width:560px;margin:0 auto 28px;
  animation:revealUp .8s ease .2s backwards;
}
.lp-hero-cta-wrap{animation:revealUp .8s ease .3s backwards}
.lp-cta-btn{
  width:auto;padding:16px 44px;font-size:1rem;
  background:var(--lp-accent);color:#fff;
  box-shadow:0 0 20px rgba(var(--lp-accent-rgb),.3);
  animation:lpPulse 3s ease-in-out infinite;
  transition:all .2s;
}
.lp-cta-btn:hover{
  box-shadow:0 0 40px rgba(var(--lp-accent-rgb),.4),0 0 80px rgba(var(--lp-accent-rgb),.15);
  transform:translateY(-2px);
}
.lp-trust-badges{
  display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap;
  margin-top:24px;animation:revealUp .8s ease .4s backwards;
}
.lp-trust-badge{
  display:flex;align-items:center;gap:6px;
  font-size:.78rem;color:var(--text-secondary);
}
.lp-trust-badge svg{color:var(--lp-accent)}

.lp-hero-comparison{
  display:flex;align-items:center;justify-content:center;gap:24px;
  margin-top:48px;position:relative;z-index:2;
  animation:revealUp .8s ease .5s backwards;
}
.lp-hero-comparison-side{
  width:240px;height:300px;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--border);position:relative;
}
.lp-hero-comparison-side img{width:100%;height:100%;object-fit:cover;display:block}
.lp-hero-comparison-after{
  border-color:var(--lp-accent);
  box-shadow:0 0 30px rgba(var(--lp-accent-rgb),.2);
}
.lp-hero-comparison-arrow{flex-shrink:0;animation:pulse 2s ease-in-out infinite}

.lp-section-title{
  font-family:var(--font-display);font-size:2.4rem;font-weight:400;
  text-align:center;margin-bottom:16px;
}
.lp-section-title em{color:var(--lp-accent);font-style:italic}

.lp-time-badge{
  text-align:center;font-family:var(--font-mono);font-size:.75rem;
  color:var(--lp-accent);background:rgba(var(--lp-accent-rgb),.08);
  border:1px solid rgba(var(--lp-accent-rgb),.2);
  padding:6px 16px;border-radius:20px;width:fit-content;margin:0 auto 40px;
}

.lp-themes-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;
  margin-top:40px;
}
.lp-theme-card{
  background:var(--glass-bg);backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-border);border-radius:var(--radius-lg);
  overflow:hidden;transition:all .3s;
}
.lp-theme-card:hover{
  border-color:var(--lp-accent);transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(0,0,0,.3);
}
.lp-theme-image{width:100%;height:280px;overflow:hidden}
.lp-theme-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.lp-theme-card:hover .lp-theme-image img{transform:scale(1.05)}
.lp-theme-name{
  display:block;padding:16px 16px 4px;
  font-size:.9rem;font-weight:500;color:var(--text-primary);
}
.lp-theme-desc{
  padding:0 16px 16px;font-size:.78rem;color:var(--text-secondary);line-height:1.5;
}

.lp-per-photo-price{
  font-family:var(--font-mono);font-size:.82rem;font-weight:600;
  color:var(--lp-accent);margin-bottom:16px;
}

.lp-faq-list{max-width:700px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.lp-faq-item{
  background:var(--bg-elevated);border:1px solid var(--border-subtle);
  border-radius:var(--radius-lg);overflow:hidden;transition:border-color .3s;
}
.lp-faq-item:hover{border-color:rgba(var(--lp-accent-rgb),.4)}
.lp-faq-item.active{border-color:var(--lp-accent)}
.lp-faq-question{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;padding:20px 24px;cursor:pointer;
  font-size:.9rem;font-weight:500;color:var(--text-primary);
  background:none;border:none;text-align:left;
}
.lp-faq-chevron{transition:transform .3s;color:var(--text-muted);flex-shrink:0}
.lp-faq-item.active .lp-faq-chevron{transform:rotate(180deg);color:var(--lp-accent)}
.lp-faq-answer{
  max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;
}
.lp-faq-item.active .lp-faq-answer{max-height:200px;padding:0 24px 20px}
.lp-faq-answer p{font-size:.82rem;color:var(--text-secondary);line-height:1.6}

.lp-sticky-bar{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:99;
  background:rgba(10,10,18,.95);backdrop-filter:blur(12px);
  border-top:1px solid var(--border-subtle);
  padding:12px 16px;
}
.lp-sticky-bar-inner{
  max-width:600px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.lp-sticky-bar-text{font-size:.82rem;color:var(--text-secondary);flex:1}
.lp-sticky-bar-btn{
  padding:10px 24px;font-size:.85rem;white-space:nowrap;
  background:var(--lp-accent);color:#fff;
  box-shadow:0 0 16px rgba(var(--lp-accent-rgb),.3);
}

@media(max-width:768px){
  .lp-hero{min-height:auto;padding:120px 20px 40px}
  .lp-hero-video{display:none}
  .lp-hero-title{font-size:2.4rem}
  .lp-hero-subtitle{font-size:.95rem}
  .lp-hero-comparison{flex-direction:column;gap:16px;margin-top:32px}
  .lp-hero-comparison-side{width:200px;height:260px}
  .lp-hero-comparison-arrow{transform:rotate(90deg)}
  .lp-section-title{font-size:1.8rem}
  .lp-themes-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}
  .lp-theme-image{height:220px}
  .lp-trust-badges{gap:12px}
  .lp-sticky-bar{display:block}
}
@media(max-width:480px){
  .lp-hero-title{font-size:1.8rem}
  .lp-hero-subtitle{font-size:.85rem}
  .lp-hero-comparison-side{width:160px;height:210px}
  .lp-trust-badges{flex-direction:column;gap:8px}
  .lp-section-title{font-size:1.4rem}
}

.btn-google{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;padding:10px 16px;
  background:#fff;color:#3c4043;
  border:1px solid #dadce0;border-radius:var(--radius);
  font-size:.9rem;font-weight:500;cursor:pointer;
  transition:background .2s,box-shadow .2s;
}
.btn-google:hover{background:#f7f8f8;box-shadow:0 1px 3px rgba(0,0,0,.08)}
.oauth-buttons{margin-bottom:16px}
.auth-divider{
  display:flex;align-items:center;margin:16px 0;
  color:var(--text-muted);font-size:.8rem;
}
.auth-divider::before,.auth-divider::after{
  content:"";flex:1;border-top:1px solid var(--border);
}
.auth-divider span{padding:0 12px}

.customize-toggle{display:flex;align-items:center;gap:6px;width:100%;padding:8px 0;border:none;background:none;color:var(--text-muted);font-family:var(--font-mono);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:color .15s}
.customize-toggle:hover{color:var(--text-primary)}
.customize-toggle svg{opacity:.5}
.customize-toggle .customize-chevron{margin-left:auto;transition:transform .15s}
.customize-panel{padding-top:8px}
.customize-axis{margin-bottom:10px}
.customize-axis-label{display:block;font-family:var(--font-mono);font-size:.55rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:5px}
.customize-axis-chips{display:flex;flex-wrap:wrap;gap:4px}
.photoshoot-form-sidebar .customize-axis-chips .chip{font-size:.62rem;padding:4px 8px;min-height:26px}

.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:var(--bg-elevated);border-top:1px solid var(--border);padding:16px 24px;backdrop-filter:blur(12px)}
.cookie-banner-inner{max-width:960px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.cookie-banner-inner p{font-size:.82rem;color:var(--text-secondary);margin:0;flex:1;min-width:200px}
.cookie-banner-inner a{color:var(--accent);text-decoration:underline}
.cookie-banner-actions{display:flex;gap:8px;flex-shrink:0}
.btn-sm{padding:8px 16px;font-size:.78rem}
@media(max-width:600px){.cookie-banner-inner{flex-direction:column;text-align:center}.cookie-banner-actions{width:100%;justify-content:center}}

