
/* @font-face for custom uploaded fonts */
@font-face{font-family:'Abnormal Bold';src:url('fonts/AbnormalBold.otf')format('opentype');font-weight:700;}
@font-face{font-family:'Abnormal Light';src:url('fonts/AbnormalLight.otf')format('opentype');font-weight:300;}
@font-face{font-family:'Abnormal';src:url('fonts/AbnormalRegular.otf')format('opentype');font-weight:400;}
@font-face{font-family:'Abnormal SemiBold';src:url('fonts/AbnormalSemiBold.otf')format('opentype');font-weight:600;}
@font-face{font-family:'Alkia';src:url('fonts/Alkia.ttf')format('truetype');}
@font-face{font-family:'Bohme Rounded';src:url('fonts/Bohme-Rounded.ttf')format('truetype');}
@font-face{font-family:'Bohme';src:url('fonts/Bohme.ttf')format('truetype');}
@font-face{font-family:'Broclen';src:url('fonts/BroclenRegular-JpR9M.ttf')format('truetype');}
@font-face{font-family:'Bunny Lovers';src:url('fonts/Bunny Lovers One Font by Keithzo.otf')format('opentype');}
@font-face{font-family:'Cambay';src:url('fonts/Cambay-Regular.ttf')format('truetype');font-weight:400;}
@font-face{font-family:'Cambay';src:url('fonts/Cambay-Bold.ttf')format('truetype');font-weight:700;}
@font-face{font-family:'Cambay';src:url('fonts/Cambay-Italic.ttf')format('truetype');font-weight:400;font-style:italic;}
@font-face{font-family:'Cambay';src:url('fonts/Cambay-BoldItalic.ttf')format('truetype');font-weight:700;font-style:italic;}
@font-face{font-family:'CatSong';src:url('fonts/CatSong-Zpp7B.otf')format('opentype');}
@font-face{font-family:'Chatlong';src:url('fonts/Chatlong-j99BG.otf')format('opentype');}
@font-face{font-family:'Finlikless';src:url('fonts/Finlikless-Regular.ttf')format('truetype');}
@font-face{font-family:'Gantians';src:url('fonts/Gantians-BLL2B.otf')format('opentype');}
@font-face{font-family:'Gaseno Bold';src:url('fonts/Gaseno-Bold.otf')format('opentype');font-weight:700;}
@font-face{font-family:'Gaseno Light';src:url('fonts/Gaseno-Light.otf')format('opentype');font-weight:300;}
@font-face{font-family:'Gaseno';src:url('fonts/Gaseno-Normal.otf')format('opentype');font-weight:400;}
@font-face{font-family:'Gaseno Rounded';src:url('fonts/Gaseno-Rounded.otf')format('opentype');}
@font-face{font-family:'Gaseno SemiBold';src:url('fonts/Gaseno-SemiBold.otf')format('opentype');font-weight:600;}
@font-face{font-family:'Gendy';src:url('fonts/Gendy.otf')format('opentype');}
@font-face{font-family:'Intan';src:url('fonts/Intan.otf')format('opentype');}
@font-face{font-family:'Moon Starlaa';src:url('fonts/MoonStarlaa-BLLmd.ttf')format('truetype');}
@font-face{font-family:'Player One';src:url('fonts/PLAYER_ONE.otf')format('opentype');}
@font-face{font-family:'Power Up';src:url('fonts/POWER_UP.otf')format('opentype');}
@font-face{font-family:'Provicali';src:url('fonts/Provicali.otf')format('opentype');}
@font-face{font-family:'Quick Zip';src:url('fonts/QUICK-ZIP.otf')format('opentype');}
@font-face{font-family:'Raintion';src:url('fonts/Raintion-Black.ttf')format('truetype');font-weight:900;}
@font-face{font-family:'Requiner';src:url('fonts/Requiner-6RRLM.otf')format('opentype');}
@font-face{font-family:'SemiCasual';src:url('fonts/SemiCasual.ttf')format('truetype');}
@font-face{font-family:'SnackBox';src:url('fonts/SnackBox-XGGmK.otf')format('opentype');}
@font-face{font-family:'Soul Daisy';src:url('fonts/SoulDaisy.otf')format('opentype');}
@font-face{font-family:'Summer Days';src:url('fonts/SummerDays-9MM20.ttf')format('truetype');}
@font-face{font-family:'Suntage';src:url('fonts/Suntage-DOAX1.otf')format('opentype');}
@font-face{font-family:'Toony Sans Italic';src:url('fonts/ToonySansPersonalUseItalic-4BPdl.otf')format('opentype');font-style:italic;}
@font-face{font-family:'Toony Sans';src:url('fonts/ToonySansPersonalUseRegular-0WwzP.otf')format('opentype');}
@font-face{font-family:'Vactory Sans';src:url('fonts/VactorySansRegular-drrAV.ttf')format('truetype');}


