:root{--paper:#FAFAF7;--paper-2:#F2F1EB;--ink:#0A0A0A;--ink-2:#141414;--char:#1C1C1C;--smoke:#595959;--line:#E5E3DB;--line-2:#D9D6CC;--accent:#FF4500;--page-max:1400px;--grain-blend:multiply;--grain-opacity:.06;--ink-fixed:#0A0A0A;--paper-fixed:#FAFAF7;--char-on-dark:#FAFAF7;--smoke-on-dark:rgba(250,250,247,.6);--line-on-dark:rgba(250,250,247,.15)}
[data-theme="dark"]{--paper:#0E0E0E;--paper-2:#171717;--ink:#FAFAF7;--ink-2:#F2F1EB;--char:#EAE9E3;--smoke:#9A9A95;--line:#262626;--line-2:#333333;--grain-blend:screen;--grain-opacity:.04}

/* ============ HEADER / NAV ============ */
[data-theme="dark"] .hdr.scrolled{background:rgba(14,14,14,.85);border-bottom-color:#262626}
[data-theme="dark"] .menu-btn{border-color:#333;color:var(--char)}
[data-theme="dark"] .nav a{color:var(--smoke)}
[data-theme="dark"] .nav a:hover,[data-theme="dark"] .nav a.active{color:var(--char)}
[data-theme="dark"] .tel-link{color:var(--char)}
[data-theme="dark"] .logo-mark{background:var(--char);color:var(--paper)}
[data-theme="dark"] .logo-name{color:var(--char)}
[data-theme="dark"] .logo-sub{color:var(--smoke)}

/* ============ BODY TEXT ============ */
[data-theme="dark"] body{color:var(--char)}
[data-theme="dark"] .smoke{color:var(--smoke)}
[data-theme="dark"] .lede{color:var(--smoke)}

/* ============ HEADINGS — anywhere on a page background ============ */
[data-theme="dark"] .hero-title,
[data-theme="dark"] .h2,
[data-theme="dark"] .h3,
[data-theme="dark"] .page-hero-title,
[data-theme="dark"] .proc-title,
[data-theme="dark"] .faq-q-text,
[data-theme="dark"] .rev-body,
[data-theme="dark"] .rev-name,
[data-theme="dark"] .method-title,
[data-theme="dark"] .ind-name,
[data-theme="dark"] .num-n,
[data-theme="dark"] .blog-card-title,
[data-theme="dark"] .ct-form-title,
[data-theme="dark"] .bulk-title,
[data-theme="dark"] .hero-stat-n,
[data-theme="dark"] .ftr-h{color:var(--char)}

/* ============ HERO LEDES & PARAGRAPHS ============ */
[data-theme="dark"] .hero-lede,
[data-theme="dark"] .page-hero-lede,
[data-theme="dark"] .page-hero-bullets li,
[data-theme="dark"] .proc-desc,
[data-theme="dark"] .method-desc,
[data-theme="dark"] .ind-desc,
[data-theme="dark"] .blog-card-desc,
[data-theme="dark"] .bulk-desc,
[data-theme="dark"] .about-story-text p{color:var(--char)}
[data-theme="dark"] .about-story p{color:var(--char)}
[data-theme="dark"] .hero-stat-l,
[data-theme="dark"] .num-l,
[data-theme="dark"] .blog-card-meta,
[data-theme="dark"] .ind-examples,
[data-theme="dark"] .blog-card-num,
[data-theme="dark"] .proc-num,
[data-theme="dark"] .method-num,
[data-theme="dark"] .svc-num,
[data-theme="dark"] .faq-q-num,
[data-theme="dark"] .ind-num{color:var(--smoke)}

/* ============ PILLS & LABELS ============ */
[data-theme="dark"] .pill{background:#1a1a1a;border-color:#333;color:var(--char)}
[data-theme="dark"] .label-row .num{color:var(--smoke)}
[data-theme="dark"] .label-row .line{background:var(--line-2)}
[data-theme="dark"] .label-row .tag{color:var(--char)}

/* ============ BUTTONS ============ */
[data-theme="dark"] .btn-primary{background:var(--char);color:var(--paper)}
[data-theme="dark"] .btn-primary:hover{background:var(--accent);color:#fff}
[data-theme="dark"] .btn-outline{color:var(--char);border-color:var(--char)}
[data-theme="dark"] .btn-outline:hover{background:var(--char);color:var(--paper)}
[data-theme="dark"] .btn-invert{background:var(--char);color:var(--paper)}
[data-theme="dark"] .btn-invert:hover{background:var(--accent);color:#fff}

/* ============ SERVICE CARDS ============ */
[data-theme="dark"] .svc-grid{background:#262626;border-color:#262626}
[data-theme="dark"] .svc-card{background:#171717;color:var(--char)}
[data-theme="dark"] .svc-card:hover{background:#1f1f1f}
[data-theme="dark"] .svc-body h3{color:var(--char)}
[data-theme="dark"] .svc-body p{color:var(--smoke)}
[data-theme="dark"] .svc-icon{color:var(--char)}
[data-theme="dark"] .svc-tag{color:var(--char)}
[data-theme="dark"] .svc-arrow{border-color:var(--char);color:var(--char)}
/* Featured DTF card flips to orange */
[data-theme="dark"] .svc-card.featured{background:var(--accent);color:#0A0A0A}
[data-theme="dark"] .svc-card.featured:hover{background:#FF6A1F}
[data-theme="dark"] .svc-card.featured .svc-num{color:rgba(0,0,0,.6)}
[data-theme="dark"] .svc-card.featured .svc-icon{color:#0A0A0A}
[data-theme="dark"] .svc-card.featured .svc-body h3{color:#0A0A0A}
[data-theme="dark"] .svc-card.featured .svc-body p{color:rgba(0,0,0,.78)}
[data-theme="dark"] .svc-card.featured .svc-tag{color:#0A0A0A}
[data-theme="dark"] .svc-card.featured .svc-arrow{border-color:rgba(0,0,0,.4);color:#0A0A0A}

/* ============ TICKER — ALWAYS DARK ============ */
.ticker{background:var(--ink-fixed) !important;color:var(--paper-fixed);border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1);overflow:hidden;padding:16px 0}
.ticker-item{color:var(--paper-fixed) !important}

/* ============ TRUST BAND ============ */
[data-theme="dark"] .trust{background:#171717;border-color:#262626}
[data-theme="dark"] .trust-intro{color:var(--smoke)}
[data-theme="dark"] .trust-logo{color:var(--char)}

/* ============ SEC-INK — ALWAYS DARK editorial section ============ */
.sec-ink{background:var(--ink-fixed) !important;color:var(--paper-fixed) !important;overflow:hidden}
.sec-ink .h2{color:var(--paper-fixed) !important}
.sec-ink .lede{color:var(--smoke-on-dark) !important}
.sec-ink .label-row .tag{color:var(--paper-fixed) !important}
.sec-ink .label-row .num{color:var(--smoke-on-dark) !important}
.sec-ink .label-row .line{background:var(--line-on-dark) !important}

/* ============ WHY-US CARDS — ALWAYS DARK ============ */
.why-card{background:var(--ink-fixed) !important;color:var(--paper-fixed) !important}
.why-card:hover{background:#1C1C1C !important}
.why-grid{background:rgba(250,250,247,.1) !important;border:1px solid rgba(250,250,247,.1) !important}
.why-icon{color:var(--accent) !important}
.why-num{color:rgba(250,250,247,.4) !important}
.why-title{color:var(--paper-fixed) !important}
.why-desc{color:rgba(250,250,247,.65) !important}

/* ============ GALLERY — image cards stay as-is, but paper-bg ones need adjusting ============ */
[data-theme="dark"] .gal-bg-paper-2{background:#171717}
[data-theme="dark"] .gal-bg-paper{background:#1f1f1f}
[data-theme="dark"] .gal-bg-paper .gal-tag,
[data-theme="dark"] .gal-bg-paper-2 .gal-tag{color:var(--char);border-color:var(--char);background:rgba(14,14,14,.6)}
[data-theme="dark"] .gal-bg-paper .gal-meta,
[data-theme="dark"] .gal-bg-paper-2 .gal-meta{color:var(--smoke)}
[data-theme="dark"] .gal-bg-paper .gal-title,
[data-theme="dark"] .gal-bg-paper-2 .gal-title{color:var(--char)}
[data-theme="dark"] .gal-bg-paper .gal-sub,
[data-theme="dark"] .gal-bg-paper-2 .gal-sub{color:var(--smoke)}

/* ============ PROCESS ============ */
[data-theme="dark"] .proc-list{border-top-color:var(--line-2)}
[data-theme="dark"] .proc-step{border-bottom-color:var(--line-2)}
[data-theme="dark"] .proc-step:hover{background:#171717}
[data-theme="dark"] .proc-arrow{border-color:var(--char);color:var(--char)}
[data-theme="dark"] .proc-step:hover .proc-arrow{background:var(--char);color:var(--paper)}

/* ============ REVIEWS ============ */
[data-theme="dark"] .rev-card{background:#171717;border-color:#262626}
[data-theme="dark"] .rev-card:hover{border-color:var(--char)}
[data-theme="dark"] .rev-co{color:var(--smoke)}
[data-theme="dark"] .rev-foot{border-top-color:#262626}

/* ============ FAQ ============ */
[data-theme="dark"] .faq-list{border-top-color:var(--line-2)}
[data-theme="dark"] .faq-item{border-bottom-color:var(--line-2)}
[data-theme="dark"] .faq-lede{color:var(--smoke)}
[data-theme="dark"] .faq-tel{color:var(--char)}
[data-theme="dark"] .faq-a p{color:var(--char)}

/* ============ CTA — ALWAYS DARK ============ */
.cta{background:var(--ink-fixed) !important;color:var(--paper-fixed) !important}
.cta-title{color:var(--paper-fixed) !important}
.cta-lede{color:var(--smoke-on-dark) !important}

/* ============ PAGE-HERO PRICE BLOCK — ALWAYS DARK ============ */
.page-hero-price{background:var(--ink-fixed) !important;color:var(--paper-fixed) !important}
.page-hero-price-lbl{color:rgba(250,250,247,.5) !important}
.page-hero-price-sub{color:rgba(250,250,247,.7) !important}
.page-hero-price-note{color:rgba(250,250,247,.5) !important;border-top-color:rgba(250,250,247,.15)}

/* ============ DTF CALC PANEL — ALWAYS DARK ============ */
.dtf-calc-panel{background:var(--ink-fixed) !important;color:var(--paper-fixed) !important}

/* ============ CONTACT STUDIO CARD — ALWAYS DARK ============ */
.ct-studio{background:var(--ink-fixed) !important;color:var(--paper-fixed) !important}
.ct-studio-title{color:rgba(250,250,247,.5) !important}
.ct-row a{color:rgba(250,250,247,.9) !important}
.ct-row-sub{color:rgba(250,250,247,.6) !important}

/* ============ CONTACT FORM (light surface) ============ */
[data-theme="dark"] .ct-form-card{background:#171717;border-color:#262626}
[data-theme="dark"] .ct-form-sub{color:var(--smoke)}
[data-theme="dark"] .form-label{color:var(--smoke)}
[data-theme="dark"] .form-input,
[data-theme="dark"] .form-select,
[data-theme="dark"] .form-textarea{color:var(--char);border-bottom-color:var(--line-2)}
[data-theme="dark"] .form-input:focus,
[data-theme="dark"] .form-select:focus,
[data-theme="dark"] .form-textarea:focus{border-bottom-color:var(--char)}
[data-theme="dark"] .form-input::placeholder,
[data-theme="dark"] .form-textarea::placeholder{color:var(--smoke)}
[data-theme="dark"] .form-select option{background:#171717;color:var(--char)}
[data-theme="dark"] .ct-form-foot p{color:var(--smoke)}
[data-theme="dark"] .ct-form-note{color:var(--smoke)}
[data-theme="dark"] .ct-form-head{border-bottom-color:#262626}

/* ============ SUCCESS STATE — ALWAYS DARK ============ */
.ct-success{background:var(--ink-fixed) !important;color:var(--paper-fixed) !important}
.ct-success h3{color:var(--paper-fixed) !important}
.ct-success p{color:rgba(250,250,247,.7) !important}

/* ============ TABLES (T-shirt / hoodie / DTF pricing) ============ */
[data-theme="dark"] .garment-table-wrap{background:#171717;border-color:#262626}
[data-theme="dark"] .garment-table tr:hover td{background:#1f1f1f}
[data-theme="dark"] .garment-table td.name{color:var(--char)}
[data-theme="dark"] .garment-table td{border-bottom-color:#262626;color:var(--char)}
[data-theme="dark"] .garment-table td.weight{color:var(--smoke)}
[data-theme="dark"] .garment-table th{border-bottom-color:#262626;color:var(--smoke)}

/* ============ METHODS / INDUSTRIES / NUMS / BLOG GRIDS ============ */
[data-theme="dark"] .methods-grid,
[data-theme="dark"] .ind-grid,
[data-theme="dark"] .nums-grid,
[data-theme="dark"] .blog-grid{background:#262626;border-color:#262626}
[data-theme="dark"] .method-card,
[data-theme="dark"] .ind-card,
[data-theme="dark"] .num-card,
[data-theme="dark"] .blog-card{background:#171717}
[data-theme="dark"] .method-card:hover,
[data-theme="dark"] .ind-card:hover,
[data-theme="dark"] .blog-card:hover{background:#1f1f1f}
[data-theme="dark"] .blog-card-arrow{border-color:var(--char);color:var(--char)}
[data-theme="dark"] .blog-card:hover .blog-card-arrow{background:var(--char);color:var(--paper)}
[data-theme="dark"] .method-tag{color:var(--accent)}
[data-theme="dark"] .ind-examples{border-top-color:#262626}

/* ============ BULK LIST ============ */
[data-theme="dark"] .bulk-list{border-top-color:var(--line-2)}
[data-theme="dark"] .bulk-row{border-bottom-color:var(--line-2)}
[data-theme="dark"] .bulk-row:hover{background:#171717}
[data-theme="dark"] .bulk-num{color:var(--smoke)}

/* ============ PRINCIPLES (already dark) ============ */
.principles-grid{background:rgba(250,250,247,.1) !important;border:1px solid rgba(250,250,247,.1) !important}
.principle-card{background:var(--ink-fixed) !important;color:var(--paper-fixed) !important}
.principle-card:hover{background:#1C1C1C !important}
.principle-num{color:var(--accent) !important}
.principle-t{color:var(--paper-fixed) !important}
.principle-d{color:rgba(250,250,247,.65) !important}

/* ============ ABOUT NUMBERS GRID ============ */
[data-theme="dark"] .nums-grid{background:#262626;border-color:#262626}
[data-theme="dark"] .num-card{background:#171717}

/* ============ BLOG FEATURED — ALWAYS DARK ============ */
.blog-featured{background:var(--ink-fixed) !important;color:var(--paper-fixed) !important}
.blog-featured-title{color:var(--paper-fixed) !important}
.blog-featured-desc{color:rgba(250,250,247,.7) !important}

/* ============ FOOTER — ALWAYS DARK ============ */
.ftr{background:var(--ink-fixed) !important;color:var(--paper-fixed) !important;border-top:1px solid rgba(250,250,247,.1)}
.ftr-grid{border-bottom-color:rgba(250,250,247,.1)}
.ftr-brand-mark{background:var(--paper-fixed);color:var(--ink-fixed)}
.ftr-brand-name{color:var(--paper-fixed) !important}
.ftr-blurb{color:rgba(250,250,247,.6) !important}
.ftr-h{color:rgba(250,250,247,.5) !important}
.ftr-list a{color:rgba(250,250,247,.8) !important}
.ftr-studio-row{color:rgba(250,250,247,.8) !important}
.ftr-studio-row a{color:rgba(250,250,247,.8) !important}
.ftr-bottom{padding-top:32px;border-top:none;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px}
.ftr-bottom p{color:rgba(250,250,247,.4) !important;margin:0;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.ftr-social a{color:var(--paper-fixed) !important;border-color:rgba(250,250,247,.2)}

/* ============ DRAWER (always dark — already correct) ============ */
.drawer{background:var(--ink-fixed) !important;color:var(--paper-fixed) !important}
.drawer-name{color:var(--paper-fixed) !important}
.drawer-link{color:var(--paper-fixed) !important}
.drawer-tel{color:rgba(250,250,247,.7) !important}
.drawer-close{color:var(--paper-fixed) !important;border-color:rgba(250,250,247,.15)}
.drawer-head{border-bottom-color:rgba(250,250,247,.1)}

/* ============ HERO PANEL (image background — always dark) ============ */
.hero-panel{background:var(--ink-fixed) !important;color:var(--paper-fixed) !important}

/* ============ GRAIN ============ */
[data-theme="dark"] .grain{mix-blend-mode:screen;opacity:.04}
.grain{mix-blend-mode:var(--grain-blend);opacity:var(--grain-opacity)}

/* ============ THEME TOGGLE BUTTON ============ */
.theme-toggle{display:none;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:1px solid var(--line-2);background:transparent;color:var(--char);transition:border-color .2s,background-color .2s}
@media(min-width:768px){.theme-toggle{display:flex}}
.theme-toggle-mobile{display:flex;margin-right:8px}
@media(min-width:768px){.theme-toggle-mobile{display:none}}
.theme-toggle:hover{border-color:var(--char);background:var(--paper-2)}
.theme-toggle .icon-sun{display:none}
.theme-toggle .icon-moon{display:block}
[data-theme="dark"] .theme-toggle{color:var(--char);border-color:var(--line-2)}
[data-theme="dark"] .theme-toggle:hover{background:var(--paper-2)}
[data-theme="dark"] .theme-toggle .icon-sun{display:block}
[data-theme="dark"] .theme-toggle .icon-moon{display:none}
.drawer-theme{margin-top:32px;padding-top:24px;border-top:1px solid rgba(250,250,247,.1);display:flex;align-items:center;justify-content:space-between;color:rgba(250,250,247,.7);font-size:14px}
.drawer-theme button{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;border:1px solid rgba(250,250,247,.2);color:#fff;font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-family:'JetBrains Mono',monospace;background:transparent}

/* ============ DTF TABS (always-dark surface) ============ */
.dtf-tabs{display:inline-flex;background:rgba(250,250,247,.06);border:1px solid rgba(250,250,247,.1);border-radius:999px;padding:3px;margin-bottom:24px}
.dtf-tab{padding:8px 18px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(250,250,247,.5);border-radius:999px;transition:background .2s,color .2s;cursor:pointer;background:transparent;border:none}
.dtf-tab.active{background:var(--accent);color:#fff}
.dtf-tab:not(.active):hover{color:rgba(250,250,247,.9)}

/* ============ HERO METHODS (always-dark surface) ============ */
.hero-methods{display:flex;flex-direction:column;gap:14px;margin-top:24px}
.hero-method{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 20px;background:rgba(250,250,247,.04);border:1px solid rgba(250,250,247,.08);border-radius:2px;transition:background .3s,border-color .3s}
.hero-method:hover{background:rgba(250,250,247,.07);border-color:var(--accent)}
.hero-method-l{display:flex;flex-direction:column;gap:2px;min-width:0}
.hero-method-name{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:18px;color:var(--paper-fixed) !important;letter-spacing:-.02em}
.hero-method-desc{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(250,250,247,.8);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hero-method-r{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:22px;color:var(--accent);letter-spacing:-.02em;flex-shrink:0}
.hero-method-r small{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;color:rgba(250,250,247,.5);font-weight:400}
/* Image panels */
.img-panel{position:relative;aspect-ratio:4/5;border-radius:2px;overflow:hidden;background:var(--ink-fixed)}
.img-panel img{width:100%;height:100%;object-fit:cover;display:block}
.img-panel-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.85) 0%,rgba(10,10,10,.4) 40%,rgba(10,10,10,0) 70%);pointer-events:none}
.img-panel-body{position:absolute;inset:0;padding:28px;display:flex;flex-direction:column;justify-content:space-between;color:var(--paper-fixed);z-index:2}
.img-panel-sticker{position:absolute;left:-8px;top:32px;background:var(--accent);color:var(--ink-fixed);padding:8px 20px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;transform:rotate(-3deg);box-shadow:0 20px 40px rgba(0,0,0,.4);z-index:3}
.img-panel-tag{display:inline-flex;align-items:center;gap:10px;padding:6px 14px;border-radius:999px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.2);color:var(--paper-fixed);backdrop-filter:blur(8px);align-self:flex-start}
.img-panel-tag .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 1.6s ease-in-out infinite}
.img-panel-cap{font-family:'Bricolage Grotesque',serif;font-weight:600;letter-spacing:-.02em;line-height:1.05;font-size:clamp(22px,3vw,30px)}
.img-panel-meta{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:8px}
/* Image strip — for gallery / feature rows */
.img-strip{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line-2);border:1px solid var(--line-2)}
@media(min-width:768px){.img-strip{grid-template-columns:repeat(3,1fr)}}
[data-theme="dark"] .img-strip{background:#262626;border-color:#262626}
.img-tile{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--ink-fixed)}
.img-tile img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.img-tile:hover img{transform:scale(1.04)}
.img-tile-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.9) 0%,rgba(10,10,10,.3) 50%,rgba(10,10,10,0) 75%);pointer-events:none}
.img-tile-body{position:absolute;left:0;right:0;bottom:0;padding:24px;color:#fff;z-index:2}
.img-tile-tag{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.img-tile-title{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:22px;letter-spacing:-.02em;line-height:1.1}
.img-tile-sub{font-size:13px;color:rgba(255,255,255,.7);margin-top:4px}
/* Two-column image+text feature */
.img-feature{display:grid;grid-template-columns:1fr;gap:32px;align-items:center}
@media(min-width:1024px){.img-feature{grid-template-columns:1fr 1fr;gap:64px}}
.img-feature.reverse{direction:rtl}
.img-feature.reverse>*{direction:ltr}
.img-feature-img{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:2px;background:var(--ink-fixed)}
.img-feature-img img{width:100%;height:100%;object-fit:cover}
@media(min-width:1024px){.img-feature-img{aspect-ratio:1/1}}
/* Quote form — file upload */
.dropzone{border:1.5px dashed var(--line-2);border-radius:2px;padding:32px;text-align:center;transition:border-color .2s,background-color .2s;cursor:pointer;position:relative}
.dropzone:hover,.dropzone.dragover{border-color:var(--accent);background:rgba(255,69,0,.04)}
[data-theme="dark"] .dropzone{border-color:#333}
[data-theme="dark"] .dropzone:hover,[data-theme="dark"] .dropzone.dragover{background:rgba(255,69,0,.08)}
.dropzone-icon{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:50%;background:var(--paper-2);color:var(--ink);margin-bottom:16px}
[data-theme="dark"] .dropzone-icon{background:#171717;color:var(--char)}
.dropzone-title{font-family:'Bricolage Grotesque',serif;font-size:18px;font-weight:600;color:var(--ink);margin-bottom:6px;letter-spacing:-.02em}
[data-theme="dark"] .dropzone-title{color:var(--char)}
.dropzone-sub{font-size:13px;color:var(--smoke);margin-bottom:14px}
.dropzone-rules{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--smoke)}
.dropzone input[type="file"]{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}
.file-list{margin-top:16px;display:flex;flex-direction:column;gap:8px}
.file-pill{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:var(--paper-2);border:1px solid var(--line-2);border-radius:2px;font-size:13px}
[data-theme="dark"] .file-pill{background:#171717;border-color:#262626}
.file-pill-l{display:flex;align-items:center;gap:10px;min-width:0;flex:1}
.file-pill-icon{flex-shrink:0;color:var(--accent)}
.file-pill-meta{min-width:0;overflow:hidden}
.file-pill-name{color:var(--ink);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
[data-theme="dark"] .file-pill-name{color:var(--char)}
.file-pill-size{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;color:var(--smoke);text-transform:uppercase}
.file-pill-remove{flex-shrink:0;width:28px;height:28px;border-radius:50%;display:grid;place-items:center;color:var(--smoke);transition:color .2s,background .2s}
.file-pill-remove:hover{color:var(--accent);background:rgba(255,69,0,.1)}
.file-pill.error{border-color:rgba(220,38,38,.4);background:rgba(220,38,38,.05)}
.file-pill.error .file-pill-icon{color:#dc2626}
.form-error{display:none;margin-top:12px;padding:12px 14px;border:1px solid rgba(220,38,38,.4);background:rgba(220,38,38,.05);color:#991b1b;font-size:13px;border-radius:2px}
[data-theme="dark"] .form-error{color:#fca5a5;background:rgba(220,38,38,.1)}
.form-error.show{display:block}
.progress{display:none;margin-top:16px}
.progress.show{display:block}
.progress-bar{height:3px;background:var(--line-2);border-radius:2px;overflow:hidden}
[data-theme="dark"] .progress-bar{background:#262626}
.progress-fill{height:100%;background:var(--accent);width:0%;transition:width .3s}
.progress-label{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--smoke);margin-top:8px;display:flex;justify-content:space-between}
.honeypot{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
/* DTF artwork submission — preview, dimensions, low-res warning */
.dtf-preview-wrap{margin:16px 0 0;display:flex;align-items:center;gap:16px}
.dtf-preview-wrap[hidden],.dtf-warn[hidden]{display:none}
.dtf-preview{width:88px;height:88px;object-fit:contain;background:var(--paper-2);border:1px solid var(--line-2);border-radius:2px;flex-shrink:0;background-image:linear-gradient(45deg,rgba(0,0,0,.04) 25%,transparent 25%,transparent 75%,rgba(0,0,0,.04) 75%),linear-gradient(45deg,rgba(0,0,0,.04) 25%,transparent 25%,transparent 75%,rgba(0,0,0,.04) 75%);background-size:14px 14px;background-position:0 0,7px 7px}
[data-theme="dark"] .dtf-preview{background-color:#171717;border-color:#262626}
.dtf-dims{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--smoke);line-height:1.7}
.dtf-dims strong{color:var(--ink);font-weight:600}
[data-theme="dark"] .dtf-dims strong{color:var(--char)}
.dtf-warn{display:flex;align-items:flex-start;gap:10px;margin-top:14px;padding:12px 14px;border:1px solid rgba(217,119,6,.4);background:rgba(217,119,6,.08);color:#92400e;font-size:13px;line-height:1.5;border-radius:2px}
.dtf-warn svg{flex-shrink:0;margin-top:1px;color:#d97706}
[data-theme="dark"] .dtf-warn{color:#fcd34d;background:rgba(217,119,6,.12);border-color:rgba(217,119,6,.45)}
/* Legal pages — privacy & terms */
.legal-wrap{max-width:760px;margin:0 auto}
.legal-meta{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--smoke);margin-top:24px;padding-top:16px;border-top:1px solid var(--line)}
.legal-content{font-size:16px;line-height:1.7;color:var(--char)}
.legal-content h2{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:24px;letter-spacing:-.02em;color:var(--ink);margin:48px 0 12px;line-height:1.2}
[data-theme="dark"] .legal-content h2{color:var(--char)}
.legal-content h2:first-child{margin-top:0}
.legal-content h3{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:17px;letter-spacing:-.01em;color:var(--ink);margin:24px 0 8px}
[data-theme="dark"] .legal-content h3{color:var(--char)}
.legal-content p{margin:0 0 16px}
.legal-content ul{margin:0 0 16px;padding-left:20px}
.legal-content li{margin-bottom:8px}
.legal-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.legal-content a:hover{text-decoration:none}
.legal-content strong{color:var(--ink);font-weight:600}
[data-theme="dark"] .legal-content strong{color:var(--char)}
.legal-callout{padding:20px 24px;background:var(--paper-2);border-left:3px solid var(--accent);margin:24px 0;font-size:14px;line-height:1.6}
[data-theme="dark"] .legal-callout{background:#171717}
/* Footer privacy/terms link styling */
.ftr-bottom-links{display:flex;gap:24px;flex-wrap:wrap}
.ftr-bottom-links a{color:rgba(250,250,247,.6) !important;text-decoration:none;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.ftr-bottom-links a:hover{color:var(--paper-fixed) !important}
/* Blog article — extends legal-content */
.article-wrap{max-width:760px;margin:0 auto}
.article-meta{display:flex;flex-wrap:wrap;align-items:center;gap:16px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--smoke);margin:24px 0 0}
.article-meta-tag{color:var(--accent)}
.article-meta-sep{opacity:.4}
.article-back{display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--smoke);text-decoration:none;margin-bottom:32px;transition:color .2s}
.article-back:hover{color:var(--accent)}
.article-content{font-size:17px;line-height:1.75;color:var(--char)}
.article-content > p:first-of-type{font-size:20px;line-height:1.5;color:var(--ink);margin-bottom:32px;font-weight:400}
[data-theme="dark"] .article-content > p:first-of-type{color:var(--char)}
.article-content h2{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:28px;letter-spacing:-.02em;color:var(--ink);margin:48px 0 16px;line-height:1.2}
[data-theme="dark"] .article-content h2{color:var(--char)}
.article-content h3{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:20px;letter-spacing:-.01em;color:var(--ink);margin:32px 0 10px}
[data-theme="dark"] .article-content h3{color:var(--char)}
.article-content p{margin:0 0 18px}
.article-content ul,.article-content ol{margin:0 0 18px;padding-left:24px}
.article-content li{margin-bottom:8px}
.article-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.article-content a:hover{text-decoration:none}
.article-content strong{color:var(--ink);font-weight:600}
[data-theme="dark"] .article-content strong{color:var(--char)}
.article-content blockquote{padding:20px 24px;background:var(--paper-2);border-left:3px solid var(--accent);margin:24px 0;font-style:italic;font-size:16px;line-height:1.6}
[data-theme="dark"] .article-content blockquote{background:#171717}
.article-callout{padding:20px 24px;background:var(--paper-2);border-left:3px solid var(--accent);margin:28px 0;font-size:15px;line-height:1.6;border-radius:2px}
[data-theme="dark"] .article-callout{background:#171717}
.article-callout strong{display:block;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent) !important;margin-bottom:8px;font-weight:600}
.article-content table{width:100%;border-collapse:collapse;margin:24px 0;font-size:14px}
.article-content th,.article-content td{padding:12px;text-align:left;border-bottom:1px solid var(--line)}
.article-content th{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--smoke);font-weight:600}
.article-content tr:hover td{background:var(--paper-2)}
[data-theme="dark"] .article-content tr:hover td{background:#171717}
.article-cta{margin:48px 0 24px;padding:32px;background:var(--paper-2);border-radius:2px;text-align:center}
[data-theme="dark"] .article-cta{background:#171717}
.article-cta h3{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:24px;letter-spacing:-.02em;color:var(--ink);margin-bottom:8px}
[data-theme="dark"] .article-cta h3{color:var(--char)}
.article-cta p{font-size:14px;color:var(--smoke);margin-bottom:20px}
.article-related{margin-top:64px;padding-top:48px;border-top:1px solid var(--line)}
.article-related-h{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--smoke);margin-bottom:24px}
.article-related-grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line)}
@media(min-width:640px){.article-related-grid{grid-template-columns:repeat(2,1fr)}}
[data-theme="dark"] .article-related-grid{background:#262626}
.article-related-card{display:block;padding:24px;background:var(--paper);text-decoration:none;color:inherit;transition:background .2s}
.article-related-card:hover{background:var(--paper-2)}
[data-theme="dark"] .article-related-card{background:var(--paper)}
[data-theme="dark"] .article-related-card:hover{background:#171717}
.article-related-card-tag{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;display:block}
.article-related-card-title{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:18px;letter-spacing:-.01em;color:var(--ink);line-height:1.3}
[data-theme="dark"] .article-related-card-title{color:var(--char)}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter Tight',system-ui,-apple-system,sans-serif;background:var(--paper);color:var(--ink);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font:inherit;color:inherit}
ul{list-style:none}
.display{font-family:'Bricolage Grotesque',serif;letter-spacing:-.035em;line-height:.92;font-weight:600}
.serif{font-family:'Instrument Serif',serif;font-style:italic;letter-spacing:-.02em;font-weight:400}
.mono{font-family:'JetBrains Mono',monospace}
.orange{color:var(--accent)}
.smoke{color:var(--smoke)}
.wrap{max-width:var(--page-max);margin:0 auto;padding:0 20px}
@media(min-width:768px){.wrap{padding:0 40px}}
section{position:relative}
.grain{position:absolute;inset:0;pointer-events:none;opacity:.06;mix-blend-mode:multiply;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.8'/></svg>")}
.dotgrid{background-image:radial-gradient(circle at 1px 1px,rgba(10,10,10,.08) 1px,transparent 0);background-size:22px 22px}
.label-row{display:flex;align-items:center;gap:16px;margin-bottom:40px}
.label-row .num{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;color:var(--smoke)}
.label-row .line{flex:1;height:1px;background:var(--line-2)}
.label-row .tag{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink)}
.label-row.dark .num{color:rgba(255,255,255,.6)}
.label-row.dark .line{background:rgba(255,255,255,.15)}
.label-row.dark .tag{color:#fff}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;padding:16px 28px;border-radius:999px;font-weight:500;font-size:15px;transition:background-color .3s,color .3s,transform .2s;cursor:pointer;border:1px solid transparent}
.btn .arrow{transition:transform .3s cubic-bezier(.2,.7,.2,1)}
.btn:hover .arrow{transform:translate(3px,-3px)}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--accent)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--paper)}
.btn-invert{background:var(--paper);color:var(--ink)}
.btn-invert:hover{background:var(--accent);color:var(--paper)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:var(--ink)}
.btn-outline-dark{background:transparent;color:#fff;border-color:rgba(255,255,255,.25)}
.btn-outline-dark:hover{background:rgba(255,255,255,.1)}
.pill{display:inline-flex;align-items:center;gap:10px;padding:7px 14px;border-radius:999px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;background:var(--paper-2);border:1px solid var(--line-2);color:var(--ink);font-weight:500}
.pill.dark{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.15);color:#fff}
.pill .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 1.6s ease-in-out infinite}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes spin-slow{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes fadeup{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.marquee-row{display:flex;white-space:nowrap;animation:marquee 38s linear infinite;width:max-content}
.spin-slow{animation:spin-slow 22s linear infinite}
.fadeup{animation:fadeup .9s cubic-bezier(.2,.7,.2,1) both}
.hdr{position:fixed;inset:0 0 auto 0;z-index:40;transition:background-color .5s,border-color .5s,backdrop-filter .5s;background:transparent;border-bottom:1px solid transparent}
.hdr.scrolled{background:rgba(250,250,247,.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom-color:var(--line)}
.hdr-inner{max-width:var(--page-max);margin:0 auto;padding:0 20px;height:72px;display:flex;align-items:center;justify-content:space-between}
@media(min-width:768px){.hdr-inner{padding:0 40px}}
.logo{display:flex;align-items:center;gap:10px}
.logo-mark{position:relative;width:32px;height:32px;display:grid;place-items:center;background:var(--ink);color:var(--paper);border-radius:4px;font-family:'Bricolage Grotesque',serif;font-weight:700;font-size:17px;line-height:1}
.logo-mark::after{content:'';position:absolute;right:-2px;bottom:-2px;width:8px;height:8px;background:var(--accent);border-radius:50%}
.logo-name{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:18px;letter-spacing:-.03em;line-height:1.2}
.logo-name .dot{color:var(--accent)}
.logo-sub{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.22em;color:var(--smoke);text-transform:uppercase;line-height:1.2}
.nav{display:none;align-items:center;gap:28px}
@media(min-width:1024px){.nav{display:flex}}
.nav a{font-size:13.5px;color:var(--smoke);transition:color .2s;background-image:linear-gradient(currentColor,currentColor);background-size:0 1px;background-repeat:no-repeat;background-position:0 100%;transition:background-size .4s,color .2s}
.nav a:hover,.nav a.active{color:var(--ink);background-size:100% 1px}
.nav a.active{font-weight:500}
.nav-group{position:relative;display:flex;align-items:center}
.nav-group-trigger{display:inline-flex;align-items:center;gap:3px}
.nav-caret{opacity:.55;transition:transform .2s;margin-top:1px}
.nav-group:hover .nav-caret,.nav-group:focus-within .nav-caret{transform:rotate(180deg)}
.nav-menu{position:absolute;top:100%;left:-10px;min-width:236px;padding:18px 8px 8px;display:flex;flex-direction:column;gap:1px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .18s,transform .18s,visibility .18s;z-index:120}
.nav-menu::before{content:"";position:absolute;top:10px;left:10px;right:0;bottom:0;background:var(--paper);border:1px solid var(--line-2);border-radius:8px;box-shadow:0 16px 40px rgba(0,0,0,.14);z-index:-1}
.nav-group:hover .nav-menu,.nav-group:focus-within .nav-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-menu a{padding:9px 14px;border-radius:5px;font-size:13.5px;background-image:none;white-space:nowrap}
.nav-menu a:hover,.nav-menu a.active{background:var(--paper-2);color:var(--ink);background-size:0 1px}
.hdr-actions{display:none;align-items:center;gap:12px}
@media(min-width:768px){.hdr-actions{display:flex}}
.tel-link{display:none;align-items:center;gap:8px;font-size:13px;color:var(--ink)}
@media(min-width:1280px){.tel-link{display:flex}}
.tel-link:hover{color:var(--accent)}
.btn-sm{padding:10px 20px!important;font-size:13px!important}
.menu-btn{display:grid;place-items:center;width:40px;height:40px;border-radius:50%;border:1px solid var(--line-2);background:transparent}
@media(min-width:1024px){.menu-btn{display:none}}
.drawer{position:fixed;inset:0;z-index:50;background:var(--ink);color:var(--paper);display:none;flex-direction:column;animation:fadeup .4s ease-out both}
.drawer.open{display:flex}
.drawer-head{display:flex;align-items:center;justify-content:space-between;height:72px;padding:0 20px;border-bottom:1px solid rgba(255,255,255,.1)}
.drawer-name{font-family:'Bricolage Grotesque',serif;font-size:20px;font-weight:600}
.drawer-name .dot{color:var(--accent)}
.drawer-close{display:grid;place-items:center;width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.15);color:#fff}
.drawer-body{padding:24px;flex:1;overflow-y:auto}
.drawer-link{display:block;font-family:'Bricolage Grotesque',serif;font-size:34px;font-weight:600;letter-spacing:-.03em;padding:10px 0;transition:color .2s}
.drawer-link:hover,.drawer-link.active{color:var(--accent)}
.drawer-cta{margin-top:32px}
.drawer-tel{margin-top:24px;display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.7);font-size:14px}
.hero{padding:128px 0 64px;background:var(--paper);overflow:hidden;position:relative}
@media(min-width:768px){.hero{padding-bottom:96px}}
.hero-grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:end;position:relative}
@media(min-width:1024px){.hero-grid{grid-template-columns:7fr 5fr}}
.hero-title{font-family:'Bricolage Grotesque',serif;font-weight:600;color:var(--ink);letter-spacing:-.035em;line-height:.92;font-size:clamp(48px,10vw,136px);margin-top:32px}
.hero-lede{margin-top:40px;font-size:18px;max-width:560px;color:var(--char);line-height:1.55}
.hero-ctas{margin-top:40px;display:flex;flex-wrap:wrap;gap:16px}
.hero-stats{margin-top:64px;padding-top:32px;display:grid;grid-template-columns:repeat(2,1fr);gap:24px;border-top:1px solid var(--line-2)}
@media(min-width:768px){.hero-stats{grid-template-columns:repeat(4,1fr);gap:32px}}
.hero-stat-n{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:30px;line-height:1;letter-spacing:-.03em;color:var(--ink)}
@media(min-width:768px){.hero-stat-n{font-size:36px}}
.hero-stat-l{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--smoke);margin-top:6px}
.hero-panel{position:relative;aspect-ratio:4/5;background:var(--ink);color:var(--paper);border-radius:2px;overflow:hidden}
.hero-panel-body{position:absolute;inset:0;padding:28px;display:flex;flex-direction:column;justify-content:space-between}
.hero-panel-live{display:flex;align-items:center;gap:12px;opacity:.7}
.hero-panel-live .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 1.6s ease-in-out infinite}
.hero-panel-live span:last-child{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase}
.hero-badge{position:absolute;top:24px;right:24px;width:96px;height:96px;animation:spin-slow 22s linear infinite}
.hero-badge-inner{position:absolute;inset:0;display:grid;place-items:center;font-family:'Bricolage Grotesque',serif;font-weight:700;font-size:28px;color:var(--accent)}
.hero-sticker{position:absolute;left:-8px;top:160px;background:var(--accent);color:var(--ink);padding:8px 20px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;transform:rotate(-3deg);box-shadow:0 20px 40px rgba(0,0,0,.3)}
.run-title{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.85);margin-bottom:16px;text-shadow:0 1px 2px rgba(0,0,0,.4)}
.run-list{display:flex;flex-direction:column;gap:12px}
.run-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1);font-size:14px}
.run-item-l{display:flex;align-items:center;gap:12px;min-width:0}
.run-method{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;color:var(--accent);width:64px;flex-shrink:0;text-transform:uppercase}
.run-job{color:rgba(255,255,255,.9);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.run-status{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.2em;color:rgba(255,255,255,.5);flex-shrink:0}
.run-cta{margin-top:24px;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:2px;transition:background-color .3s,color .3s}
.run-cta:hover{background:var(--accent);color:var(--ink)}
.run-cta span:first-child{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase}
.ticker{background:var(--ink);color:var(--paper);border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1);overflow:hidden;padding:16px 0}
.ticker-item{display:inline-flex;align-items:center;font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.28em;text-transform:uppercase;padding:0 32px;color:var(--paper)}
.ticker-item .dot{display:inline-block;margin-left:32px;width:6px;height:6px;border-radius:50%;background:var(--accent)}
.sec{padding:80px 0}
@media(min-width:768px){.sec{padding:112px 0}}
.sec-paper{background:var(--paper)}
.sec-paper-2{background:var(--paper-2)}
.sec-ink{background:var(--ink);color:var(--paper);overflow:hidden}
.sec-head{display:flex;flex-direction:column;gap:24px;margin-bottom:48px}
@media(min-width:768px){.sec-head{flex-direction:row;align-items:end;justify-content:space-between}}
.h2{font-family:'Bricolage Grotesque',serif;font-weight:600;letter-spacing:-.035em;line-height:.92;color:var(--ink);font-size:clamp(40px,7vw,84px)}
.sec-ink .h2{color:var(--paper)}
.h3{font-family:'Bricolage Grotesque',serif;font-weight:600;letter-spacing:-.03em;line-height:1;font-size:clamp(24px,3vw,32px)}
.lede{font-size:15px;color:var(--smoke);max-width:400px;line-height:1.55}
.svc-grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line-2);border:1px solid var(--line-2)}
@media(min-width:768px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.svc-grid{grid-template-columns:repeat(3,1fr)}}
.svc-card{position:relative;background:var(--paper);padding:32px;display:flex;flex-direction:column;justify-content:space-between;min-height:320px;transition:background-color .4s,transform .5s cubic-bezier(.2,.7,.2,1)}
@media(min-width:768px){.svc-card{padding:40px}}
.svc-card:hover{background:var(--paper-2);transform:translateY(-4px)}
.svc-card.featured{background:var(--ink);color:var(--paper)}
.svc-card.featured:hover{background:var(--ink)}
.svc-top{display:flex;align-items:flex-start;justify-content:space-between}
.svc-num{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;color:var(--smoke)}
.svc-card.featured .svc-num{color:rgba(255,255,255,.6)}
.svc-icon{color:var(--ink)}
.svc-card.featured .svc-icon{color:var(--accent)}
.svc-body h3{margin-bottom:12px;font-size:clamp(22px,2.5vw,32px);font-family:'Bricolage Grotesque',serif;font-weight:600;letter-spacing:-.03em;line-height:1}
.svc-body p{font-size:14px;line-height:1.55;color:var(--smoke);margin-bottom:24px;margin-top:16px}
.svc-card.featured .svc-body p{color:rgba(255,255,255,.7)}
.svc-foot{display:flex;align-items:center;justify-content:space-between}
.svc-tag{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink)}
.svc-card.featured .svc-tag{color:var(--accent)}
.svc-arrow{display:grid;place-items:center;width:40px;height:40px;border-radius:50%;border:1px solid var(--ink);transition:transform .3s}
.svc-card.featured .svc-arrow{border-color:rgba(255,255,255,.3);color:#fff}
.svc-card:hover .svc-arrow{transform:rotate(45deg)}
.why-grid{display:grid;grid-template-columns:1fr;gap:1px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.1)}
@media(min-width:768px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.why-grid{grid-template-columns:repeat(3,1fr)}}
.why-card{background:var(--ink);padding:32px;transition:background-color .5s}
@media(min-width:768px){.why-card{padding:40px}}
.why-card:hover{background:var(--ink-2)}
.why-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px}
.why-icon{color:var(--accent)}
.why-num{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;color:rgba(255,255,255,.4)}
.why-title{font-family:'Bricolage Grotesque',serif;font-weight:600;letter-spacing:-.03em;line-height:1.1;font-size:clamp(22px,2.5vw,28px);color:#fff;margin-bottom:12px}
.why-desc{font-size:14px;color:rgba(255,255,255,.6);line-height:1.55}
.trust{padding:64px 0;background:var(--paper-2);border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);overflow:hidden}
.trust-intro{text-align:center;font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--smoke);margin-bottom:40px}
.trust-logo{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:30px;color:var(--ink);padding:0 40px;opacity:.7;white-space:nowrap}
@media(min-width:768px){.trust-logo{font-size:48px}}
.trust-logo .dot{display:inline-block;margin-left:32px;width:6px;height:6px;border-radius:50%;background:var(--accent);vertical-align:middle}
.gallery-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:768px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}
.gal-card{position:relative;aspect-ratio:4/5;overflow:hidden;transition:transform .5s cubic-bezier(.2,.7,.2,1);cursor:pointer}
.gal-card:hover{transform:translateY(-4px)}
.gal-bg-ink{background:var(--ink)}
.gal-bg-paper-2{background:var(--paper-2)}
.gal-bg-accent{background:var(--accent)}
.gal-bg-char{background:var(--char)}
.gal-bg-paper{background:var(--paper)}
.gal-card>svg{position:absolute;inset:0;width:100%;height:100%}
.gal-body{position:absolute;inset:0;padding:24px;display:flex;flex-direction:column;justify-content:space-between}
.gal-top{display:flex;align-items:flex-start;justify-content:space-between}
.gal-tag{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;padding:5px 10px;border-radius:999px;border:1px solid;backdrop-filter:blur(4px)}
.gal-bg-ink .gal-tag,.gal-bg-char .gal-tag{border-color:rgba(255,255,255,.3);color:#fff;background:rgba(0,0,0,.2)}
.gal-bg-paper .gal-tag,.gal-bg-paper-2 .gal-tag{border-color:var(--ink);color:var(--ink);background:rgba(250,250,247,.8)}
.gal-bg-accent .gal-tag{border-color:var(--ink);color:var(--ink)}
.gal-meta{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;color:rgba(255,255,255,.6)}
.gal-bg-paper .gal-meta,.gal-bg-paper-2 .gal-meta{color:var(--smoke)}
.gal-bg-accent .gal-meta{color:var(--ink);opacity:.7}
.gal-title{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:22px;letter-spacing:-.03em;margin-bottom:4px;color:#fff}
.gal-bg-paper .gal-title,.gal-bg-paper-2 .gal-title,.gal-bg-accent .gal-title{color:var(--ink)}
.gal-sub{font-size:13px;color:rgba(255,255,255,.7)}
.gal-bg-paper .gal-sub,.gal-bg-paper-2 .gal-sub{color:var(--smoke)}
.gal-bg-accent .gal-sub{color:var(--ink);opacity:.7}
.proc-list{border-top:1px solid var(--line-2)}
.proc-step{display:grid;grid-template-columns:1fr;gap:16px;padding:32px 4px;border-bottom:1px solid var(--line-2);transition:background-color .3s}
.proc-step:hover{background:var(--paper)}
@media(min-width:768px){.proc-step{grid-template-columns:2fr 4fr 5fr 1fr;gap:24px}}
.proc-num{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.2em;color:var(--smoke)}
.proc-title{font-family:'Bricolage Grotesque',serif;font-weight:600;letter-spacing:-.03em;line-height:1;font-size:clamp(24px,3vw,36px);color:var(--ink)}
.proc-desc{font-size:15px;color:var(--char);line-height:1.6}
.proc-arrow{justify-self:end;align-self:start;display:grid;place-items:center;width:40px;height:40px;border-radius:50%;border:1px solid var(--ink);transition:background .3s,color .3s}
.proc-step:hover .proc-arrow{background:var(--ink);color:var(--paper)}
.rev-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:768px){.rev-grid{grid-template-columns:repeat(2,1fr)}}
.rev-card{position:relative;padding:32px;border:1px solid var(--line-2);transition:border-color .3s;background:var(--paper)}
@media(min-width:768px){.rev-card{padding:40px}}
.rev-card:hover{border-color:var(--ink)}
.rev-quote-icon{color:var(--accent);margin-bottom:24px}
.rev-body{font-family:'Bricolage Grotesque',serif;font-weight:500;font-size:clamp(18px,2vw,24px);line-height:1.25;color:var(--ink);margin-bottom:32px;letter-spacing:-.03em}
.rev-foot{padding-top:24px;border-top:1px solid var(--line-2);display:flex;align-items:center;justify-content:space-between}
.rev-name{font-size:15px;font-weight:500;color:var(--ink)}
.rev-co{font-size:13px;color:var(--smoke)}
.rev-stars{display:flex;gap:2px}
.rev-stars svg{fill:var(--accent);color:var(--accent)}
.rev-subline{color:var(--smoke);font-weight:400;font-style:italic;font-family:'Instrument Serif',serif;font-size:clamp(32px,5vw,56px);letter-spacing:-.02em}
.faq-grid{display:grid;grid-template-columns:1fr;gap:40px}
@media(min-width:1024px){.faq-grid{grid-template-columns:4fr 8fr}}
.faq-h2{margin-bottom:24px}
.faq-lede{color:var(--smoke);line-height:1.55;margin-bottom:32px}
.faq-tel{display:inline-flex;align-items:center;gap:8px;color:var(--ink);background-image:linear-gradient(currentColor,currentColor);background-size:0 1px;background-repeat:no-repeat;background-position:0 100%;transition:background-size .4s}
.faq-tel:hover{background-size:100% 1px}
.faq-list{border-top:1px solid var(--line-2)}
.faq-item{border-bottom:1px solid var(--line-2)}
.faq-q{width:100%;display:flex;gap:24px;padding:24px 0;text-align:left;align-items:flex-start;justify-content:space-between}
.faq-q-inner{display:flex;gap:24px;flex:1;align-items:flex-start}
.faq-q-num{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.18em;color:var(--smoke);margin-top:6px;flex-shrink:0}
.faq-q-text{font-family:'Bricolage Grotesque',serif;font-weight:500;font-size:clamp(18px,2vw,24px);letter-spacing:-.02em;color:var(--ink);line-height:1.2;transition:color .2s}
.faq-q:hover .faq-q-text{color:var(--accent)}
.faq-toggle{margin-top:6px;flex-shrink:0}
.faq-a{display:none;padding:0 48px 24px 48px;animation:fadeup .4s ease-out}
.faq-item.open .faq-a{display:block}
.faq-a p{font-size:15px;line-height:1.6;color:var(--char);max-width:640px}
.faq-item .icon-minus{display:none}
.faq-item.open .icon-plus{display:none}
.faq-item.open .icon-minus{display:block}
.cta{position:relative;padding:96px 0;background:var(--ink);color:var(--paper);overflow:hidden}
@media(min-width:768px){.cta{padding:128px 0}}
.cta-blur{position:absolute;left:-80px;bottom:-80px;width:500px;height:500px;border-radius:50%;background:var(--accent);filter:blur(140px);opacity:.3}
.cta-wrap{position:relative;text-align:center}
.cta-title{font-family:'Bricolage Grotesque',serif;font-weight:600;letter-spacing:-.035em;line-height:.92;font-size:clamp(56px,10vw,140px);margin:32px auto 40px;max-width:18ch}
.cta-lede{max-width:540px;margin:0 auto 40px;color:rgba(255,255,255,.7);font-size:18px;line-height:1.55}
.cta-ctas{display:flex;flex-wrap:wrap;justify-content:center;gap:16px}
.ct-grid{display:grid;grid-template-columns:1fr;gap:32px}
@media(min-width:1024px){.ct-grid{grid-template-columns:5fr 7fr;gap:40px}}
.ct-studio{position:relative;background:var(--ink);color:var(--paper);padding:32px;border-radius:2px;overflow:hidden}
.ct-studio-title{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:16px}
.ct-studio-name{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:30px;letter-spacing:-.03em;margin-bottom:24px}
.ct-row{display:flex;gap:16px;margin-bottom:16px;font-size:14px}
.ct-row svg{color:var(--accent);flex-shrink:0;margin-top:2px}
.ct-row a{color:rgba(255,255,255,.9)}
.ct-row a:hover{color:var(--accent)}
.ct-row-sub{color:rgba(255,255,255,.6)}
.ct-wa{margin-top:32px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px;background:#25D366;color:#fff;border-radius:2px;transition:background-color .2s}
.ct-wa:hover{background:#1ebe5a}
.ct-wa-l{display:flex;align-items:center;gap:12px}
.ct-wa-l span{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.ct-form-card{background:var(--paper);border:1px solid var(--line-2);padding:32px;border-radius:2px}
@media(min-width:768px){.ct-form-card{padding:48px}}
.ct-form-head{display:flex;align-items:center;justify-content:space-between;padding-bottom:24px;margin-bottom:32px;border-bottom:1px solid var(--line-2)}
.ct-form-sub{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--smoke)}
.ct-form-title{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:26px;letter-spacing:-.03em;margin-top:4px}
.form-grid{display:grid;grid-template-columns:1fr;gap:8px 32px}
@media(min-width:768px){.form-grid{grid-template-columns:1fr 1fr}}
.form-field{padding:8px 0}
.form-field.full{grid-column:1/-1}
.form-label{display:block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--smoke);font-weight:500;margin-bottom:4px}
.form-input,.form-select,.form-textarea{width:100%;background:transparent;border:none;border-bottom:1px solid var(--line-2);padding:14px 2px;font-size:15px;color:var(--ink);outline:none;transition:border-color .2s;font-family:inherit}
.form-input::placeholder,.form-textarea::placeholder{color:var(--smoke)}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-bottom-color:var(--ink)}
.form-textarea{resize:none}
.ct-form-foot{margin-top:40px;display:flex;flex-direction:column;gap:24px;align-items:flex-start}
@media(min-width:768px){.ct-form-foot{flex-direction:row;align-items:center;justify-content:space-between}}
.ct-form-note{font-size:12px;color:var(--smoke);max-width:360px}
.ct-success{background:var(--ink);color:var(--paper);padding:40px;border-radius:2px;animation:fadeup .4s ease-out}
@media(min-width:768px){.ct-success{padding:64px}}
.ct-success-check{display:grid;place-items:center;width:56px;height:56px;border-radius:50%;background:var(--accent);margin-bottom:24px}
.ct-success h3{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:36px;letter-spacing:-.03em;margin-bottom:16px}
.ct-success p{color:rgba(255,255,255,.7);max-width:420px;line-height:1.6}
.dtf-paid-banner{background:rgba(255,69,0,.08);border:1px solid rgba(255,69,0,.35);border-radius:2px;padding:16px 20px;margin-bottom:24px;font-size:14px;line-height:1.5;color:var(--ink)}
.dtf-paid-banner strong{color:var(--accent)}
.qw-est{border:1px solid var(--line-2);border-radius:6px;padding:14px 16px;background:var(--paper-2)}
.qw-est-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;flex-wrap:wrap}
.qw-est-lbl{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--smoke)}
.qw-est-val{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:19px;letter-spacing:-.01em;color:var(--ink)}
.qw-est-note{font-size:12px;color:var(--smoke);margin-top:6px;line-height:1.5}
.qw-est-note a{color:var(--accent);text-decoration:underline}
.rev-badge{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--smoke);text-decoration:none;border:1px solid var(--line-2);border-radius:999px;padding:8px 16px;white-space:nowrap}
.rev-badge:hover{border-color:var(--accent)}
.rev-badge strong{color:var(--ink);font-family:'Bricolage Grotesque',serif;font-size:15px}
.rev-stars{color:var(--accent);letter-spacing:3px;line-height:1;font-size:15px}
.rev-cards{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:640px){.rev-cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.rev-cards{grid-template-columns:repeat(3,1fr)}}
.rev-card2{background:var(--paper-2);border:1px solid var(--line-2);border-radius:8px;padding:26px 24px;display:flex;flex-direction:column;gap:14px;margin:0}
.rev-quote{font-size:14.5px;line-height:1.6;color:var(--char);margin:0}
.rev-meta{display:flex;flex-direction:column;gap:2px;margin-top:auto}
.rev-name{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:15px;color:var(--ink)}
.rev-src{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--smoke)}
.rev-cta{background:var(--ink);color:var(--paper);border-radius:8px;padding:28px 26px;display:flex;align-items:center;justify-content:center;text-align:center}
.rev-cta-inner{display:flex;flex-direction:column;gap:14px;align-items:center}
.rev-cta-title{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:20px;line-height:1.2;color:var(--paper);margin:0}
.rev-cta-btns{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.ftr{background:var(--ink);color:var(--paper);padding:80px 0 32px;border-top:1px solid rgba(255,255,255,.1)}
.ftr-grid{display:grid;grid-template-columns:1fr;gap:40px;padding-bottom:64px;border-bottom:1px solid rgba(255,255,255,.1)}
@media(min-width:768px){.ftr-grid{grid-template-columns:3fr 2fr 2fr 2fr 3fr}}
@media(min-width:768px) and (max-width:1023px){.ftr-grid{grid-template-columns:repeat(3,1fr)}}
.ftr-brand{display:flex;align-items:center;gap:10px;margin-bottom:24px}
.ftr-brand-mark{width:36px;height:36px;display:grid;place-items:center;background:var(--paper);color:var(--ink);border-radius:4px;font-family:'Bricolage Grotesque',serif;font-weight:700;font-size:18px}
.ftr-brand-name{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:24px;letter-spacing:-.03em}
.ftr-brand-name .dot{color:var(--accent)}
.ftr-blurb{color:rgba(255,255,255,.6);max-width:320px;line-height:1.6;margin-bottom:32px}
.ftr-social{display:flex;gap:12px}
.ftr-social a{display:grid;place-items:center;width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.2);color:#fff;transition:background-color .3s,border-color .3s}
.ftr-social a:hover{background:var(--accent);border-color:var(--accent)}
.ftr-h{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:20px}
.ftr-list a{display:block;padding:6px 0;font-size:14px;color:rgba(255,255,255,.8);transition:color .2s}
.ftr-list a:hover{color:var(--accent)}
.ftr-studio-row{display:flex;gap:12px;margin-bottom:12px;font-size:14px;color:rgba(255,255,255,.8)}
.ftr-studio-row svg{color:var(--accent);flex-shrink:0;margin-top:2px}
.ftr-bottom{padding-top:32px;display:flex;flex-direction:column;gap:16px;align-items:center;justify-content:space-between}
@media(min-width:768px){.ftr-bottom{flex-direction:row}}
.ftr-bottom p{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;color:rgba(255,255,255,.4)}
/* Mobile sticky action bar — one primary (Get a quote) + WhatsApp.
   Hidden on desktop where the header already carries both CTAs. */
.mobile-bar{position:fixed;left:0;right:0;bottom:0;z-index:40;display:none;gap:10px;padding:10px 12px;padding-bottom:calc(10px + env(safe-area-inset-bottom));background:rgba(250,250,247,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--line-2)}
[data-theme="dark"] .mobile-bar{background:rgba(14,14,14,.92);border-top-color:#262626}
.mobile-bar-cta{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--accent);color:#fff;font-family:'Inter Tight',system-ui,sans-serif;font-weight:600;font-size:15px;letter-spacing:-.01em;padding:14px 18px;border-radius:2px;text-decoration:none}
.mobile-bar-cta:hover{background:#e63e00}
.mobile-bar-wa{flex-shrink:0;display:grid;place-items:center;width:52px;background:#25D366;color:#fff;border-radius:2px;text-decoration:none}
.mobile-bar-wa:hover{background:#1ebe5a}
@media(max-width:767px){.mobile-bar{display:flex}body{padding-bottom:72px}}
.page{display:none;animation:fadeup .3s ease-out}
.page.active{display:block}
.page-hero{padding:120px 0 56px;background:var(--paper);overflow:hidden;position:relative}
@media(min-width:768px){.page-hero{padding-bottom:96px}}
.page-hero-grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:end;position:relative}
@media(min-width:1024px){.page-hero-grid{grid-template-columns:8fr 4fr}}
.page-hero-title{font-family:'Bricolage Grotesque',serif;font-weight:600;color:var(--ink);letter-spacing:-.035em;line-height:.92;font-size:clamp(44px,8vw,104px);margin-top:24px}
.page-hero-lede{margin-top:32px;font-size:18px;max-width:640px;color:var(--char);line-height:1.55}
.page-hero-bullets{margin-top:32px;display:grid;grid-template-columns:1fr;gap:12px;max-width:640px}
@media(min-width:640px){.page-hero-bullets{grid-template-columns:1fr 1fr}}
.page-hero-bullets li{display:flex;gap:12px;align-items:flex-start;font-size:14px;color:var(--char)}
.page-hero-bullets svg{color:var(--accent);flex-shrink:0;margin-top:2px}
.page-hero-price{background:var(--ink);color:var(--paper);padding:32px;border-radius:2px;position:relative;overflow:hidden}
.page-hero-price-lbl{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:16px}
.page-hero-price-val{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:72px;color:var(--accent);line-height:1;letter-spacing:-.03em}
.page-hero-price-sub{font-family:'Instrument Serif',serif;font-style:italic;font-size:20px;color:rgba(255,255,255,.7);margin-top:8px}
.page-hero-price-note{margin-top:32px;padding-top:24px;border-top:1px solid rgba(255,255,255,.15);font-family:'JetBrains Mono',monospace;font-size:11px;color:rgba(255,255,255,.5);letter-spacing:.18em;text-transform:uppercase}
.methods-grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line-2);border:1px solid var(--line-2)}
@media(min-width:768px){.methods-grid{grid-template-columns:1fr 1fr}}
.method-card{background:var(--paper);padding:32px;transition:background .3s}
@media(min-width:768px){.method-card{padding:40px}}
.method-card:hover{background:var(--paper-2)}
.method-num{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;color:var(--smoke)}
.method-title{font-family:'Bricolage Grotesque',serif;font-weight:600;letter-spacing:-.03em;font-size:clamp(24px,2.5vw,32px);color:var(--ink);margin:16px 0}
.method-desc{font-size:14px;color:var(--char);line-height:1.6;margin-bottom:24px}
.method-tag{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.garment-table-wrap{background:var(--paper);border:1px solid var(--line-2);overflow-x:auto}
.garment-table{width:100%;min-width:680px;border-collapse:collapse}
.garment-table th{text-align:left;padding:24px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--smoke);border-bottom:1px solid var(--line-2);font-weight:500}
.garment-table td{padding:24px;border-bottom:1px solid var(--line-2);font-size:14px;color:var(--char);transition:background .3s}
.garment-table tr:last-child td{border-bottom:none}
.garment-table tr:hover td{background:var(--paper-2)}
.garment-table td.name{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:18px;color:var(--ink)}
.garment-table td.weight{font-family:'JetBrains Mono',monospace;font-size:13px}
.garment-table td.price{text-align:right;font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:20px;color:var(--accent)}
.dtf-calc-grid{display:grid;grid-template-columns:1fr;gap:32px}
@media(min-width:1024px){.dtf-calc-grid{grid-template-columns:5fr 7fr}}
.dtf-calc-panel{background:var(--ink);color:var(--paper);padding:40px;border-radius:2px;position:relative;overflow:hidden}
.dtf-calc-head{display:flex;justify-content:space-between;margin-bottom:16px}
.dtf-calc-head span:first-child{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;color:rgba(255,255,255,.5)}
.dtf-calc-head span:last-child{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;color:var(--accent)}
.dtf-calc-price{font-family:'Bricolage Grotesque',serif;font-weight:700;font-size:clamp(72px,15vw,120px);color:var(--accent);line-height:1;margin-bottom:8px;letter-spacing:-.04em}
.dtf-calc-sub{font-family:'Instrument Serif',serif;font-style:italic;color:rgba(255,255,255,.7);font-size:22px;margin-bottom:32px}
.dtf-slider{width:100%;-webkit-appearance:none;appearance:none;height:4px;background:rgba(255,255,255,.2);border-radius:2px;outline:none}
.dtf-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--accent);cursor:pointer}
.dtf-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--accent);cursor:pointer;border:none}
.dtf-slider-labels{display:flex;justify-content:space-between;margin-top:12px;font-family:'JetBrains Mono',monospace;font-size:11px;color:rgba(255,255,255,.4)}
.dtf-calc-ctas{margin-top:32px;display:flex;flex-wrap:wrap;gap:12px}
.ind-grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line-2);border:1px solid var(--line-2)}
@media(min-width:768px){.ind-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.ind-grid{grid-template-columns:repeat(3,1fr)}}
.ind-card{background:var(--paper);padding:32px;transition:background .3s}
@media(min-width:768px){.ind-card{padding:40px}}
.ind-card:hover{background:var(--paper-2)}
.ind-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px}
.ind-icon{color:var(--accent)}
.ind-num{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;color:var(--smoke)}
.ind-name{font-family:'Bricolage Grotesque',serif;font-weight:600;letter-spacing:-.03em;font-size:clamp(22px,2.5vw,28px);color:var(--ink);margin-bottom:12px}
.ind-desc{font-size:14px;color:var(--char);line-height:1.6;margin-bottom:20px}
.ind-examples{padding-top:20px;border-top:1px solid var(--line-2);font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--smoke)}
.nums-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-2);border:1px solid var(--line-2)}
@media(min-width:768px){.nums-grid{grid-template-columns:repeat(4,1fr)}}
.num-card{background:var(--paper);padding:32px}
@media(min-width:768px){.num-card{padding:40px}}
.num-n{font-family:'Bricolage Grotesque',serif;font-weight:600;letter-spacing:-.035em;font-size:clamp(36px,5vw,60px);color:var(--ink);line-height:1}
.num-l{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--smoke);margin-top:12px}
.principles-grid{display:grid;grid-template-columns:1fr;gap:1px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.1)}
@media(min-width:768px){.principles-grid{grid-template-columns:1fr 1fr}}
.principle-card{background:var(--ink);padding:40px;transition:background .3s}
.principle-card:hover{background:var(--ink-2)}
.principle-num{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;color:var(--accent);margin-bottom:24px}
.principle-t{font-family:'Bricolage Grotesque',serif;font-weight:600;letter-spacing:-.03em;font-size:clamp(24px,3vw,36px);color:#fff;margin-bottom:16px}
.principle-d{font-size:15px;line-height:1.6;color:rgba(255,255,255,.6)}
.bulk-list{border-top:1px solid var(--line-2)}
.bulk-row{display:grid;grid-template-columns:1fr;gap:16px;padding:32px 4px;border-bottom:1px solid var(--line-2);transition:background .3s}
.bulk-row:hover{background:var(--paper-2)}
@media(min-width:768px){.bulk-row{grid-template-columns:2fr 4fr 5fr 1fr;gap:24px}}
.bulk-num{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.2em;color:var(--smoke)}
.bulk-title{font-family:'Bricolage Grotesque',serif;font-weight:600;letter-spacing:-.03em;line-height:1;font-size:clamp(24px,3vw,36px);color:var(--ink)}
.bulk-desc{font-size:15px;color:var(--char);line-height:1.6}
.blog-featured{padding:40px;background:var(--ink);color:var(--paper);border-radius:2px;position:relative;overflow:hidden;transition:transform .4s;display:block}
@media(min-width:768px){.blog-featured{padding:64px}}
.blog-featured:hover{transform:translateY(-4px)}
.blog-featured-grid{display:grid;grid-template-columns:1fr;gap:32px;position:relative;align-items:end}
@media(min-width:768px){.blog-featured-grid{grid-template-columns:8fr 4fr}}
.blog-featured-tag{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}
.blog-featured-title{font-family:'Bricolage Grotesque',serif;font-weight:600;letter-spacing:-.03em;line-height:1;font-size:clamp(32px,5.5vw,64px);margin:16px 0 20px;transition:color .3s}
.blog-featured:hover .blog-featured-title{color:var(--accent)}
.blog-featured-desc{color:rgba(255,255,255,.7);font-size:18px;max-width:640px;line-height:1.55}
.blog-featured-meta{display:flex;justify-content:space-between;align-items:center;gap:24px}
.blog-featured-meta-left{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.6);display:flex;gap:8px;align-items:center}
.blog-featured-arrow{display:grid;place-items:center;width:48px;height:48px;border-radius:50%;background:var(--accent);color:var(--ink);transition:transform .3s;flex-shrink:0}
.blog-featured:hover .blog-featured-arrow{transform:rotate(45deg)}
.blog-grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line-2);border:1px solid var(--line-2)}
@media(min-width:768px){.blog-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.blog-grid{grid-template-columns:repeat(3,1fr)}}
.blog-card{background:var(--paper);padding:32px;min-height:320px;display:flex;flex-direction:column;justify-content:space-between;transition:background .3s,transform .4s;cursor:pointer}
@media(min-width:768px){.blog-card{padding:40px}}
.blog-card:hover{background:var(--paper-2);transform:translateY(-4px)}
.blog-card-top{display:flex;justify-content:space-between;margin-bottom:24px}
.blog-card-tag{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}
.blog-card-num{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;color:var(--smoke)}
.blog-card-title{font-family:'Bricolage Grotesque',serif;font-weight:600;letter-spacing:-.03em;line-height:1.1;font-size:clamp(20px,2.2vw,26px);color:var(--ink);margin-bottom:16px;transition:color .3s}
.blog-card:hover .blog-card-title{color:var(--accent)}
.blog-card-desc{font-size:14px;color:var(--char);line-height:1.6;margin-bottom:24px}
.blog-card-foot{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--line-2)}
.blog-card-meta{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--smoke)}
.blog-card-arrow{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--ink);transition:background .3s,color .3s,transform .3s}
.blog-card:hover .blog-card-arrow{background:var(--ink);color:var(--paper);transform:rotate(45deg)}
/* Accessibility: skip link + reduced motion */
.skip-link{position:absolute;top:-40px;left:0;background:var(--ink);color:var(--paper);padding:8px 16px;z-index:9999;text-decoration:none;font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.skip-link:focus{top:0}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
  .marquee-row{animation:none !important}
  .grain{display:none !important}
}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}

/* ====================================================================
   Quote wizard + trade application (quote.njk / trade.njk)
   ==================================================================== */
/* Breadcrumbs */
.crumbs{display:flex;align-items:center;gap:10px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--smoke);margin-bottom:24px}
.crumbs a{color:var(--smoke);transition:color .2s}
.crumbs a:hover{color:var(--accent)}
.crumbs span[aria-current]{color:var(--ink)}
[data-theme="dark"] .crumbs span[aria-current]{color:var(--char)}

/* Button variants used by the wizard nav */
.page-hero-ctas{display:flex;flex-wrap:wrap;gap:12px}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--ink)}
[data-theme="dark"] .btn-ghost{color:var(--char);border-color:#333}
[data-theme="dark"] .btn-ghost:hover{border-color:var(--char)}
.btn-link{background:transparent;color:var(--smoke);border:none;padding:14px 8px;text-decoration:underline;text-underline-offset:3px}
.btn-link:hover{color:var(--accent)}

/* Required asterisk + field help / error */
.req{color:var(--accent);font-weight:700}
.field-help{display:block;font-size:12px;color:var(--smoke);margin-top:6px;line-height:1.5}
.field-error{display:none;font-size:12.5px;color:#b91c1c;margin-top:6px;line-height:1.4}
.field-error.show{display:block}
[data-theme="dark"] .field-error{color:#fca5a5}
.form-input.invalid,.form-select.invalid{border-bottom-color:#dc2626}

/* Checkboxes (consent, deadline, trade) */
.check{display:inline-flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--ink);cursor:pointer;line-height:1.45;min-height:32px}
.check-block{display:flex;align-items:center;padding:10px 0;min-height:44px}
[data-theme="dark"] .check{color:var(--char)}
.check input[type="checkbox"]{flex-shrink:0;width:20px;height:20px;margin-top:1px;accent-color:var(--accent);cursor:pointer}
.qw-trade-note,.qw-noart{font-size:13px;color:var(--smoke);margin-top:10px;line-height:1.5}
.qw-trade-note a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.qw-noart{padding:12px 14px;border:1px dashed var(--line-2);border-radius:2px;background:var(--paper-2)}
[data-theme="dark"] .qw-noart{background:#171717;border-color:#333}

/* Multi-select checkbox grid (trade services) */
.ms{border:none;padding:0;margin:0;min-width:0}
.ms-grid{display:grid;grid-template-columns:1fr;gap:10px;margin-top:10px}
@media(min-width:560px){.ms-grid{grid-template-columns:1fr 1fr}}
.ms-option{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--line-2);border-radius:2px;font-size:14px;color:var(--ink);cursor:pointer;transition:border-color .2s,background .2s;min-height:44px}
.ms-option:hover{border-color:var(--accent)}
.ms-option input{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}
[data-theme="dark"] .ms-option{color:var(--char);border-color:#262626;background:#171717}

/* Step indicator */
.qw-steps{display:flex;gap:8px;list-style:none;padding:0 0 28px;margin:0 0 28px;border-bottom:1px solid var(--line-2)}
.qw-step-item{flex:1;min-width:0}
.qw-step-btn{display:flex;align-items:center;gap:10px;width:100%;background:transparent;border:none;padding:4px;cursor:pointer;text-align:left;color:var(--smoke)}
.qw-step-btn:disabled{cursor:default}
.qw-step-dot{flex-shrink:0;display:grid;place-items:center;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line-2);font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:500;color:var(--smoke);background:var(--paper);transition:all .2s}
.qw-step-lbl{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qw-step-item.active .qw-step-dot{border-color:var(--accent);background:var(--accent);color:#fff}
.qw-step-item.active .qw-step-btn{color:var(--ink)}
.qw-step-item.done .qw-step-dot{border-color:var(--ink);background:var(--ink);color:var(--paper)}
[data-theme="dark"] .qw-step-dot{background:#171717}
[data-theme="dark"] .qw-step-item.active .qw-step-btn,[data-theme="dark"] .qw-step-item.done .qw-step-btn{color:var(--char)}
@media(max-width:560px){.qw-step-lbl{display:none}.qw-steps{gap:12px}.qw-step-item{flex:0 0 auto}}

/* Step panels */
.qw-step{border:none;padding:0;margin:0;min-width:0}
.qw-step[hidden]{display:none}
.qw-legend{font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:20px;letter-spacing:-.02em;color:var(--ink);padding:0;margin-bottom:8px}
[data-theme="dark"] .qw-legend{color:var(--char)}
.qw-intro{font-size:14px;color:var(--smoke);line-height:1.6;margin-bottom:24px;max-width:52ch}

/* Wizard nav row */
.qw-nav{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:32px;flex-wrap:wrap}
.qw-nav-r{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-left:auto}

/* Sidebar */
.qw-aside{align-self:start}
@media(min-width:1024px){.qw-aside{position:sticky;top:104px}}
.qw-usp{list-style:none;padding:0;margin:20px 0 24px;display:flex;flex-direction:column;gap:14px}
.qw-usp li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:rgba(255,255,255,.85);line-height:1.45}
.qw-usp svg{flex-shrink:0;margin-top:2px;color:var(--accent)}
.qw-aside-trade{margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,.12);font-size:13px;color:rgba(255,255,255,.6)}
.qw-aside-trade a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}

/* Trade page extras */
.methods-grid-3{grid-template-columns:1fr}
@media(min-width:768px){.methods-grid-3{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.methods-grid-3{grid-template-columns:1fr 1fr 1fr}}
.method-icon{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:50%;background:var(--paper-2);color:var(--accent);margin-bottom:20px}
[data-theme="dark"] .method-icon{background:#0f0f0f}
/* Reusable Google rating trust strip (see _includes/rating-strip.njk) */
.rating-strip{display:flex;justify-content:center;margin:0 0 28px}
/* Dark-card context (e.g. the quote aside) — keep the badge readable */
.ct-studio .rating-strip{justify-content:flex-start;margin:0 0 24px}
.ct-studio .rev-badge{border-color:rgba(255,255,255,.2);color:rgba(255,255,255,.7)}
.ct-studio .rev-badge strong{color:#fff}
.ct-studio .rev-badge:hover{border-color:var(--accent)}
/* Hero rating strips left-align within hero columns */
.hero .rating-strip,.page-hero .rating-strip{justify-content:flex-start}
/* Contact map embed */
.contact-map{border:1px solid var(--line-2);border-radius:2px;overflow:hidden;line-height:0}
/* Case-study cards (/work/) */
.case-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:768px){.case-grid{grid-template-columns:1fr 1fr}}
.case-card{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line-2);border-radius:8px;overflow:hidden;transition:border-color .3s}
.case-card:hover{border-color:var(--ink)}
.case-media{position:relative;aspect-ratio:16/10;overflow:hidden}
.case-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.case-tag{position:absolute;top:16px;left:16px;font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.3);border-radius:999px;padding:6px 12px;backdrop-filter:blur(8px)}
.case-no{position:absolute;top:16px;right:16px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;color:rgba(255,255,255,.85)}
.case-body{flex:1;padding:28px 26px;display:flex;flex-direction:column;gap:12px}
.case-outcome{margin:0;font-family:'Bricolage Grotesque',serif;font-weight:600;font-size:clamp(20px,2.2vw,26px);line-height:1.2;letter-spacing:-.02em;color:var(--ink)}
.case-client{margin:0;font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--smoke)}
.case-spec{display:grid;grid-template-columns:1fr 1fr;gap:16px 20px;margin:6px 0 0;padding-top:20px;border-top:1px solid var(--line-2)}
.case-spec div{display:flex;flex-direction:column;gap:3px}
.case-spec dt{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--smoke)}
.case-spec dd{margin:0;font-size:15px;font-weight:500;color:var(--ink)}
/* Garment colour swatch chips (quote wizard) */
.swatch-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.swatch{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;font-size:13px;color:var(--ink);background:var(--paper);border:1px solid var(--line-2);border-radius:999px;cursor:pointer;transition:border-color .2s,background .2s}
.swatch:hover{border-color:var(--ink)}
.swatch.selected{border-color:var(--accent);background:rgba(255,69,0,.06)}
.swatch-dot{width:14px;height:14px;border-radius:50%;border:1px solid transparent;flex-shrink:0}
.swatch-any{color:var(--smoke)}
.guarantees .method-card a{text-decoration:none;font-weight:500}
.guarantees .method-card a:hover{text-decoration:underline}