/* API Keys header panel */
#api-keys-panel{position:fixed;top:60px;left:0;width:340px;background:#1e293b;border:1px solid #334155;border-top:none;border-radius:0 0 12px 0;box-shadow:0 8px 32px rgba(0,0,0,0.45);z-index:9999;padding:18px 20px 20px;transform:translateX(-110%);transition:transform 0.3s cubic-bezier(0.4,0,0.2,1);overflow:hidden;}
#api-keys-panel.open{transform:translateX(0);}
#api-keys-panel label{color:#94a3b8;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;display:block;margin-bottom:3px;}
#api-keys-panel input{width:100%;background:#0f172a;color:#e2e8f0;border:1px solid #334155;border-radius:6px;padding:7px 10px;font-size:12px;box-sizing:border-box;margin-bottom:10px;}
#api-keys-panel .ak-title{color:#a855f7;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;margin-bottom:14px;display:flex;align-items:center;gap:8px;}
#api-keys-panel .ak-title button{margin-left:auto;background:none;border:none;color:#64748b;cursor:pointer;font-size:16px;padding:0;line-height:1;}
#api-keys-panel .ak-title button:hover{color:#e2e8f0;}
#api-keys-panel textarea{width:100%;background:#0f172a;color:#e2e8f0;border:1px solid #334155;border-radius:6px;padding:7px 10px;font-size:11px;box-sizing:border-box;resize:vertical;min-height:52px;margin-bottom:10px;}
#api-keys-btn{background:rgba(168,85,247,0.18);color:#c4b5fd;border:1px solid rgba(168,85,247,0.4);padding:7px 14px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:background .2s;}
#api-keys-btn:hover{background:rgba(168,85,247,0.32);}
/* ── Collapsible Style Dropdown ── */
.style-dropdown{margin-top:4px;}
.style-dropdown .sd-toggle{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;color:#6d28d9;cursor:pointer;user-select:none;text-transform:uppercase;letter-spacing:.5px;padding:3px 8px;border-radius:5px;background:#f5f3ff;border:1px solid #e0d9f5;transition:background .15s;}
.style-dropdown .sd-toggle:hover{background:#ede9fe;}
.style-dropdown .sd-toggle .sd-arrow{font-size:8px;transition:transform .15s;}
.style-dropdown.open .sd-toggle .sd-arrow{transform:rotate(180deg);}
.style-dropdown .sd-body{display:none;background:#f8f7ff;border:1px solid #e0d9f5;border-radius:6px;padding:8px 10px;margin-top:4px;}
.style-dropdown.open .sd-body{display:block;}
.sd-body .sd-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:4px;}
.sd-body .sd-row:last-child{margin-bottom:0;}
.sd-body .sd-reset{font-size:10px;font-weight:700;color:#6d28d9;background:#fff;border:1px solid #c4b5fd;border-radius:5px;padding:4px 10px;cursor:pointer;text-transform:uppercase;letter-spacing:.4px;}
.sd-body .sd-reset:hover{background:#ede9fe;}
.sd-details{margin:6px 0 6px 8px;border-left:2px solid #e0d9f5;padding-left:8px;}
.sd-details > summary{font-size:10px;font-weight:700;color:#6d28d9;cursor:pointer;text-transform:uppercase;letter-spacing:.4px;padding:3px 0;list-style:none;user-select:none;}
.sd-details > summary::before{content:'▶ ';font-size:8px;}
.sd-details[open] > summary::before{content:'▼ ';}
.sd-details > summary::-webkit-details-marker{display:none;}
.sd-body .sd-row-label{font-size:11px;font-weight:800;color:#1e293b;text-transform:uppercase;letter-spacing:.4px;min-width:32px;}
.sd-body .sd-font{width:110px;height:22px;font-size:10px;border:1px solid #d1d5db;border-radius:4px;padding:0 3px;background:#fff;}
.sd-body .sd-color{width:22px;height:22px;border:1px solid #d1d5db;border-radius:4px;padding:0;cursor:pointer;vertical-align:middle;}
.sd-body .sd-btn{width:22px;height:22px;border:1px solid #d1d5db;border-radius:4px;background:#fff;cursor:pointer;font-size:10px;display:inline-flex;align-items:center;justify-content:center;color:#64748b;transition:all .15s;}
.sd-body .sd-btn:hover{background:#f1f5f9;}
.sd-body .sd-btn.on{background:#7c3aed;color:#fff;border-color:#7c3aed;}


:root{--navy:#1e0a3c;--gold:#a855f7;--gold-lt:#f0c96a;--cream:#faf8f3;--slate:#4a5568;--success:#22c55e;--danger:#ef4444;--card-shadow:0 20px 60px rgba(15,39,68,0.13);}
/* ── Multiline text input (Shift+Enter support) ── */
textarea.multiline-input{resize:vertical;min-height:34px;max-height:120px;line-height:1.4;font-family:inherit;font-size:inherit;padding:7px 10px;overflow-y:auto;}
/* ── Template Dropdown Styles ── */
.tpl-dropdown-wrap{position:relative;margin-bottom:12px;}
.tpl-dropdown-btn{width:100%;padding:12px 20px;background:linear-gradient(135deg,#1e1b4b,#312e81);border:1.5px solid rgba(139,92,246,0.35);border-radius:10px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;transition:all .2s;box-sizing:border-box;overflow:hidden;}
.tpl-dropdown-btn > span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1;}
.tpl-dropdown-btn:hover{border-color:#a855f7;background:linear-gradient(135deg,#312e81,#3b0764);}
.tpl-dropdown-btn .dd-chev{transition:transform .2s;font-size:11px;color:rgba(255,255,255,0.6);}
.tpl-dropdown-btn.open .dd-chev{transform:rotate(180deg);}
.tpl-dropdown-list{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#1e1b4b;border:1.5px solid rgba(139,92,246,0.4);border-radius:10px;overflow:hidden;z-index:50;display:none;box-shadow:0 8px 24px rgba(0,0,0,0.4);}
.tpl-dropdown-list.open{display:block;}
.tpl-dd-item{padding:12px 18px;cursor:pointer;font-size:12.5px;font-weight:500;color:rgba(255,255,255,0.85);border-bottom:1px solid rgba(139,92,246,0.15);display:flex;align-items:center;gap:10px;transition:background .15s;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.tpl-dd-item:last-child{border-bottom:none;}
.tpl-dd-item:hover{background:rgba(139,92,246,0.18);}
.tpl-dd-item.active{background:rgba(139,92,246,0.25);color:#fff;font-weight:700;}
.tpl-dd-item .dd-num{width:22px;height:22px;border-radius:50%;background:rgba(139,92,246,0.3);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#c4b5fd;flex-shrink:0;}
.tpl-dd-item.active .dd-num{background:#7c3aed;color:#fff;}
.tpl-dd-item.placeholder{opacity:0.5;cursor:default;}
.tpl-dd-item.placeholder:hover{background:transparent;}
.tpl-dd-item.placeholder .dd-badge{font-size:9px;background:rgba(255,255,255,0.12);color:rgba(255,255,255,0.5);padding:2px 6px;border-radius:4px;font-weight:600;letter-spacing:.3px;margin-left:auto;}
/* ── Bold/Italic Toggle Styles ── */
.text-style-toggles{display:inline-flex;gap:2px;margin-left:6px;vertical-align:middle;}
.text-style-btn{width:24px;height:22px;border:1.5px solid #e2e8f0;border-radius:4px;background:#fff;cursor:pointer;font-size:12px;font-family:'Inter',sans-serif;color:var(--slate);display:inline-flex;align-items:center;justify-content:center;transition:all .15s;padding:0;line-height:1;}
.text-style-btn:hover{border-color:var(--gold);background:#fffdf7;}
.text-style-btn.active{background:#7c3aed;color:#fff;border-color:#7c3aed;}
.text-style-btn.active:hover{background:#6d28d9;}
/* ── Font Picker Styles ── */
.font-picker-wrap{position:relative;margin-top:3px;}
.font-picker-btn{display:flex;align-items:center;gap:6px;width:100%;padding:5px 8px;border:1.5px solid #e2e8f0;border-radius:6px;background:#fff;cursor:pointer;font-size:11px;color:var(--navy);font-family:'Inter',sans-serif;transition:border-color .2s;}
.font-picker-btn:hover,.font-picker-btn.open{border-color:var(--gold);}
.font-picker-btn .fp-label{flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500;}
.font-picker-btn .fp-icon{font-size:9px;color:#94a3b8;transition:transform .2s;}
.font-picker-btn.open .fp-icon{transform:rotate(180deg);}
.font-picker-dd{display:none;position:absolute;top:100%;left:0;right:0;z-index:999;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,0.15);margin-top:2px;max-height:280px;overflow:hidden;flex-direction:column;}
.font-picker-dd.open{display:flex;}
.fp-search{border:none;border-bottom:1px solid #f0ede8;padding:8px 10px;font-size:12px;font-family:'Inter',sans-serif;outline:none;width:100%;}
.fp-list{overflow-y:auto;max-height:240px;padding:4px 0;}
.fp-item{padding:6px 10px;cursor:pointer;font-size:12px;transition:background .1s;display:flex;align-items:center;gap:8px;}
.fp-item:hover{background:#f5f3ff;}
.fp-item.active{background:#ede9fe;font-weight:600;}
.fp-item .fp-cat{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#a855f7;flex-shrink:0;}
.fp-item .fp-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.fp-group-label{padding:6px 10px 3px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--gold);border-top:1px solid #f0ede8;margin-top:2px;}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Inter',sans-serif;background:#ede9e0;color:var(--navy);min-height:100vh;}
header{background:linear-gradient(135deg,#4c1d95 0%,#6d28d9 60%,#7c3aed 100%);padding:16px 36px;display:flex;align-items:center;gap:16px;box-shadow:0 4px 24px rgba(109,40,217,0.45);}
.hlogo{height:36px;}
.htitle{font-family:'Playfair Display',serif;color:#fff;font-size:20px;}
.hbadge{margin-left:auto;background:var(--gold);color:var(--navy);font-size:10px;font-weight:700;padding:4px 14px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px;}
/* Split-panel layout: controls left, preview right */
:root{--panel-w:520px;}
.container{display:flex;gap:0;max-width:100%;margin:0;padding:0;height:calc(100vh - 68px);}
.controls-panel{flex:0 0 var(--panel-w);width:var(--panel-w);max-width:var(--panel-w);min-width:0;overflow-y:auto;overflow-x:hidden;padding:24px 20px;background:#ede9e0;border-right:1px solid #e2e8f0;height:100%;box-sizing:border-box;}
.preview-panel{flex:1;min-width:0;overflow-y:auto;padding:24px 20px;background:#f5f3f0;height:100%;box-sizing:border-box;display:flex;flex-direction:column;align-items:flex-start;}
.preview-panel > *{align-self:stretch;max-width:100%;}
.preview-panel .cards-grid{margin-left:0 !important;margin-right:auto !important;}
#panel-resizer{flex:0 0 6px;background:#cbd5e1;cursor:col-resize;position:relative;z-index:50;transition:background .15s;}
#panel-resizer:hover,#panel-resizer.dragging{background:#a855f7;}
#panel-resizer::after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:2px;height:40px;background:#94a3b8;border-radius:2px;pointer-events:none;}
#panel-resizer:hover::after,#panel-resizer.dragging::after{background:#fff;}
body.resizing{cursor:col-resize;user-select:none;}
body.resizing *{user-select:none !important;}
html[data-theme="dark"] #panel-resizer{background:#334155;}
html[data-theme="dark"] #panel-resizer:hover,html[data-theme="dark"] #panel-resizer.dragging{background:#a855f7;}
.controls-panel select,.controls-panel input[type="text"],.controls-panel input[type="tel"],.controls-panel input[type="email"],.controls-panel input[type="url"],.controls-panel input[type="number"]{max-width:100%;min-width:0;box-sizing:border-box;}
.controls-panel .field{min-width:0;}
#zoom-bar{display:inline-flex !important;align-items:center;gap:12px;margin:0 0 14px 0 !important;padding:12px 28px !important;background:#fff;border-radius:14px;box-shadow:0 1px 4px rgba(0,0,0,0.08);user-select:none;align-self:flex-start !important;width:auto !important;max-width:100%;flex-wrap:wrap;row-gap:8px;}
#zoom-bar .zb-label{font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.6px;white-space:nowrap;flex-shrink:0;}
#zoom-bar .zb-btn{width:30px;height:30px;border:1px solid #e2e8f0;border-radius:6px;background:#f8fafc;color:#334155;font-size:16px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;padding:0;line-height:1;}
#zoom-bar .zb-btn:hover{background:#e2e8f0;}
#zoom-bar .zb-val{font-size:13px;font-weight:800;color:#6d28d9;min-width:46px;text-align:center;white-space:nowrap;flex-shrink:0;}
#zoom-bar .zb-reset{border:1px solid #e2e8f0;border-radius:6px;background:#f8fafc;color:#475569;font-size:11px;font-weight:700;padding:8px 18px !important;cursor:pointer;white-space:nowrap;flex-shrink:0;margin-left:4px;line-height:1.4;height:auto;min-height:30px;display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;}
#zoom-bar .zb-reset:hover{background:#e2e8f0;color:#1e293b;}
html[data-theme="dark"] #zoom-bar{background:#1e293b;}
html[data-theme="dark"] #zoom-bar .zb-label{color:#94a3b8;}
html[data-theme="dark"] #zoom-bar .zb-btn,html[data-theme="dark"] #zoom-bar .zb-reset{background:#0f172a;color:#e2e8f0;border-color:#334155;}
html[data-theme="dark"] #zoom-bar .zb-btn:hover,html[data-theme="dark"] #zoom-bar .zb-reset:hover{background:#334155;}
html[data-theme="dark"] #zoom-bar .zb-val{color:#c4b5fd;}
/* Responsive: stack on narrow screens */
@media(max-width:1100px){
  .container{flex-direction:column;height:auto;}
  .controls-panel{flex:none;max-width:100%;height:auto;border-right:none;border-bottom:1px solid #e2e8f0;}
  .preview-panel{flex:none;height:auto;}
}
.accordion{background:#fff;border-radius:14px;box-shadow:var(--card-shadow);margin-bottom:14px;overflow:hidden;}
.accordion-header{display:flex;align-items:center;gap:12px;padding:20px 24px;cursor:pointer;user-select:none;transition:background .15s;}
.accordion-header:hover{background:#fafafa;}
.acc-icon{font-size:20px;width:32px;text-align:center;}
.acc-title{font-family:'Provicali',serif;font-size:18px;font-weight:normal;flex:1;}
.acc-sub{font-size:11px;color:var(--slate);margin-top:2px;}
.acc-chev{color:var(--slate);font-size:14px;transition:transform .25s;margin-left:auto;}
.accordion-header.open .acc-chev{transform:rotate(180deg);}
.accordion-body{display:none;padding:0 24px 24px;border-top:1px solid #f0ede8;}
.accordion-body.open{display:block;}
.fields{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px;}
.field{display:flex;flex-direction:column;gap:5px;min-width:0;}
.field.full{grid-column:1/-1;}
label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--slate);}
input,select,textarea{border:1.5px solid #e2e8f0;border-radius:8px;padding:9px 12px;font-size:13px;font-family:'Inter',sans-serif;color:var(--navy);background:#fff;outline:none;transition:border-color .2s;}
input:focus,select:focus,textarea:focus{border-color:var(--gold);}
input[type="password"]{font-family:monospace;font-size:12px;}
textarea{resize:vertical;min-height:100px;line-height:1.7;}
.sec-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--gold);margin-bottom:10px;margin-top:16px;}
hr.div{border:none;border-top:1px solid #f0ede8;margin:18px 0;}
.logo-upload-area{border:2px dashed #e2e8f0;border-radius:10px;padding:20px;text-align:center;cursor:pointer;transition:all .2s;position:relative;}
.logo-upload-area:hover{border-color:var(--gold);background:#fffdf7;}
.logo-upload-area input{position:absolute;inset:0;opacity:0;cursor:pointer;}
.logo-preview{max-height:60px;max-width:220px;object-fit:contain;display:none;margin:0 auto;}
.logo-upload-hint{font-size:12px;color:var(--slate);}
.color-row{display:flex;gap:6px;align-items:center;min-width:0;}
.swatch{width:30px;height:30px;border-radius:6px;border:1.5px solid #e2e8f0;cursor:pointer;flex-shrink:0;position:relative;overflow:hidden;}
.swatch input[type="color"]{position:absolute;inset:-4px;opacity:0;cursor:pointer;width:calc(100%+8px);height:calc(100%+8px);}
.mode-tabs{display:flex;background:#f0ece4;border-radius:8px;overflow:hidden;margin-top:16px;margin-bottom:16px;}
.mode-tab{flex:1;padding:10px;text-align:center;font-size:12px;font-weight:600;cursor:pointer;background:transparent;color:var(--slate);border:none;font-family:'Inter',sans-serif;transition:all .2s;border-radius:8px;}
.template-card{border:2px solid #e2e8f0;border-radius:12px;padding:12px;cursor:pointer;transition:all .2s;background:#fafafa;}
.template-card:hover{border-color:#a855f7;background:#fdf4ff;}
.research-panel{background:#fff;border-radius:14px;box-shadow:var(--card-shadow);margin-bottom:14px;overflow:hidden;border:none;}
.research-header{padding:20px 24px 16px;display:flex;align-items:center;gap:14px;}
.research-icon{font-size:26px;}
.research-title{font-family:'Provicali',serif;font-size:18px;font-weight:normal;color:#1e293b;flex:1;}
.research-sub{font-size:11px;color:#c4b5fd;margin-top:2px;}
.research-body{padding:0 24px 24px;}
.research-inputs{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px;}
.research-input{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:9px;padding:10px 14px;font-size:13px;font-family:'Inter',sans-serif;color:#1e293b;outline:none;transition:border-color .2s;width:100%;}
.research-input::placeholder{color:#94a3b8;}
.research-input:focus{border-color:#a855f7;background:#fff;}
.research-btn{background:linear-gradient(135deg,#6d28d9,#a855f7);color:#fff;border:none;border-radius:9px;padding:11px 28px;font-size:13px;font-weight:700;font-family:'Inter',sans-serif;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px;white-space:nowrap;}
.research-btn:hover{background:linear-gradient(135deg,#7c3aed,#c084fc);transform:translateY(-1px);box-shadow:0 4px 16px rgba(109,40,217,0.45);}
.research-btn:disabled{opacity:0.55;cursor:not-allowed;transform:none;}
.research-status{margin-top:12px;padding:12px 16px;border-radius:9px;font-size:12px;display:none;}
.research-status.loading{background:rgba(109,40,217,0.08);border:1px solid rgba(109,40,217,0.25);color:#5b21b6;display:flex;align-items:center;gap:10px;}
.research-status.success{background:rgba(22,163,74,0.08);border:1px solid rgba(22,163,74,0.3);color:#15803d;display:block;}
.research-status.error{background:rgba(220,38,38,0.08);border:1px solid rgba(220,38,38,0.3);color:#dc2626;display:block;}
.research-results{margin-top:14px;display:none;background:rgba(255,255,255,0.05);border-radius:10px;padding:14px 16px;border:1px solid rgba(168,85,247,0.2);}
.research-results-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#a855f7;margin-bottom:10px;}
.research-field-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:7px;font-size:12px;}
.research-field-key{color:#6d28d9;font-weight:600;min-width:90px;flex-shrink:0;}
.research-field-val{color:#1e293b;word-break:break-all;}
.research-apply-btn{margin-top:14px;background:rgba(34,197,94,0.2);border:1.5px solid rgba(34,197,94,0.5);color:#86efac;border-radius:8px;padding:10px 20px;font-size:12px;font-weight:700;font-family:'Inter',sans-serif;cursor:pointer;transition:all .2s;width:100%;}
.research-apply-btn:hover{background:rgba(34,197,94,0.32);}
.spinner{width:16px;height:16px;border:2px solid rgba(168,85,247,0.3);border-top-color:#a855f7;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0;}
@keyframes spin{to{transform:rotate(360deg);}}
.template-card.selected{border-color:#6d28d9;background:#f5f3ff;box-shadow:0 0 0 3px rgba(109,40,217,0.15);}
.tpl-preview-3{position:relative;height:60px;border-radius:5px;overflow:hidden;background:#e8e8e8;}
.tpl3-texture{position:absolute;inset:0;background:linear-gradient(135deg,#7c3aed 0%,#2a5298 100%);opacity:0.85;}
.tpl3-photo{position:absolute;right:0;top:0;width:52%;height:100%;background:#b0c4de;clip-path:polygon(12% 0,100% 0,100% 100%,0% 100%);}
.tpl3-footer{position:absolute;bottom:0;left:0;right:0;height:28%;background:#a855f7;}
.tpl-preview{height:72px;border-radius:8px;overflow:hidden;position:relative;margin-bottom:10px;background:#e2e8f0;}
.tpl-label{font-size:13px;font-weight:700;color:#1e0a3c;}
.tpl-sub{font-size:11px;color:#64748b;margin-top:2px;}
.tpl-preview-1 .tpl-left-panel{position:absolute;left:0;top:0;width:48%;height:80%;background:#1e0a3c;clip-path:polygon(0 0,100% 0,88% 100%,0 100%);}
.tpl-preview-1 .tpl-right-photo{position:absolute;right:0;top:0;width:60%;height:80%;background:linear-gradient(135deg,#94a3b8,#64748b);}
.tpl-preview-1 .tpl-bottom-bar{position:absolute;bottom:0;left:0;width:100%;height:20%;background:#a855f7;}
.tpl-preview-2 .tpl2-photo{position:absolute;left:0;top:0;width:100%;height:100%;background:linear-gradient(135deg,#475569,#94a3b8);}
.tpl-preview-2 .tpl2-left-wave{position:absolute;left:0;top:0;width:46%;height:78%;background:#1e3a6e;clip-path:ellipse(90% 100% at 0% 50%);}
.tpl-preview-2 .tpl2-cta-box{position:absolute;left:6%;top:28%;width:36%;height:22%;background:#56a5e0;border-radius:3px;}
.tpl-preview-2 .tpl2-footer{position:absolute;bottom:0;left:0;width:100%;height:22%;background:#22c55e;}
.mode-tab.active{background:var(--navy);color:#fff;}
.warn-box{grid-column:1/-1;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:10px 14px;font-size:11px;color:#b91c1c;}
.info-box{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:10px 14px;font-size:11px;color:#1e40af;margin-top:8px;}
.model-card{background:#1a2f4e;border:2px solid #2a4a6e;border-radius:10px;padding:12px;cursor:pointer;transition:all .2s;text-align:center;}
.model-card:hover{border-color:var(--accent);background:#7c3aed;}
.model-card.active{border-color:var(--accent);background:#0e2a44;box-shadow:0 0 0 3px rgba(34,167,224,0.25);}
.model-name{font-size:12px;font-weight:700;color:#fff;margin-bottom:2px;}
.model-quality{font-size:11px;color:var(--accent);font-weight:600;margin-bottom:4px;}
.model-cost{font-size:16px;font-weight:800;color:#4ade80;margin-bottom:4px;}
.model-desc{font-size:10px;color:var(--slate);}
.preset-card{background:#1a2f4e;border:2px solid #2a4a6e;border-radius:8px;padding:10px 12px;cursor:pointer;font-size:12px;font-weight:600;color:#cbd5e1;transition:all .2s;text-align:center;}
.preset-card:hover{border-color:var(--accent);color:#fff;}
.preset-card.active{border-color:var(--gold);color:#fff;background:#7c3aed;box-shadow:0 0 0 2px rgba(234,179,8,0.2);}
.run-btn{margin-top:20px;width:100%;padding:15px;background:var(--navy);color:#fff;border:none;border-radius:10px;font-family:'Inter',sans-serif;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 4px 16px rgba(15,39,68,0.25);}
.run-btn:hover:not(:disabled){background:#1a3a5c;transform:translateY(-1px);}
.run-btn:disabled{opacity:.45;cursor:not-allowed;}
.run-btn .gold{color:var(--gold-lt);}
.log-panel{background:#0d1f33;border-radius:12px;padding:20px;margin-bottom:14px;display:none;}
.log-panel.on{display:block;}
.log-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--gold);margin-bottom:12px;}
.log-body{font-family:monospace;font-size:12px;line-height:1.8;color:#8899aa;max-height:220px;overflow-y:auto;}
.log-body .ok{color:#4ade80;}.log-body .err{color:#f87171;}.log-body .inf{color:#93c5fd;}.log-body .hd{color:#fff;font-weight:bold;}
.steps{display:none;background:#fff;border-radius:10px;overflow:hidden;box-shadow:var(--card-shadow);margin-bottom:14px;}
.step{flex:1;padding:12px 4px;text-align:center;font-size:10px;color:#9ca3af;border-right:1px solid #f0f0f0;transition:all .3s;}
.step:last-child{border-right:none;}
.step .n{display:block;width:20px;height:20px;border-radius:50%;background:#e5e7eb;color:#9ca3af;font-size:10px;font-weight:700;line-height:20px;margin:0 auto 5px;}
.step.active{color:var(--navy);}.step.active .n{background:var(--gold);color:#fff;}
.step.done{color:var(--success);}.step.done .n{background:var(--success);color:#fff;}
.previews{display:none;}.previews.on{display:block;}
.previews h2{font-family:'Inter',sans-serif;font-size:22px;font-weight:800;margin-bottom:4px;letter-spacing:-.01em;}
.previews p{color:var(--slate);font-size:13px;margin-bottom:18px;}
.cards-grid{display:grid;gap:22px;margin-bottom:0;}
.card-wrap{background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--card-shadow);opacity:1;transform:none;animation:none;}
@keyframes fadeUp{to{opacity:1;transform:translateY(0);}}
.card-meta{padding:10px 16px;background:var(--navy);color:#fff;font-size:11px;display:flex;align-items:center;gap:8px;}
.card-meta .addr{color:var(--gold-lt);font-weight:600;flex:1;}
.cbadge{font-size:9px;font-weight:700;padding:2px 8px;border-radius:20px;text-transform:uppercase;}
.cbadge.pass{background:var(--success);color:#fff;}
canvas.card{display:block;width:100%;height:auto;}
.dl-bar{display:none;background:#fff;border-radius:14px;padding:24px;box-shadow:var(--card-shadow);align-items:center;gap:16px;flex-wrap:wrap;margin-top:0;margin-bottom:14px;}
.dl-bar.on{display:flex;}
.dl-info{flex:1;min-width:200px;}
.dl-info strong{font-family:'Inter',sans-serif;font-weight:800;font-size:16px;display:block;margin-bottom:4px;letter-spacing:-.01em;}
.dl-info span{font-size:12px;color:var(--slate);}
.dl-btns{display:flex;gap:10px;flex-wrap:wrap;}
.dl-btn{padding:11px 22px;background:var(--gold);color:var(--navy);border:none;border-radius:8px;font-family:'Inter',sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap;}
.dl-btn:hover{background:var(--gold-lt);}
#include-3d-toggle:checked + #toggle-3d-slider{background:#7c3aed;}
#toggle-3d-slider::before{content:'';position:absolute;height:16px;width:16px;left:2px;bottom:2px;background:#fff;border-radius:50%;transition:.2s;}
#include-3d-toggle:checked + #toggle-3d-slider::before{transform:translateX(16px);}
.dl-btn.sec{background:var(--navy);color:#fff;}
.dl-btn.sec:hover{background:#1a3a5c;}
.spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:none;}
.spinner.on{display:inline-block;}
@keyframes spin{to{transform:rotate(360deg);}}
.progress-bar-wrap{background:#e5e7eb;border-radius:4px;height:6px;margin-top:10px;overflow:hidden;display:none;}
.progress-bar-wrap.on{display:block;}
.progress-bar{height:100%;background:var(--gold);border-radius:4px;transition:width .3s;width:0%;}
input[type="range"]{-webkit-appearance:none;width:100%;height:6px;background:#e2e8f0;border-radius:3px;outline:none;border:none;padding:0;}
input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--navy);border-radius:50%;cursor:pointer;}
/* ── Text size & position controls ── */
.field-controls{display:flex;gap:6px;margin-top:4px;align-items:center;flex-wrap:wrap;}
.field-ctrl-group{display:flex;align-items:center;gap:2px;background:#f1f5f9;border-radius:6px;padding:2px 4px;font-size:10px;color:#64748b;user-select:none;}
.field-ctrl-group span.ctrl-label{font-weight:600;margin-right:2px;text-transform:uppercase;letter-spacing:.5px;}
.field-ctrl-btn{width:22px;height:22px;border:none;border-radius:4px;background:#e2e8f0;color:#334155;font-size:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;}
.field-ctrl-btn:hover{background:#cbd5e1;}
.t4-style-row{display:flex;align-items:center;gap:3px;margin-top:2px;flex-wrap:nowrap;height:24px;}
.t4s-font{width:100px;height:22px;font-size:10px;border:1px solid #d1d5db;border-radius:3px;padding:0 2px;background:#fff;}
.t4s-sz{width:44px;height:22px;font-size:10px;border:1px solid #d1d5db;border-radius:3px;padding:0 2px;text-align:center;}
.t4s-color{width:22px;height:22px;border:1px solid #d1d5db;border-radius:3px;padding:0;cursor:pointer;}
.t4s-btn{width:22px;height:22px;border:1px solid #d1d5db;border-radius:3px;background:#fff;cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center;color:#64748b;transition:all .15s;}
.t4s-btn:hover{background:#f1f5f9;}
.t4s-btn.on{background:#7c3aed;color:#fff;border-color:#7c3aed;}
.t4s-slider{width:60px;height:18px;cursor:pointer;accent-color:#7c3aed;}
.t4s-slider-val{font-size:9px;color:#64748b;min-width:26px;text-align:center;}
.field-ctrl-val{font-size:10px;font-weight:700;color:#6d28d9;min-width:24px;text-align:center;}
.field-ctrl-reset{height:22px;border:none;border-radius:4px;background:#fce7f3;color:#be185d;font-size:9px;font-weight:700;cursor:pointer;padding:0 6px;letter-spacing:.3px;text-transform:uppercase;transition:background .15s;}
.field-ctrl-reset:hover{background:#fbcfe8;}
/* ── Template-first flow ── */
.tpl-step{background:#fff;border-radius:14px;box-shadow:var(--card-shadow);margin-bottom:14px;overflow:visible;}
.tpl-step-header{background:#fff;padding:18px 24px;display:flex;align-items:center;gap:12px;border-radius:14px;}
.tpl-step-num{width:28px;height:28px;border-radius:50%;background:#6d28d9;color:#fff;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.tpl-step-title{color:#1e293b;font-family:'Provicali',serif;font-size:18px;font-weight:normal;}
.tpl-step-sub{color:rgba(255,255,255,0.75);font-size:11px;margin-top:2px;}
.tpl-step-body{padding:20px 24px;}
.tpl-step-body.collapsed{display:none;}
#tpl-collapse-body.collapsed{display:none;}
.research-body.collapsed{display:none;}
.log-body.collapsed{display:none;}
#proofs-body.collapsed{display:none;}
.tpl-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.template-card{border:2px solid #e2e8f0;border-radius:12px;padding:14px;cursor:pointer;transition:all .2s;background:#fafafa;}
.template-card:hover{border-color:#a855f7;background:#fdf4ff;}

.template-card.selected{border-color:#6d28d9;background:#f5f3ff;box-shadow:0 0 0 3px rgba(109,40,217,0.15);}
.tpl-preview-3{position:relative;height:60px;border-radius:5px;overflow:hidden;background:#e8e8e8;}
.tpl3-texture{position:absolute;inset:0;background:linear-gradient(135deg,#7c3aed 0%,#2a5298 100%);opacity:0.85;}
.tpl3-photo{position:absolute;right:0;top:0;width:52%;height:100%;background:#b0c4de;clip-path:polygon(12% 0,100% 0,100% 100%,0% 100%);}
.tpl3-footer{position:absolute;bottom:0;left:0;right:0;height:28%;background:#a855f7;}
.tpl-check{display:none;float:right;color:#6d28d9;font-size:18px;font-weight:900;}
.template-card.selected .tpl-check{display:inline;}
/* Field panels */
.tpl-fields-panel{display:none;}
.tpl-fields-panel.active{display:block;}
.tpl-fields-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#6d28d9;padding:14px 24px 0;border-top:1px solid #f0ede8;margin-top:4px;}
.tpl-fields-note{font-size:11px;color:#64748b;padding:4px 24px 0;}
.tpl-fields-inner{padding:12px 24px 20px;}



/* ── Dark Theme Overrides ── */
html[data-theme="dark"] body{background:#0f172a;color:#e2e8f0;}
html[data-theme="dark"] .controls-panel{background:#1e293b;border-right-color:#334155;color:#e2e8f0;}
html[data-theme="dark"] .preview-panel{background:#0f172a;}
html[data-theme="dark"] .accordion,html[data-theme="dark"] .research-panel{background:#1e293b;color:#e2e8f0;}
html[data-theme="dark"] .accordion-header{color:#e2e8f0;}
html[data-theme="dark"] .accordion-header:hover{background:#273449;}
html[data-theme="dark"] input[type=text],html[data-theme="dark"] input[type=number],html[data-theme="dark"] input[type=password],html[data-theme="dark"] input[type=email],html[data-theme="dark"] input[type=url],html[data-theme="dark"] textarea,html[data-theme="dark"] select{background:#0f172a;color:#e2e8f0;border-color:#334155;}
html[data-theme="dark"] .field label,html[data-theme="dark"] .sec-label,html[data-theme="dark"] label{color:#cbd5e1;}
html[data-theme="dark"] .info-box{background:#1e3a5f;color:#e2e8f0;border-color:#334155;}
html[data-theme="dark"] .tpl-fields-label{color:#c4b5fd;border-top-color:#334155;}
html[data-theme="dark"] .tpl-fields-note{color:#94a3b8;}
html[data-theme="dark"] hr.div,html[data-theme="dark"] .divider{border-color:#334155;}
html[data-theme="dark"] .mode-tabs{background:#0f172a;}
html[data-theme="dark"] .mode-tab{color:#94a3b8;}
html[data-theme="dark"] .mode-tab.active{background:#7c3aed;color:#fff;}
html[data-theme="dark"] .dl-btn{background:#7c3aed;color:#fff;}
html[data-theme="dark"] .dl-btn.sec{background:#334155;color:#fff;}
html[data-theme="dark"] .run-btn{background:#7c3aed;}
html[data-theme="dark"] .run-btn:hover:not(:disabled){background:#6d28d9;}
html[data-theme="dark"] .card,html[data-theme="dark"] .research-panel,html[data-theme="dark"] .research-header{background:#1e293b;color:#e2e8f0;}
html[data-theme="dark"] .text-style-btn,html[data-theme="dark"] .font-picker-btn{background:#0f172a;color:#e2e8f0;border-color:#334155;}
html[data-theme="dark"] .sd-body .sd-btn{background:#0f172a;color:#cbd5e1;border-color:#334155;}
html[data-theme="dark"] .sd-body .sd-btn.on{background:#7c3aed;color:#fff;border-color:#7c3aed;}
html[data-theme="dark"] .tpl-dropdown-btn{background:linear-gradient(135deg,#0f172a,#1e1b4b);color:#fff;}
html[data-theme="dark"] #theme-toggle:hover{background:rgba(255,255,255,0.1);}

/* ── Dark Theme: broader coverage ── */
html[data-theme="dark"] .accordion-body{background:#1e293b;color:#e2e8f0;}
html[data-theme="dark"] .tpl-fields-panel,html[data-theme="dark"] .tpl-fields-inner{background:#1e293b;color:#e2e8f0;}
html[data-theme="dark"] .field input,html[data-theme="dark"] .field select,html[data-theme="dark"] .field textarea{background:#0f172a;color:#e2e8f0;border-color:#334155;}
html[data-theme="dark"] .fp-dropdown,html[data-theme="dark"] .font-picker-dropdown{background:#1e293b;color:#e2e8f0;border-color:#334155;}
html[data-theme="dark"] .fp-group-label{color:#c4b5fd;border-top-color:#334155;}
html[data-theme="dark"] .fp-item{color:#e2e8f0;}
html[data-theme="dark"] .fp-item:hover{background:#273449;}
html[data-theme="dark"] #previews,html[data-theme="dark"] .preview-wrap,html[data-theme="dark"] .zoom-bar,html[data-theme="dark"] #zoom-bar{background:#1e293b;color:#e2e8f0;border-color:#334155;}
html[data-theme="dark"] .zoom-bar *,html[data-theme="dark"] #zoom-bar *{color:#e2e8f0;}
html[data-theme="dark"] .zoom-btn,html[data-theme="dark"] #zoom-bar button{background:#0f172a;color:#e2e8f0;border-color:#334155;}
html[data-theme="dark"] .dl-bar,html[data-theme="dark"] #dl-bar{background:#1e293b;}
html[data-theme="dark"] .step,html[data-theme="dark"] #steps,html[data-theme="dark"] #log{background:#1e293b;color:#e2e8f0;border-color:#334155;}
html[data-theme="dark"] #log-body{background:#0f172a;color:#cbd5e1;}
html[data-theme="dark"] .tpl-card,html[data-theme="dark"] .template-card{background:#1e293b;color:#e2e8f0;border-color:#334155;}
html[data-theme="dark"] .tpl-card.active,html[data-theme="dark"] .template-card.active{border-color:#7c3aed;background:#273449;}
html[data-theme="dark"] .fields,html[data-theme="dark"] .field{background:transparent;color:#e2e8f0;}
html[data-theme="dark"] input[type=color]{background:#0f172a;border-color:#334155;}
html[data-theme="dark"] input[type=file]{color:#e2e8f0;}
html[data-theme="dark"] .accordion-header .acc-title{color:#e2e8f0;}
html[data-theme="dark"] .accordion-header.open{background:#273449;}
html[data-theme="dark"] .sample-house-body,html[data-theme="dark"] #sample-house-body{background:#1e293b;color:#e2e8f0;}
html[data-theme="dark"] [onclick*="sample-house-body"]{background:#273449 !important;color:#cbd5e1 !important;}
html[data-theme="dark"] option{background:#1e293b;color:#e2e8f0;}
html[data-theme="dark"] #brand-preset-select{background:#4c1d95;color:#fff;}
html[data-theme="dark"] #brand-preset-select option{background:#4c1d95;color:#fff;}
html[data-theme="dark"] .card{background:#1e293b;}
html[data-theme="dark"] *[style*="background:#fff"]{background:#1e293b !important;color:#e2e8f0 !important;}
html[data-theme="dark"] *[style*="background:#ffffff"]{background:#1e293b !important;color:#e2e8f0 !important;}
html[data-theme="dark"] *[style*="background:#fafafa"]{background:#273449 !important;color:#e2e8f0 !important;}
html[data-theme="dark"] *[style*="background:#f5f3f0"]{background:#0f172a !important;color:#e2e8f0 !important;}
html[data-theme="dark"] *[style*="background:#f1f5f9"]{background:#273449 !important;color:#e2e8f0 !important;}
html[data-theme="dark"] *[style*="background:#ede9e0"]{background:#1e293b !important;color:#e2e8f0 !important;}
html[data-theme="dark"] *[style*="color:#111"]{color:#e2e8f0 !important;}
html[data-theme="dark"] *[style*="color:#0f172a"]{color:#e2e8f0 !important;}
html[data-theme="dark"] *[style*="color:#1e293b"]{color:#e2e8f0 !important;}
html[data-theme="dark"] *[style*="color:#334155"]{color:#cbd5e1 !important;}
html[data-theme="dark"] *[style*="color:#475569"]{color:#cbd5e1 !important;}
html[data-theme="dark"] *[style*="color:#64748b"]{color:#94a3b8 !important;}

/* ── Dark Theme: target-specific fixes ── */
html[data-theme="dark"] .art-style-card{background:#273449 !important;color:#e2e8f0 !important;border-color:#334155 !important;}
html[data-theme="dark"] .art-style-card.selected{background:#312e81 !important;border-color:#7c3aed !important;}
html[data-theme="dark"] .art-style-card *{color:#e2e8f0 !important;}
html[data-theme="dark"] #zoom-bar{background:#1e293b !important;border:1px solid #334155;color:#e2e8f0;}
html[data-theme="dark"] #zoom-bar *{color:#e2e8f0 !important;}
html[data-theme="dark"] #zoom-val{color:#c4b5fd !important;}
html[data-theme="dark"] #zoom-bar button{background:#0f172a !important;color:#e2e8f0 !important;border:1px solid #334155 !important;}
html[data-theme="dark"] .tpl-step-title,html[data-theme="dark"] .acc-title{color:#e2e8f0 !important;}
html[data-theme="dark"] .research-panel,html[data-theme="dark"] .research-header{background:#1e293b !important;color:#e2e8f0 !important;}
html[data-theme="dark"] .research-header *,html[data-theme="dark"] .research-panel *{color:#e2e8f0 !important;}
html[data-theme="dark"] .research-btn{color:#fff !important;}
html[data-theme="dark"] .research-panel input,html[data-theme="dark"] .research-panel select,html[data-theme="dark"] .research-panel textarea{background:#0f172a !important;color:#e2e8f0 !important;border-color:#334155 !important;}
html[data-theme="dark"] .research-panel ::placeholder{color:#64748b !important;}
html[data-theme="dark"] #brand-results,html[data-theme="dark"] .research-results{background:#273449 !important;color:#e2e8f0 !important;}
html[data-theme="dark"] .accordion{background:#1e293b !important;}
html[data-theme="dark"] .accordion-body,html[data-theme="dark"] .acc-body{background:#1e293b !important;color:#e2e8f0 !important;}
html[data-theme="dark"] .accordion *{color:#e2e8f0;}
html[data-theme="dark"] .accordion label,html[data-theme="dark"] .accordion .sec-label{color:#cbd5e1 !important;}
html[data-theme="dark"] .accordion input,html[data-theme="dark"] .accordion select,html[data-theme="dark"] .accordion textarea{background:#0f172a !important;color:#e2e8f0 !important;border-color:#334155 !important;}
html[data-theme="dark"] *[style*="background:#fffdf5"]{background:#273449 !important;color:#e2e8f0 !important;}
html[data-theme="dark"] *[style*="background: #fff"]{background:#1e293b !important;color:#e2e8f0 !important;}
html[data-theme="dark"] *[style*="background:white"]{background:#1e293b !important;color:#e2e8f0 !important;}
html[data-theme="dark"] *[style*="background-color:#fff"]{background-color:#1e293b !important;color:#e2e8f0 !important;}

/* ── Dark Theme: template step + style chips ── */
html[data-theme="dark"] .tpl-step{background:#1e293b !important;color:#e2e8f0 !important;border-color:#334155 !important;}
html[data-theme="dark"] .tpl-step-header{background:#1e293b !important;color:#e2e8f0 !important;}
html[data-theme="dark"] .tpl-step-header *{color:#e2e8f0 !important;}
html[data-theme="dark"] .tpl-step-body{background:#1e293b !important;color:#e2e8f0 !important;}
html[data-theme="dark"] .tpl-step-title{color:#e2e8f0 !important;}
html[data-theme="dark"] .tpl-step-num{color:#fff !important;}
html[data-theme="dark"] #tpl-step-chev{color:#c4b5fd !important;}
html[data-theme="dark"] .text-style-btn,html[data-theme="dark"] button.text-style-btn{background:#273449 !important;color:#e2e8f0 !important;border-color:#334155 !important;}
html[data-theme="dark"] .text-style-btn:hover{background:#334155 !important;}
html[data-theme="dark"] .style-chip,html[data-theme="dark"] .chip,html[data-theme="dark"] .sd,html[data-theme="dark"] .sd-toggle{background:#273449 !important;color:#e2e8f0 !important;border-color:#334155 !important;}
html[data-theme="dark"] .sd-head{background:#273449 !important;color:#e2e8f0 !important;}
html[data-theme="dark"] .sd-body{background:#1e293b !important;color:#e2e8f0 !important;}
html[data-theme="dark"] .font-picker-wrap,html[data-theme="dark"] .font-picker{background:#1e293b !important;}
html[data-theme="dark"] .font-picker-btn{background:#273449 !important;color:#e2e8f0 !important;border-color:#334155 !important;}

/* ── Dark Theme: purple section backgrounds ── */
html[data-theme="dark"] .accordion{background:linear-gradient(135deg,#4c1d95,#6d28d9) !important;border:1px solid #7c3aed !important;box-shadow:0 4px 16px rgba(124,58,237,0.25) !important;}
html[data-theme="dark"] .tpl-step{background:linear-gradient(135deg,#4c1d95,#6d28d9) !important;border:1px solid #7c3aed !important;box-shadow:0 4px 16px rgba(124,58,237,0.25) !important;}
html[data-theme="dark"] .accordion-header,html[data-theme="dark"] .tpl-step-header{background:transparent !important;}
html[data-theme="dark"] .accordion-header:hover,html[data-theme="dark"] .tpl-step-header:hover{background:rgba(255,255,255,0.06) !important;}
html[data-theme="dark"] .accordion-body,html[data-theme="dark"] .tpl-step-body{background:#1e1b4b !important;border-top:1px solid rgba(255,255,255,0.1) !important;}
html[data-theme="dark"] .research-panel{background:linear-gradient(135deg,#4c1d95,#6d28d9) !important;border:1px solid #7c3aed !important;box-shadow:0 4px 16px rgba(124,58,237,0.25) !important;}
html[data-theme="dark"] .research-header{background:transparent !important;}
html[data-theme="dark"] .accordion *,html[data-theme="dark"] .tpl-step *,html[data-theme="dark"] .research-panel *{color:#f1f5f9;}
html[data-theme="dark"] .accordion input,html[data-theme="dark"] .accordion select,html[data-theme="dark"] .accordion textarea,html[data-theme="dark"] .tpl-step input,html[data-theme="dark"] .tpl-step select,html[data-theme="dark"] .tpl-step textarea{background:#0f0a24 !important;color:#f1f5f9 !important;border-color:#4c1d95 !important;}
html[data-theme="dark"] .acc-chev,html[data-theme="dark"] #tpl-step-chev{color:#c4b5fd !important;}

/* ── Dark Theme: expanded body polish + overflow fix ── */
html[data-theme="dark"] .accordion-body,html[data-theme="dark"] .tpl-step-body{background:#1e293b !important;border-top:1px solid #334155 !important;border-radius:0 0 10px 10px;padding:14px 16px !important;}
html[data-theme="dark"] .tpl-fields-inner{padding:10px 2px !important;}
html[data-theme="dark"] .fields{gap:12px !important;}
html[data-theme="dark"] .field{min-width:0;}
html[data-theme="dark"] .field input,html[data-theme="dark"] .field select,html[data-theme="dark"] .field textarea{width:100% !important;box-sizing:border-box !important;max-width:100%;}
html[data-theme="dark"] .field label{word-break:normal;overflow-wrap:break-word;}

/* ── Dark Theme: style dropdown (sd) ── */
html[data-theme="dark"] .style-dropdown .sd-toggle{background:#273449 !important;color:#c4b5fd !important;border-color:#4c1d95 !important;}
html[data-theme="dark"] .style-dropdown .sd-toggle:hover{background:#334155 !important;}
html[data-theme="dark"] .style-dropdown .sd-body{background:#0f172a !important;border-color:#4c1d95 !important;color:#e2e8f0 !important;}
html[data-theme="dark"] .sd-body *{color:#e2e8f0;}
html[data-theme="dark"] .sd-body .sd-row-label{color:#c4b5fd !important;}
html[data-theme="dark"] .sd-body .sd-btn{background:#1e293b !important;color:#e2e8f0 !important;border-color:#334155 !important;}
html[data-theme="dark"] .sd-body .sd-btn:hover{background:#334155 !important;}
html[data-theme="dark"] .sd-body .sd-btn.on{background:#7c3aed !important;color:#fff !important;border-color:#7c3aed !important;}
html[data-theme="dark"] .sd-body .sd-font,html[data-theme="dark"] .sd-body select,html[data-theme="dark"] .sd-body input{background:#1e293b !important;color:#e2e8f0 !important;border-color:#334155 !important;}
html[data-theme="dark"] .sd-body .sd-color{border-color:#334155 !important;}

/* ── Dark Theme: field-ctrl buttons inside sd-body ── */
html[data-theme="dark"] .field-ctrl-btn{background:#1e293b !important;color:#e2e8f0 !important;}
html[data-theme="dark"] .field-ctrl-btn:hover{background:#334155 !important;}
html[data-theme="dark"] .field-ctrl-val{color:#c4b5fd !important;}
html[data-theme="dark"] .field-ctrl-reset{background:#7c3aed !important;color:#fff !important;}
html[data-theme="dark"] .field-ctrl-reset:hover{background:#6d28d9 !important;}
html[data-theme="dark"] .field-ctrl-group{background:#0f172a !important;color:#e2e8f0 !important;}
html[data-theme="dark"] .font-picker-btn,html[data-theme="dark"] .font-picker-btn .fp-label{background:#1e293b !important;color:#e2e8f0 !important;border-color:#334155 !important;}
html[data-theme="dark"] .font-picker-btn .fp-chev{color:#c4b5fd !important;}
html[data-theme="dark"] .fp-dropdown{background:#1e293b !important;border-color:#334155 !important;}
html[data-theme="dark"] .fp-item{color:#e2e8f0 !important;background:#1e293b !important;}
html[data-theme="dark"] .fp-item:hover{background:#334155 !important;}
html[data-theme="dark"] .fp-group-label{color:#c4b5fd !important;border-top-color:#334155 !important;}

html[data-theme="dark"] #opt-ai-stylize + span,html[data-theme="dark"] label:has(#opt-ai-stylize){color:#e2e8f0 !important;}

/* ══════════════════════════════════════════════════════════ */
/* UI POLISH — flat buttons, tighter density, unified accent  */
/* ══════════════════════════════════════════════════════════ */
:root{--ui-accent:#7c3aed;--ui-accent-hi:#a855f7;--ui-accent-lo:#4c1d95;}

/* Flat buttons (kill gradients on secondary/tertiary) */
.dl-btn{background:var(--ui-accent) !important;color:#fff !important;border:none !important;box-shadow:none !important;transition:background .15s;}
.dl-btn:hover{background:var(--ui-accent-hi) !important;}
.dl-btn.sec{background:#475569 !important;}
.dl-btn.sec:hover{background:#334155 !important;}
.research-btn{background:var(--ui-accent) !important;box-shadow:none !important;}
.research-btn:hover{background:var(--ui-accent-hi) !important;}
/* Keep Run Pipeline gradient — primary CTA */
.run-btn#run-btn{background:linear-gradient(135deg,var(--ui-accent-lo),var(--ui-accent)) !important;box-shadow:0 4px 14px rgba(124,58,237,0.3) !important;}

/* Tighter density */
.accordion-header,.tpl-step-header{padding:14px 20px !important;}
.accordion-body,.tpl-step-body,.tpl-fields-inner{padding:10px 16px !important;}
.fields{gap:10px 12px !important;}
.field{margin-bottom:6px !important;}
.field label{font-size:10px !important;letter-spacing:.3px;margin-bottom:3px !important;}
.field input,.field select,.field textarea{font-size:12.5px !important;padding:5px 8px !important;}
.sec-label{font-size:10px !important;margin-top:10px !important;margin-bottom:6px !important;}
.info-box{font-size:11px !important;padding:8px 10px !important;line-height:1.35;}
hr.div,.div{margin:8px 0 !important;}

/* Cleaner section cards (light) */
.accordion,.tpl-step,.research-panel{box-shadow:0 1px 3px rgba(15,23,42,0.06) !important;border:1px solid #e2e8f0;margin-bottom:8px !important;}

/* Tighter style chips */
.style-dropdown .sd-toggle{font-size:9px !important;padding:2px 6px !important;margin-top:2px !important;}
.sd-body{padding:6px 8px !important;}
.sd-body .sd-btn{width:20px !important;height:20px !important;font-size:9px !important;}
.field-ctrl-btn{width:18px !important;height:18px !important;font-size:11px !important;}
.field-ctrl-val{font-size:9px !important;min-width:20px !important;}
.field-ctrl-reset{height:18px !important;font-size:8px !important;padding:0 5px !important;}

/* Sticky Run Pipeline in controls panel bottom */
.controls-panel{position:relative;}
#run-btn{position:sticky;bottom:8px;z-index:20;}

/* Compact zoom chip */
#zoom-bar{margin:0 0 8px 0 !important;}
#zoom-bar button{width:22px !important;height:22px !important;font-size:11px !important;padding:0 !important;}
#zoom-bar span{font-size:10px !important;}

/* Header: clean chip size */
header{padding:10px 24px !important;}
#brand-presets-header{gap:4px !important;margin-left:10px !important;}
#brand-presets-header span{font-size:10px !important;}
#brand-presets-header button,#api-keys-btn{font-size:11px !important;padding:5px 10px !important;}
#brand-preset-select{font-size:11px !important;min-width:140px !important;padding:5px 8px !important;}

/* Carousel nav: flatter */
#carousel-nav{padding:6px 10px !important;gap:6px !important;}
#carousel-nav button{padding:4px 10px !important;font-size:11px !important;}
#carousel-nav select{font-size:11px !important;padding:4px 8px !important;}

/* Field-ctrl group: hide reset unless hovered */
.field-ctrl-reset{opacity:0.55;transition:opacity .15s;}
.field-ctrl-group:hover .field-ctrl-reset,.sd-body:hover .field-ctrl-reset{opacity:1;}

/* ══════ Wizard mode refinements ══════ */
.wpill{transition:background .15s, color .15s;}
.wpill:hover{filter:brightness(1.1);}
#wizard-pills{box-shadow:0 2px 8px rgba(0,0,0,0.1);}
.tpl-step-num{width:26px !important;height:26px !important;font-size:12px !important;}
.acc-chev,#tpl-step-chev{font-size:11px !important;}
#mode-toggle button{transition:background .15s;}
#mode-toggle button:hover{filter:brightness(1.15);}
#content-tabs{display:none;}
/* Compact Run-step layout */
[data-step="run"] .run-btn{font-size:13px !important;padding:12px 16px !important;}
/* Address input area roomier when solo step */

/* ══════════════════════════════════════════════════════════════
   VORTEX ANALYTICS STYLE — Dark indigo theme (cosmetic only)
   ══════════════════════════════════════════════════════════════ */
html[data-theme="dark"]{
  --v-bg:#0a0a0f;
  --v-surface:#111420;
  --v-surface-2:#161a29;
  --v-sidebar:#0e1019;
  --v-border:#1f2230;
  --v-border-strong:#2a2e42;
  --v-indigo:#6366f1;
  --v-indigo-hover:#4f46e5;
  --v-indigo-dim:rgba(99,102,241,0.15);
  --v-text:#ffffff;
  --v-text-soft:#cbd5e1;
  --v-text-mute:#6b7280;
  --v-success:#22c55e;
  --v-danger:#ef4444;
  --v-warn:#f59e0b;
}

html[data-theme="dark"] body{background:var(--v-bg) !important;color:var(--v-text-soft) !important;}
html[data-theme="dark"] .container{background:var(--v-bg);}

html[data-theme="dark"] .header,html[data-theme="dark"] header{background:linear-gradient(90deg,#0e1019,#111420) !important;border-bottom:1px solid var(--v-border) !important;}
html[data-theme="dark"] .htitle{color:var(--v-text) !important;}

html[data-theme="dark"] .controls-panel{background:var(--v-sidebar) !important;border-right:1px solid var(--v-border) !important;color:var(--v-text-soft) !important;}
html[data-theme="dark"] .preview-panel{background:var(--v-bg) !important;}

html[data-theme="dark"] .accordion,
html[data-theme="dark"] .tpl-step,
html[data-theme="dark"] .research-panel,
html[data-theme="dark"] .card,
html[data-theme="dark"] .sample-house-body,
html[data-theme="dark"] #sample-house-body{
  background:var(--v-surface) !important;
  border:1px solid var(--v-border) !important;
  border-radius:14px !important;
  box-shadow:0 1px 2px rgba(0,0,0,0.4) !important;
  color:var(--v-text-soft) !important;
}
html[data-theme="dark"] .accordion-body,
html[data-theme="dark"] .tpl-fields-panel,
html[data-theme="dark"] .tpl-fields-inner,
html[data-theme="dark"] .tpl-step-body,
html[data-theme="dark"] .tpl-step-header{background:var(--v-surface) !important;color:var(--v-text-soft) !important;}
html[data-theme="dark"] .accordion-header{color:var(--v-text) !important;background:var(--v-surface) !important;border-bottom:1px solid var(--v-border);}
html[data-theme="dark"] .accordion-header:hover,
html[data-theme="dark"] .accordion-header.open{background:var(--v-surface-2) !important;}
html[data-theme="dark"] .accordion-header .acc-title{color:var(--v-text) !important;font-weight:700 !important;}

html[data-theme="dark"] .tpl-step-num{background:var(--v-indigo) !important;box-shadow:0 0 0 4px var(--v-indigo-dim);}
html[data-theme="dark"] .tpl-step-title{color:var(--v-text) !important;}

html[data-theme="dark"] input[type=text],
html[data-theme="dark"] input[type=number],
html[data-theme="dark"] input[type=tel],
html[data-theme="dark"] input[type=password],
html[data-theme="dark"] input[type=email],
html[data-theme="dark"] input[type=url],
html[data-theme="dark"] textarea,
html[data-theme="dark"] select,
html[data-theme="dark"] .controls-panel select,
html[data-theme="dark"] .controls-panel input{
  background:var(--v-bg) !important;
  color:var(--v-text) !important;
  border:1px solid var(--v-border) !important;
  border-radius:8px !important;
  transition:border-color .15s, box-shadow .15s;
}
html[data-theme="dark"] input:focus,
html[data-theme="dark"] textarea:focus,
html[data-theme="dark"] select:focus{
  border-color:var(--v-indigo) !important;
  box-shadow:0 0 0 3px var(--v-indigo-dim) !important;
  outline:none !important;
}

html[data-theme="dark"] label,
html[data-theme="dark"] .field label,
html[data-theme="dark"] .sec-label{color:var(--v-text-mute) !important;font-weight:600 !important;letter-spacing:.03em;}
html[data-theme="dark"] .tpl-fields-label{color:var(--v-indigo) !important;text-transform:uppercase;font-size:10px !important;letter-spacing:.15em !important;border-top:1px solid var(--v-border) !important;}

html[data-theme="dark"] .dl-btn,
html[data-theme="dark"] .run-btn{
  background:var(--v-indigo) !important;
  color:#fff !important;
  border:none !important;
  border-radius:8px !important;
  transition:background .15s;
}
html[data-theme="dark"] .dl-btn:hover,
html[data-theme="dark"] .run-btn:hover:not(:disabled){background:var(--v-indigo-hover) !important;}
html[data-theme="dark"] .dl-btn.sec{background:var(--v-surface-2) !important;color:var(--v-text-soft) !important;border:1px solid var(--v-border) !important;}
html[data-theme="dark"] .dl-btn.sec:hover{background:var(--v-border) !important;}

html[data-theme="dark"] .mode-tabs{background:var(--v-sidebar) !important;border:1px solid var(--v-border) !important;border-radius:10px !important;}
html[data-theme="dark"] .mode-tab{color:var(--v-text-mute) !important;}
html[data-theme="dark"] .mode-tab.active{background:var(--v-indigo) !important;color:#fff !important;box-shadow:0 2px 8px rgba(99,102,241,0.3);}

html[data-theme="dark"] .tpl-dropdown-btn{background:var(--v-surface-2) !important;border:1px solid var(--v-border) !important;color:var(--v-text) !important;}
html[data-theme="dark"] .tpl-dropdown-btn:hover{border-color:var(--v-indigo) !important;}
html[data-theme="dark"] .tpl-dropdown-list{background:var(--v-surface) !important;border:1px solid var(--v-border) !important;}
html[data-theme="dark"] .tpl-dd-item{color:var(--v-text-soft) !important;border-bottom:1px solid var(--v-border) !important;}
html[data-theme="dark"] .tpl-dd-item:hover{background:var(--v-surface-2) !important;}
html[data-theme="dark"] .tpl-dd-item.active{background:var(--v-indigo-dim) !important;color:var(--v-text) !important;}
html[data-theme="dark"] .tpl-dd-item.active .dd-num,
html[data-theme="dark"] .tpl-dd-item .dd-num{background:var(--v-indigo) !important;color:#fff !important;}

html[data-theme="dark"] #panel-resizer{background:var(--v-border) !important;}
html[data-theme="dark"] #panel-resizer:hover,
html[data-theme="dark"] #panel-resizer.dragging{background:var(--v-indigo) !important;}

html[data-theme="dark"] #zoom-bar{background:var(--v-surface) !important;border:1px solid var(--v-border) !important;}
html[data-theme="dark"] #zoom-bar .zb-label{color:var(--v-text-mute) !important;}
html[data-theme="dark"] #zoom-bar .zb-btn{background:var(--v-bg) !important;border:1px solid var(--v-border) !important;color:var(--v-text-soft) !important;}
html[data-theme="dark"] #zoom-bar .zb-btn:hover{background:var(--v-indigo) !important;color:#fff !important;border-color:var(--v-indigo) !important;}
html[data-theme="dark"] #zoom-bar .zb-val{color:var(--v-indigo) !important;}
html[data-theme="dark"] #zoom-bar .zb-reset{background:var(--v-bg) !important;border:1px solid var(--v-border) !important;color:var(--v-text-soft) !important;}
html[data-theme="dark"] #zoom-bar .zb-reset:hover{background:var(--v-indigo) !important;color:#fff !important;border-color:var(--v-indigo) !important;}

html[data-theme="dark"] .fp-dropdown,
html[data-theme="dark"] .font-picker-dropdown,
html[data-theme="dark"] .style-dropdown .sd-body{background:var(--v-surface) !important;border:1px solid var(--v-border) !important;color:var(--v-text-soft) !important;}
html[data-theme="dark"] .fp-group-label{color:var(--v-indigo) !important;border-top-color:var(--v-border) !important;}
html[data-theme="dark"] .fp-item:hover{background:var(--v-surface-2) !important;}
html[data-theme="dark"] .font-picker-btn,
html[data-theme="dark"] .text-style-btn{background:var(--v-bg) !important;border:1px solid var(--v-border) !important;color:var(--v-text-soft) !important;}

html[data-theme="dark"] .template-card,
html[data-theme="dark"] .tpl-card{background:var(--v-surface-2) !important;border:1px solid var(--v-border) !important;color:var(--v-text-soft) !important;}
html[data-theme="dark"] .template-card:hover,
html[data-theme="dark"] .tpl-card:hover{border-color:var(--v-indigo) !important;background:var(--v-surface) !important;}
html[data-theme="dark"] .template-card.selected,
html[data-theme="dark"] .tpl-card.active,
html[data-theme="dark"] .template-card.active{border-color:var(--v-indigo) !important;background:var(--v-indigo-dim) !important;box-shadow:0 0 0 3px rgba(99,102,241,0.2) !important;}

html[data-theme="dark"] .info-box{background:var(--v-indigo-dim) !important;border:1px solid var(--v-indigo) !important;color:var(--v-text) !important;}

html[data-theme="dark"] .step,
html[data-theme="dark"] #steps,
html[data-theme="dark"] #log{background:var(--v-surface) !important;border:1px solid var(--v-border) !important;color:var(--v-text-soft) !important;}
html[data-theme="dark"] #log-body{background:var(--v-bg) !important;color:var(--v-text-mute) !important;border-radius:8px;}

html[data-theme="dark"] .dl-bar,
html[data-theme="dark"] #dl-bar{background:var(--v-surface) !important;border:1px solid var(--v-border) !important;border-radius:14px !important;}

html[data-theme="dark"] #previews,
html[data-theme="dark"] .preview-wrap{background:transparent !important;border:none !important;color:var(--v-text-soft) !important;}

html[data-theme="dark"] .controls-panel::-webkit-scrollbar,
html[data-theme="dark"] .preview-panel::-webkit-scrollbar{width:10px;height:10px;}
html[data-theme="dark"] .controls-panel::-webkit-scrollbar-track,
html[data-theme="dark"] .preview-panel::-webkit-scrollbar-track{background:var(--v-sidebar);}
html[data-theme="dark"] .controls-panel::-webkit-scrollbar-thumb,
html[data-theme="dark"] .preview-panel::-webkit-scrollbar-thumb{background:var(--v-border-strong);border-radius:5px;}
html[data-theme="dark"] .controls-panel::-webkit-scrollbar-thumb:hover,
html[data-theme="dark"] .preview-panel::-webkit-scrollbar-thumb:hover{background:var(--v-indigo);}

html[data-theme="dark"] input[type=color]{background:var(--v-bg) !important;border:1px solid var(--v-border) !important;}

html[data-theme="dark"] .field-ctrl-reset{background:var(--v-surface-2) !important;color:var(--v-text-mute) !important;}
html[data-theme="dark"] .field-ctrl-reset:hover{background:var(--v-indigo) !important;color:#fff !important;}
html[data-theme="dark"] .field-ctrl-val{color:var(--v-indigo) !important;}

html[data-theme="dark"] .t4s-btn{background:var(--v-bg) !important;border:1px solid var(--v-border) !important;color:var(--v-text-soft) !important;}
html[data-theme="dark"] .t4s-btn:hover{background:var(--v-surface-2) !important;}
html[data-theme="dark"] .t4s-btn.on{background:var(--v-indigo) !important;border-color:var(--v-indigo) !important;color:#fff !important;}
html[data-theme="dark"] .t4s-slider{accent-color:var(--v-indigo) !important;}

html[data-theme="dark"] #carousel-nav{background:var(--v-surface) !important;border:1px solid var(--v-border) !important;}
html[data-theme="dark"] #carousel-nav button{background:var(--v-indigo) !important;}
html[data-theme="dark"] #carousel-nav button:hover{background:var(--v-indigo-hover) !important;}
html[data-theme="dark"] #carousel-select{background:var(--v-bg) !important;border:1px solid var(--v-border) !important;color:var(--v-text) !important;}

html[data-theme="dark"] h1,
html[data-theme="dark"] h2,
html[data-theme="dark"] h3{color:var(--v-text) !important;letter-spacing:-0.01em;}

/* ══════════════════════════════════════════════════════════════
   ANIMATIONS + COMPRESSED ZOOM BAR
   ══════════════════════════════════════════════════════════════ */

/* Accordion smooth expand/collapse */
.accordion-body{display:block !important;max-height:0 !important;overflow:hidden !important;opacity:0;padding-top:0 !important;padding-bottom:0 !important;transition:max-height .35s cubic-bezier(0.4,0,0.2,1),opacity .25s ease,padding .3s ease,border-color .25s ease !important;}
.accordion-body.open{max-height:4000px !important;opacity:1;padding-top:16px !important;padding-bottom:16px !important;}
.tpl-step-body{display:block;max-height:4000px;overflow:hidden;transition:max-height .35s cubic-bezier(0.4,0,0.2,1),opacity .25s ease,padding .3s ease;}
.tpl-step-body.collapsed{max-height:0 !important;opacity:0;padding-top:0 !important;padding-bottom:0 !important;}
#tpl-collapse-body{transition:max-height .35s cubic-bezier(0.4,0,0.2,1),opacity .25s ease;overflow:hidden;}
#tpl-collapse-body.collapsed{max-height:0 !important;opacity:0;}

/* Chevron rotation */
.acc-chev,.tpl-step-chev,.dd-chev{transition:transform .25s cubic-bezier(0.4,0,0.2,1);display:inline-block;}
.accordion-header.open .acc-chev{transform:rotate(180deg);}

/* Cards lift on hover */
.accordion,.tpl-step,.card{transition:border-color .2s ease,box-shadow .25s ease,transform .2s ease;}
html[data-theme="dark"] .accordion:hover,
html[data-theme="dark"] .tpl-step:hover{border-color:var(--v-border-strong) !important;box-shadow:0 4px 16px rgba(0,0,0,0.5) !important;}

/* Buttons: subtle scale + bg transition */
.dl-btn,.run-btn,button,.t4s-btn,.field-ctrl-reset,.mode-tab,.zb-btn,.zb-reset{transition:background-color .18s ease,color .18s ease,border-color .18s ease,transform .08s ease,box-shadow .2s ease !important;}
.dl-btn:hover,.run-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(99,102,241,0.35) !important;}
.dl-btn:active,.run-btn:active,button:active{transform:translateY(0) scale(0.98);}

/* Inputs focus ripple */
input,textarea,select{transition:border-color .2s ease,box-shadow .25s ease,background-color .2s ease !important;}

/* Mode tabs slide */
.mode-tab{transition:background-color .2s ease,color .2s ease,box-shadow .25s ease !important;}

/* Dropdowns fade-in */
.tpl-dropdown-list,.fp-dropdown,.font-picker-dropdown,.style-dropdown .sd-body{transform-origin:top center;transition:opacity .2s ease,transform .2s cubic-bezier(0.4,0,0.2,1);}
.tpl-dropdown-list{display:block !important;opacity:0;transform:translateY(-8px) scaleY(0.95);pointer-events:none;}
.tpl-dropdown-list.open{opacity:1;transform:translateY(0) scaleY(1);pointer-events:auto;}

/* Dropdown items hover slide */
.tpl-dd-item,.fp-item{transition:background-color .15s ease,padding-left .15s ease,color .15s ease !important;}
.tpl-dd-item:hover,.fp-item:hover{padding-left:22px !important;}

/* Fade-in on page load for main panels */
@keyframes vFadeIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
.controls-panel > *,.preview-panel > *{animation:vFadeIn .4s cubic-bezier(0.4,0,0.2,1) both;}
.controls-panel > *:nth-child(1){animation-delay:.00s;}
.controls-panel > *:nth-child(2){animation-delay:.06s;}
.controls-panel > *:nth-child(3){animation-delay:.12s;}
.controls-panel > *:nth-child(4){animation-delay:.18s;}
.controls-panel > *:nth-child(5){animation-delay:.24s;}
.controls-panel > *:nth-child(6){animation-delay:.30s;}

/* Preview zoom bar — compressed */
#zoom-bar{padding:6px 14px !important;gap:8px !important;border-radius:10px !important;}
#zoom-bar .zb-label{font-size:10px !important;letter-spacing:.5px !important;}
#zoom-bar .zb-btn{width:24px !important;height:24px !important;font-size:14px !important;border-radius:5px !important;}
#zoom-bar .zb-val{font-size:11px !important;min-width:34px !important;}
#zoom-bar .zb-reset{padding:5px 10px !important;font-size:10px !important;min-height:24px !important;border-radius:5px !important;}

/* Resizer pulse on hover */
#panel-resizer{transition:background-color .2s ease,width .2s ease;}
#panel-resizer:hover{background:var(--v-indigo) !important;}

/* Template step-num pulse on active */
@keyframes vPulse{0%,100%{box-shadow:0 0 0 0 rgba(99,102,241,0.4);}50%{box-shadow:0 0 0 6px rgba(99,102,241,0);}}
html[data-theme="dark"] .tpl-step-num{animation:vPulse 2.4s ease-in-out infinite;}

/* Accordion header arrow smoother */
.accordion-header{transition:background-color .2s ease !important;}

/* Sample house, carousel etc */
#carousel-nav button,.tpl-card,.template-card{transition:all .2s ease !important;}
.tpl-card:hover,.template-card:hover{transform:translateY(-2px);}

/* Run button glow on ready */
.run-btn:not(:disabled){box-shadow:0 2px 8px rgba(99,102,241,0.25);}

/* Reduced-motion accessibility */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;}
}

/* ══════════════════════════════════════════════════════════════
   FIX PASS — remove animations, uniform cards, stable layout
   ══════════════════════════════════════════════════════════════ */

/* Stable scrollbar — no width shift on open/close */
.controls-panel{scrollbar-gutter:stable;}

/* Remove all accordion animations — snap open/close */
.accordion-body{display:none !important;max-height:none !important;opacity:1 !important;overflow:visible !important;transition:none !important;padding:14px 20px !important;}
.accordion-body.open{display:block !important;}
.tpl-step-body{display:block !important;max-height:none !important;opacity:1 !important;overflow:visible !important;transition:none !important;}
.tpl-step-body.collapsed{display:none !important;}
#tpl-collapse-body{display:block !important;max-height:none !important;opacity:1 !important;overflow:visible !important;transition:none !important;}
#tpl-collapse-body.collapsed{display:none !important;}
.research-body{display:block !important;transition:none !important;}
.research-body.collapsed{display:none !important;}
#log-body.collapsed,#proofs-body.collapsed{display:none !important;}

/* Strip fade-in page-load animations */
.controls-panel > *,.preview-panel > *{animation:none !important;}

/* Strip step-num pulse */
html[data-theme="dark"] .tpl-step-num{animation:none !important;}

/* Card hover lift off */
.accordion:hover,.tpl-step:hover,.tpl-card:hover,.template-card:hover,.dl-btn:hover,.run-btn:hover{transform:none !important;box-shadow:none !important;}
.accordion,.tpl-step{transition:border-color .15s ease !important;}

/* Dropdown item padding slide off */
.tpl-dd-item:hover,.fp-item:hover{padding-left:16px !important;}

/* Chevron still rotates — keep */
.acc-chev,.tpl-step-chev,.dd-chev{transition:transform .15s ease;}

/* Remove top/bottom horizontal divider lines from cards */
.accordion,.tpl-step,.research-panel{border-top:none !important;border-bottom:none !important;}
.accordion-body,.tpl-step-body{border-top:none !important;border-bottom:none !important;}
.accordion-header,.tpl-step-header,.research-header{border-top:none !important;border-bottom:none !important;}
.tpl-fields-label{border-top:none !important;padding-top:10px !important;}

/* Uniform card sizing — research-panel matches accordion */
.research-panel,.accordion,.tpl-step{
  background:#fff;
  border-radius:14px !important;
  margin-bottom:14px !important;
  box-shadow:0 2px 8px rgba(0,0,0,0.04) !important;
  border:1px solid rgba(0,0,0,0.06) !important;
}
html[data-theme="dark"] .research-panel,
html[data-theme="dark"] .accordion,
html[data-theme="dark"] .tpl-step{
  background:var(--v-surface) !important;
  border:1px solid var(--v-border) !important;
  box-shadow:0 1px 2px rgba(0,0,0,0.4) !important;
}
.research-header,.accordion-header,.tpl-step-header{
  padding:16px 20px !important;
  min-height:56px;
}
.research-body,.accordion-body,.tpl-step-body{
  padding:12px 20px 16px !important;
}

/* Zoom bar Reset — bigger right padding so text doesn't overflow */
#zoom-bar{padding:8px 16px 8px 18px !important;gap:10px !important;}
#zoom-bar .zb-reset{padding:6px 18px !important;margin-right:6px !important;}

/* Hide top-bar mode toggle remnants */
#mode-toggle{display:none !important;}

/* Preview layout modes */
.cards-grid[data-layout="vertical"]{display:grid;grid-template-columns:1fr;gap:22px;}
.cards-grid[data-layout="horizontal"]{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.cards-grid[data-layout="horizontal"] .sample-card,
.cards-grid[data-layout="horizontal"] .preview-card{width:100%;}

/* Horizontal preview layout — front left, back right */
.cards-grid[data-layout="horizontal"]{grid-template-columns:1fr;}
.cards-grid[data-layout="horizontal"] .card-wrap{display:grid;grid-template-columns:1fr 1fr;column-gap:16px;row-gap:6px;max-width:100%;}
.cards-grid[data-layout="horizontal"] .card-wrap > .card-meta{grid-column:1/-1;}
.cards-grid[data-layout="horizontal"] .card-wrap > *:nth-child(2){grid-column:1;grid-row:2;}
.cards-grid[data-layout="horizontal"] .card-wrap > *:nth-child(3){grid-column:1;grid-row:3;width:100%;height:auto;}
.cards-grid[data-layout="horizontal"] .card-wrap > *:nth-child(4){grid-column:2;grid-row:2;}
.cards-grid[data-layout="horizontal"] .card-wrap > *:nth-child(5){grid-column:2;grid-row:3;width:100%;height:auto;}
.cards-grid[data-layout="vertical"] .card-wrap > canvas.card{width:100%;height:auto;}

/* Fullscreen overlay */
#fs-overlay{position:fixed;inset:0;z-index:99998;background:rgba(10,10,15,0.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);display:none;align-items:center;justify-content:center;padding:40px;animation:fsFadeIn .25s ease;}
#fs-overlay.on{display:flex;}
@keyframes fsFadeIn{from{opacity:0;}to{opacity:1;}}
#fs-overlay .fs-inner{display:flex;gap:24px;align-items:center;justify-content:center;max-width:100%;max-height:100%;}
#fs-overlay .fs-card{background:#fff;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,0.6);overflow:hidden;cursor:zoom-in;position:relative;}
#fs-overlay .fs-card img{display:block;max-width:100%;max-height:100%;width:auto;height:auto;transition:transform .2s ease;transform-origin:center;}
#fs-overlay .fs-card.zoomed{cursor:zoom-out;overflow:auto;}
#fs-overlay .fs-card.zoomed img{transform:scale(2);}
#fs-overlay .fs-close{position:absolute;top:20px;right:20px;background:rgba(255,255,255,0.95);border:none;border-radius:50%;width:44px;height:44px;font-size:22px;cursor:pointer;z-index:2;box-shadow:0 4px 16px rgba(0,0,0,0.4);display:flex;align-items:center;justify-content:center;font-weight:800;color:#0a0a0f;}
#fs-overlay .fs-close:hover{background:#fff;transform:scale(1.05);}

/* v2t1 dark mode tweaks */
html[data-theme="dark"] .tpl-step-num,
html[data-theme="dark"] .accordion-header{box-shadow:none !important;}
html[data-theme="dark"] .mode-tab.active,
html[data-theme="dark"] .tpl-dd-item.active{box-shadow:none !important;}
html[data-theme="dark"] .preview-panel{background:var(--v-bg) !important;}
html[data-theme="dark"] .previews,
html[data-theme="dark"] #previews,
html[data-theme="dark"] .cards-grid,
html[data-theme="dark"] .card-wrap{background:transparent !important;}
html[data-theme="dark"] .tpl-step-num{animation:none !important;box-shadow:none !important;}

/* ══════════════════════════════════════════════════════════════
   MOBILE POLISH — ≤ 768px
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 768px){
  /* Stack panels */
  .container{flex-direction:column !important;height:auto !important;min-height:calc(100vh - 68px);}
  .controls-panel{flex:none !important;width:100% !important;max-width:100% !important;height:auto !important;max-height:none !important;border-right:none !important;border-bottom:1px solid var(--v-border);padding:14px 12px !important;scrollbar-gutter:auto;}
  .preview-panel{flex:none !important;min-height:360px;padding:12px !important;}
  #panel-resizer{display:none !important;}

  /* Header compact */
  header{padding:8px 10px !important;flex-wrap:wrap;gap:6px;}
  .hlogo{width:40px !important;height:40px !important;}
  .htitle{font-size:15px !important;}
  #dashboard-link,#theme-toggle,#settings-gear-btn{height:32px !important;width:32px !important;padding:0 6px !important;}
  #dashboard-link{font-size:10px !important;padding:0 8px !important;}
  #dashboard-link svg{width:12px;height:12px;}

  /* Touch targets ≥44px */
  button,.dl-btn,.run-btn,.mode-tab,.tpl-dd-item,.accordion-header,.tpl-step-header,.acc-header{min-height:44px;}
  input[type="range"]{height:28px;}
  input[type="range"]::-webkit-slider-thumb{width:22px;height:22px;}
  input[type="color"]{width:36px !important;height:36px !important;}
  .t4s-btn,.zb-btn,.field-ctrl-btn{min-width:32px;min-height:32px;}

  /* Typography */
  .acc-title,.tpl-step-title{font-size:15px !important;}
  .tpl-fields-label{font-size:11px !important;}
  label,.sec-label{font-size:12px !important;}
  input[type="text"],input[type="number"],input[type="email"],input[type="url"],input[type="tel"],textarea,select{font-size:15px !important;padding:10px 12px !important;}

  /* Accordion padding */
  .accordion-header,.tpl-step-header{padding:14px 16px !important;}
  .accordion-body,.tpl-step-body,.tpl-fields-inner{padding:12px 14px !important;}

  /* Kill hover-only lift/glow on touch */
  .accordion:hover,.tpl-step:hover,.dl-btn:hover,.run-btn:hover,.tpl-card:hover,.template-card:hover{transform:none !important;box-shadow:none !important;}

  /* Disable heavy animations + blur for GPU cost */
  .accordion,.tpl-step,.card{transition:none !important;}
  #fs-overlay{backdrop-filter:blur(6px) !important;-webkit-backdrop-filter:blur(6px) !important;}
  .tpl-step-num{animation:none !important;box-shadow:none !important;}

  /* Mode tabs + dropdowns */
  .mode-tabs{flex-wrap:wrap;}
  .mode-tab{flex:1 1 45%;min-width:120px;font-size:12px !important;}
  .tpl-dropdown-btn{font-size:14px !important;padding:14px 16px !important;}
  .tpl-dd-item{font-size:14px !important;padding:14px 16px !important;}

  /* Zoom bar */
  #zoom-bar{flex-wrap:wrap;padding:8px 14px !important;}
  #zoom-bar .zb-label{font-size:10px !important;}
  #zoom-bar .zb-btn{width:32px !important;height:32px !important;}

  /* Preview bar buttons */
  #photo-toggle-btn,#preview-layout-btn,#fullscreen-btn{padding:8px 10px !important;font-size:11px !important;}

  /* Wizard pills wrap */
  #wizard-pills{flex-wrap:wrap;}
  .wpill{flex:1 1 45%;font-size:11px !important;padding:8px 10px !important;}

  /* Fields stack 1 column */
  .fields[style*="grid-template-columns:1fr 1fr"],
  .fields[style*="grid-template-columns:1fr 1fr 1fr"],
  .fields[style*="grid-template-columns:1fr 1fr 1fr 1fr"],
  .fields[style*="grid-template-columns:1fr 2fr"]{grid-template-columns:1fr !important;}

  /* Style dropdowns */
  .style-dropdown .sd-body{padding:10px 12px;}
  .sd-row{flex-wrap:wrap;gap:8px;margin-bottom:8px;}
  .sd-row-label{min-width:64px;font-size:10px;}
  .sd-row input[type="range"]{flex:1 1 100%;}

  /* DL bar full width */
  .dl-bar,#dl-bar{flex-direction:column !important;gap:8px !important;}
  .dl-btns{flex-direction:column !important;}
  .dl-btns button{width:100% !important;}

  /* Gear menu narrower */
  #settings-gear-menu{min-width:auto !important;width:calc(100vw - 20px) !important;left:10px !important;right:10px !important;max-height:75vh;}

  /* Popups — avoid iOS viewport jump */
  #more-dl-menu,#cp-pop,#brand-save-modal{max-width:calc(100vw - 20px) !important;}

  /* Fullscreen overlay */
  #fs-overlay{padding:10px !important;}
  #fs-overlay .fs-inner{flex-direction:column !important;gap:12px !important;}
  #fs-overlay .fs-close{top:8px !important;right:8px !important;width:38px !important;height:38px !important;}

  /* Login */
  #login-overlay > div{width:calc(100vw - 40px) !important;padding:28px 22px !important;}

  /* Scrollbars native-thin */
  .controls-panel,.preview-panel{scrollbar-width:thin;}
  .controls-panel::-webkit-scrollbar,
  .preview-panel::-webkit-scrollbar{width:6px;height:6px;}

  /* Prevent horizontal overflow */
  body,html{overflow-x:hidden;}
  .fields,.accordion-body,.tpl-step-body{max-width:100%;box-sizing:border-box;overflow-x:hidden;}

  /* Kill text shadow anim on kid title preview (mobile perf) */
  @keyframes vPulse{0%,100%{box-shadow:none;}}

  /* Cards grid horizontal → stack on mobile */
  .cards-grid[data-layout="horizontal"]{grid-template-columns:1fr !important;}
  .cards-grid[data-layout="horizontal"] .card-wrap{grid-template-columns:1fr !important;}
  .cards-grid[data-layout="horizontal"] .card-wrap > *:nth-child(n){grid-column:1 !important;grid-row:auto !important;}
}

/* Very small phones */
@media (max-width: 420px){
  header{padding:6px 8px !important;}
  .htitle{font-size:13px !important;}
  .hbadge{display:none !important;}
  .tpl-dropdown-btn{font-size:13px !important;}
  .accordion-header,.tpl-step-header{padding:12px 14px !important;}
  .acc-title,.tpl-step-title{font-size:14px !important;}
}

/* Disable transform animations for reduced motion OR touch-only */
@media (hover:none){
  *,*::before,*::after{transition-duration:0.1s !important;}
  .tpl-dd-item:hover,.fp-item:hover{padding-left:16px !important;}
}
