/* =========================================================
   kunalwaghmare.com — design system v2
   ========================================================= */
:root{
  --ink:#0F1B2D;--ink-2:#1F2937;--paper:#FAF8F3;--paper-2:#F2EDE2;
  --line:#E5DFD0;--gold:#C8A45C;--gold-deep:#A8853F;--rose:#B65A3C;
  --teal:#2D6A6A;--mute:#6A6F77;--mute-2:#9BA0A8;--white:#FFFFFF;
  --shadow:0 1px 2px rgba(15,27,45,.04),0 8px 24px rgba(15,27,45,.08);
  --shadow-lg:0 4px 12px rgba(15,27,45,.06),0 24px 48px rgba(15,27,45,.10);
  --container:72rem;--gap:clamp(1rem,2vw,1.5rem);--gap-lg:clamp(2rem,5vw,4rem);
  --serif:"Fraunces",ui-serif,Georgia,serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"SF Mono",Menlo,Monaco,Consolas,monospace;
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);font-size:17px;line-height:1.6;color:var(--ink-2);background:var(--paper);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
@media(min-width:48em){body{font-size:18px}}
img,svg{display:block;max-width:100%;height:auto}
a{color:var(--ink);text-decoration:none;text-underline-offset:.2em}
a:hover{color:var(--gold-deep)}
a:focus-visible,button:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:2px}
.skip{position:absolute;left:-9999px;top:.5rem;background:var(--ink);color:var(--white);padding:.5rem 1rem;border-radius:4px;z-index:100}
.skip:focus{left:.5rem}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* type */
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.15;color:var(--ink);letter-spacing:-.01em;margin:0 0 .5em}
h1{font-size:clamp(2.25rem,6vw,4.25rem);font-weight:400;letter-spacing:-.02em;line-height:1.05}
h2{font-size:clamp(1.75rem,4vw,2.75rem);letter-spacing:-.015em}
h3{font-size:clamp(1.25rem,2.5vw,1.625rem)}
h4{font-size:1.125rem;font-family:var(--sans);font-weight:600}
p{margin:0 0 1em}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);font-size:.75rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);margin:0 0 1.25rem}
.eyebrow::before{content:"";display:block;width:1.75rem;height:1px;background:var(--gold)}
.lead{font-size:clamp(1.0625rem,1.6vw,1.25rem);line-height:1.55;color:var(--ink-2);max-width:38em}
.kicker{font-family:var(--mono);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--mute)}

/* layout */
.wrap{width:100%;max-width:var(--container);margin:0 auto;padding:0 1.25rem}
@media(min-width:48em){.wrap{padding:0 2rem}}
section{padding:clamp(3rem,7vw,6rem) 0}
.section-tight{padding:clamp(2rem,5vw,4rem) 0}

/* NAV */
.nav{position:sticky;top:0;z-index:50;background:rgba(250,248,243,.92);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid transparent;transition:border-color .2s,background .2s}
.nav.scrolled{border-bottom-color:var(--line);background:rgba(250,248,243,.97)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;max-width:var(--container);margin:0 auto;gap:1rem}
@media(min-width:48em){.nav-inner{padding:1.25rem 2rem}}
.brand{font-family:var(--serif);font-size:1.0625rem;font-weight:500;color:var(--ink);letter-spacing:-.01em;white-space:nowrap}
.brand span{color:var(--gold-deep)}
@media(min-width:48em){.brand{font-size:1.25rem}}
.nav-links{display:none;gap:1.5rem;align-items:center;font-size:.9375rem;flex-wrap:nowrap}
@media(min-width:64em){.nav-links{display:flex;gap:1.75rem}}
.nav-links a{color:var(--ink-2);white-space:nowrap}
.nav-links a:hover{color:var(--gold-deep)}
a.nav-cta,.nav-links a.nav-cta{display:inline-flex;align-items:center;gap:.5rem;background:var(--ink);color:var(--white)!important;padding:.625rem 1rem;border-radius:999px;font-size:.875rem;font-weight:500;transition:background .2s,transform .2s;text-decoration:none}
a.nav-cta:hover,.nav-links a.nav-cta:hover{background:var(--gold-deep);transform:translateY(-1px)}
.nav-toggle{display:flex;flex-direction:column;gap:4px;background:transparent;border:0;padding:.5rem;cursor:pointer;flex-shrink:0}
@media(min-width:64em){.nav-toggle{display:none}}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--ink);transition:.2s}
.nav-mobile{display:none;flex-direction:column;gap:.25rem;padding:1rem 1.25rem 2rem;border-top:1px solid var(--line);background:var(--paper);max-height:calc(100vh - 70px);overflow-y:auto}
.nav-mobile.open{display:flex}
.nav-mobile a{padding:.625rem 0;font-size:1rem;color:var(--ink-2)}
.nav-mobile h5{font-family:var(--mono);font-size:.6875rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mute);margin:1.25rem 0 .25rem;font-weight:600}
.nav-mobile h5:first-child{margin-top:.5rem}
.nav-mobile a.nav-cta{margin-top:1rem;justify-content:center}

/* dropdown */
.has-drop{position:relative}
.has-drop>a::after{content:" ▾";font-size:.625rem;opacity:.6}
.drop{position:absolute;top:calc(100% + .5rem);left:-1rem;background:var(--white);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);padding:.75rem;min-width:18rem;display:none;flex-direction:column;gap:.125rem;z-index:60}
.has-drop:hover .drop,.has-drop:focus-within .drop{display:flex}
.drop a{display:block;padding:.625rem .875rem;border-radius:4px;font-size:.9375rem;color:var(--ink-2);white-space:normal;line-height:1.3}
.drop a:hover{background:var(--paper-2);color:var(--gold-deep)}
.drop-eyebrow{font-family:var(--mono);font-size:.625rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);padding:.5rem .875rem .25rem;font-weight:600}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;border-radius:999px;font-size:.9375rem;font-weight:500;font-family:var(--sans);cursor:pointer;border:0;transition:transform .18s,background .18s,color .18s,box-shadow .18s;text-decoration:none;line-height:1}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--ink);color:var(--white)}
.btn-primary:hover{background:var(--gold-deep);color:var(--white);box-shadow:var(--shadow)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--white)}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:var(--gold-deep);color:var(--white)}
.btn-arrow::after{content:"→";transition:transform .2s}
.btn-arrow:hover::after{transform:translateX(3px)}

/* HERO */
.hero{position:relative;padding:clamp(3rem,8vw,7rem) 0 clamp(3rem,7vw,5rem);background:radial-gradient(ellipse at top right,rgba(200,164,92,.08),transparent 50%),var(--paper);overflow:hidden}
.hero-grid{display:grid;gap:var(--gap-lg);grid-template-columns:1fr}
@media(min-width:62em){.hero-grid{grid-template-columns:1.5fr 1fr;align-items:end}}
.hero-art{display:none}
@media(min-width:62em){.hero-art{display:block;position:relative;min-height:360px}}
.hero-h1{margin-bottom:.5em}
.hero-lead{margin-bottom:2rem}
.hero-ctas{display:flex;gap:.75rem;flex-wrap:wrap}
.hero-meta{display:flex;flex-wrap:wrap;gap:1.5rem 2rem;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--line);list-style:none;padding-left:0}
.hero-meta>div{flex:1 1 8rem;min-width:8rem}
.hero-meta dt{font-family:var(--mono);font-size:.6875rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);margin-bottom:.25rem}
.hero-meta dd{margin:0;font-family:var(--serif);font-size:1.5rem;font-weight:500;color:var(--ink)}

/* STATS BAND */
.stats-band{background:var(--ink);color:var(--paper);padding:clamp(2.5rem,5vw,4rem) 0}
.stats-band .wrap{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem 1rem}
@media(min-width:48em){.stats-band .wrap{grid-template-columns:repeat(4,1fr);gap:3rem 1.5rem}}
.stat-num{font-family:var(--serif);font-size:clamp(2rem,5vw,3rem);font-weight:400;color:var(--gold);letter-spacing:-.02em;line-height:1;display:block}
.stat-label{font-family:var(--sans);font-size:.875rem;color:var(--paper);opacity:.75;margin-top:.5rem;line-height:1.4}

/* CARDS */
.cards{display:grid;gap:1.25rem;grid-template-columns:1fr}
@media(min-width:40em){.cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:62em){.cards-3{grid-template-columns:repeat(3,1fr)}.cards-4{grid-template-columns:repeat(4,1fr)}}
.card{background:var(--white);border:1px solid var(--line);padding:1.75rem;border-radius:6px;transition:transform .2s,box-shadow .2s,border-color .2s;position:relative}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--gold)}
.card-num{font-family:var(--mono);font-size:.75rem;color:var(--gold-deep);letter-spacing:.08em;margin-bottom:1rem;display:block}
.card h3{font-size:1.25rem;margin-bottom:.625rem}
.card p{color:var(--mute);font-size:.9375rem;margin:0}

/* PROCESS */
.process{display:grid;gap:1.5rem;grid-template-columns:1fr;counter-reset:step}
@media(min-width:62em){.process{grid-template-columns:repeat(4,1fr)}}
.step{position:relative;padding:1.75rem;border-left:2px solid var(--gold);background:var(--white);border-radius:0 6px 6px 0}
@media(min-width:62em){.step{border-left:0;border-top:2px solid var(--gold);border-radius:0 0 6px 6px;padding-top:1.25rem}}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--mono);font-size:.75rem;color:var(--gold-deep);letter-spacing:.08em;display:block;margin-bottom:.625rem}
.step h3{font-size:1.125rem;margin-bottom:.5rem}
.step p{color:var(--mute);font-size:.9375rem;margin:0}

/* LOGO WALL */
.logos{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;align-items:center}
@media(min-width:48em){.logos{grid-template-columns:repeat(3,1fr)}}
@media(min-width:62em){.logos{grid-template-columns:repeat(3,1fr)}}
.logo{display:flex;align-items:flex-start;justify-content:flex-start;flex-direction:column;gap:.25rem;color:var(--ink-2);font-family:var(--serif);font-size:.9375rem;letter-spacing:.01em;font-weight:500;padding:1rem;background:var(--white);border:1px solid var(--line);border-radius:6px;transition:border-color .2s,transform .2s;text-align:left}
.logo:hover{border-color:var(--gold);transform:translateY(-2px)}
.logo-cat{font-family:var(--mono);font-size:.625rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}

/* PRODUCT BANDS */
.product-band{border-radius:8px;padding:clamp(2rem,4vw,3rem);display:grid;gap:2rem;grid-template-columns:1fr;align-items:center}
@media(min-width:62em){.product-band{grid-template-columns:1.4fr 1fr;gap:3rem}}
.product-band--vyndeal{background:linear-gradient(135deg,#1A1F2C,#0F1B2D);color:var(--paper)}
.product-band--vyndeal h3{color:var(--paper)}
.product-band--vyndeal .kicker{color:var(--gold)}
.product-band--quiamo{background:var(--paper-2);border:1px solid var(--line)}
.product-mock{background:rgba(255,255,255,.05);border:1px solid rgba(200,164,92,.25);border-radius:6px;padding:1.25rem;font-family:var(--mono);font-size:.8125rem}
.product-band--quiamo .product-mock{background:var(--white);border-color:var(--line);color:var(--ink-2)}

/* FAQ */
.faq{display:flex;flex-direction:column;gap:.5rem;max-width:48rem;margin:0 auto}
.faq details{background:var(--white);border:1px solid var(--line);border-radius:6px;padding:1.25rem 1.5rem;transition:border-color .2s}
.faq details[open]{border-color:var(--gold)}
.faq summary{cursor:pointer;font-weight:600;font-size:1.0625rem;color:var(--ink);display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--serif);font-size:1.5rem;color:var(--gold-deep);flex-shrink:0;transition:transform .2s;line-height:1}
.faq details[open] summary::after{content:"−"}
.faq details[open] summary{margin-bottom:.75rem}
.faq p{margin:0;color:var(--mute);font-size:.9375rem;line-height:1.65}

/* FINAL CTA */
.final-cta{background:var(--ink);color:var(--paper);text-align:center;padding:clamp(3rem,7vw,5rem) 0}
.final-cta h2{color:var(--paper);margin-bottom:.5em}
.final-cta p{color:var(--paper);opacity:.8;margin-bottom:2rem;max-width:36rem;margin-left:auto;margin-right:auto}
.final-cta .btn-primary{background:var(--gold);color:var(--ink)}
.final-cta .btn-primary:hover{background:var(--paper);color:var(--ink)}
.final-cta .btn-ghost{color:var(--paper);border-color:rgba(250,248,243,.4)}
.final-cta .btn-ghost:hover{background:var(--paper);color:var(--ink)}

/* QUOTE */
.quote{font-family:var(--serif);font-size:clamp(1.25rem,2.5vw,1.75rem);line-height:1.4;color:var(--ink);font-style:italic;border-left:3px solid var(--gold);padding-left:1.5rem;max-width:42rem}
.quote-attr{display:block;margin-top:1rem;font-family:var(--sans);font-size:.875rem;font-style:normal;color:var(--mute)}

/* CHARTS */
.chart{width:100%;height:auto;font-family:var(--sans)}
.chart text{font-size:11px;fill:var(--mute)}
.chart .bar{fill:var(--gold);transition:fill .2s}
.chart .bar:hover{fill:var(--gold-deep)}
.chart-label{font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;fill:var(--mute)}

/* TABLES */
.tbl{width:100%;border-collapse:collapse;font-size:.9375rem}
.tbl th,.tbl td{padding:.875rem 1rem;text-align:left;border-bottom:1px solid var(--line)}
.tbl th{font-family:var(--mono);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--mute);font-weight:500}
.tbl tbody tr:hover{background:var(--paper-2)}
.tbl-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:6px;background:var(--white)}

/* BREADCRUMB */
.crumbs{font-family:var(--mono);font-size:.75rem;letter-spacing:.06em;color:var(--mute);margin-bottom:1.5rem}
.crumbs a{color:var(--mute)}
.crumbs a:hover{color:var(--ink)}
.crumbs span{margin:0 .5rem;color:var(--mute-2)}

/* FOOTER */
.foot{background:var(--ink);color:var(--paper);padding:clamp(3rem,5vw,4rem) 0 2rem;font-size:.875rem}
.foot a{color:var(--paper);opacity:.75;display:block;padding:.25rem 0}
.foot a:hover{opacity:1;color:var(--gold)}
.foot-grid{display:grid;gap:2rem;grid-template-columns:1fr;margin-bottom:2.5rem}
@media(min-width:48em){.foot-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:62em){.foot-grid{grid-template-columns:1.6fr 1fr 1fr 1fr}}
.foot h4{color:var(--paper);font-family:var(--mono);font-size:.6875rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;margin-bottom:1rem;opacity:.85}
.foot-bottom{border-top:1px solid rgba(250,248,243,.12);padding-top:1.5rem;display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;font-size:.8125rem;opacity:.6}
.foot-bottom a{display:inline}
.foot-tagline{font-family:var(--serif);font-size:1.125rem;color:var(--paper);max-width:22rem;margin-bottom:1.5rem;line-height:1.5}
.foot-social{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}
.foot-social a{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(250,248,243,.2);border-radius:50%;padding:0;opacity:.7}
.foot-social a:hover{opacity:1;border-color:var(--gold)}

/* UTILS */
.center{text-align:center}.muted{color:var(--mute)}.gold{color:var(--gold-deep)}
.divider{height:1px;background:var(--line);margin:3rem 0;border:0}
.tag{display:inline-block;font-family:var(--mono);font-size:.6875rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-deep);background:rgba(200,164,92,.12);padding:.25rem .625rem;border-radius:999px;margin-right:.375rem}
.bg-paper-2{background:var(--paper-2)}.bg-white{background:var(--white)}

/* ANIMATIONS */
/* Progressive enhancement: content visible by default. Only hide when JS class set. */
.reveal{opacity:1;transform:none}
html.js .reveal{opacity:0;transform:translateY(16px);transition:opacity .8s ease,transform .8s ease}
html.js .reveal.in{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion:reduce){html.js .reveal,html.js .reveal.in{opacity:1!important;transform:none!important;transition:none!important}}
.reveal-delay-1{transition-delay:.08s}.reveal-delay-2{transition-delay:.16s}
.reveal-delay-3{transition-delay:.24s}.reveal-delay-4{transition-delay:.32s}
@keyframes grow-bar{from{transform:scaleY(0)}to{transform:scaleY(1)}}
.chart .bar{transform-origin:bottom}
.chart.in .bar{animation:grow-bar .7s cubic-bezier(.2,.8,.2,1) both}
.chart.in .bar:nth-child(2){animation-delay:.05s}.chart.in .bar:nth-child(3){animation-delay:.1s}
.chart.in .bar:nth-child(4){animation-delay:.15s}.chart.in .bar:nth-child(5){animation-delay:.2s}
.chart.in .bar:nth-child(6){animation-delay:.25s}.chart.in .bar:nth-child(7){animation-delay:.3s}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0!important;transition-duration:0!important}
  .reveal{opacity:1;transform:none}html{scroll-behavior:auto}
}

/* ENTRIES (case study + insight tiles) */
.entries{display:grid;gap:1.5rem;grid-template-columns:1fr}
@media(min-width:48em){.entries{grid-template-columns:repeat(2,1fr)}}
@media(min-width:62em){.entries{grid-template-columns:repeat(3,1fr)}}
.entry{background:var(--white);border:1px solid var(--line);border-radius:6px;overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s;text-decoration:none;color:inherit}
.entry:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.entry-cover{aspect-ratio:16/10;background:linear-gradient(135deg,var(--paper-2),rgba(200,164,92,.4));display:flex;align-items:center;justify-content:center;color:var(--ink);font-family:var(--serif);font-size:1.125rem;padding:1.5rem;text-align:center;line-height:1.3}
.entry-body{padding:1.5rem;flex:1;display:flex;flex-direction:column}
.entry h3{font-size:1.125rem;margin-bottom:.5rem;flex:1}
.entry-meta{font-family:var(--mono);font-size:.6875rem;letter-spacing:.08em;text-transform:uppercase;color:var(--mute);margin-top:.75rem}

/* TWO-COL */
.two-col{display:grid;gap:var(--gap-lg);grid-template-columns:1fr}
@media(min-width:62em){.two-col{grid-template-columns:1fr 1fr}}

/* TIERS */
.tiers{display:grid;gap:1.25rem;grid-template-columns:1fr}
@media(min-width:48em){.tiers{grid-template-columns:repeat(2,1fr)}}
@media(min-width:62em){.tiers{grid-template-columns:repeat(4,1fr)}}
.tier{background:var(--white);border:1px solid var(--line);border-radius:8px;padding:1.75rem;display:flex;flex-direction:column}
.tier--featured{border-color:var(--gold);background:linear-gradient(180deg,var(--paper-2),var(--white))}
.tier-name{font-family:var(--serif);font-size:1.375rem;color:var(--ink);margin-bottom:.25rem}
.tier-price{font-family:var(--mono);font-size:.875rem;color:var(--gold-deep);margin-bottom:1rem;letter-spacing:.04em}
.tier ul{list-style:none;padding:0;margin:0 0 1.5rem;font-size:.9375rem;color:var(--mute);flex:1}
.tier li{padding:.5rem 0;border-bottom:1px solid var(--line)}
.tier li:last-child{border-bottom:0}
.tier li::before{content:"→";color:var(--gold-deep);margin-right:.5rem;font-weight:600}

/* CONNECT SECTION */
.connect-grid{display:grid;gap:2rem;grid-template-columns:1fr}
@media(min-width:62em){.connect-grid{grid-template-columns:1.1fr 1fr;gap:3rem}}
.connect-card{background:var(--white);border:1px solid var(--line);border-radius:8px;padding:2rem}
.connect-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1.25rem}
.connect-list li{display:flex;gap:1rem;align-items:flex-start}
.connect-icon{flex-shrink:0;width:38px;height:38px;border-radius:50%;background:rgba(200,164,92,.14);display:flex;align-items:center;justify-content:center;color:var(--gold-deep)}
.connect-list>li>div{display:flex;flex-direction:column;gap:.125rem;flex:1;min-width:0}
.connect-lab{font-family:var(--mono);font-size:.6875rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);font-weight:500}
.connect-list a{font-size:1rem;color:var(--ink);font-weight:500;word-break:break-word}
.connect-list a:hover{color:var(--gold-deep)}
.connect-availability{font-size:.875rem;color:var(--mute);margin:1.5rem 0 0;padding-top:1.25rem;border-top:1px solid var(--line);font-style:italic}
.connect-social{display:flex;flex-wrap:wrap;gap:.5rem}
.connect-social a{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .875rem;border:1px solid var(--line);border-radius:999px;font-size:.8125rem;font-weight:500;color:var(--ink-2);background:var(--paper);transition:border-color .2s,color .2s,background .2s}
.connect-social a:hover{border-color:var(--gold);color:var(--gold-deep);background:rgba(200,164,92,.06)}
.connect-social svg{flex-shrink:0;color:var(--gold-deep)}
.connect-form{background:var(--ink);color:var(--paper);border-radius:8px;padding:2rem;display:flex;flex-direction:column;gap:1rem}
.connect-form .kicker{color:var(--gold)}
.connect-form .connect-lab{color:rgba(250,248,243,.7)}
.connect-form a{color:var(--gold)}
.connect-form a:hover{color:var(--paper)}
.connect-form label{display:flex;flex-direction:column;gap:.4rem}
.connect-form input,.connect-form select,.connect-form textarea{background:rgba(250,248,243,.08);border:1px solid rgba(250,248,243,.18);border-radius:6px;padding:.75rem .875rem;color:var(--paper);font-family:var(--sans);font-size:.9375rem;width:100%;transition:border-color .2s,background .2s}
.connect-form input::placeholder,.connect-form textarea::placeholder{color:rgba(250,248,243,.4)}
.connect-form input:focus,.connect-form select:focus,.connect-form textarea:focus{outline:none;border-color:var(--gold);background:rgba(250,248,243,.12)}
.connect-form select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23C8A45C' d='M0 0l6 8 6-8z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.connect-form textarea{resize:vertical;min-height:80px;font-family:var(--sans)}
.connect-form .btn-primary{background:var(--gold);color:var(--ink)}
.connect-form .btn-primary:hover{background:var(--paper);color:var(--ink)}
.consent-line{display:flex;align-items:flex-start;gap:.5rem;font-size:.8125rem;color:rgba(250,248,243,.7)}
.consent-line input{width:auto;flex-shrink:0;margin-top:.25rem}
.consent-line a{color:var(--gold);text-decoration:underline}

/* HOMEPAGE */
.home-hero{position:relative;padding:clamp(3rem,8vw,7rem) 0 clamp(3rem,7vw,6rem);overflow:hidden;background:var(--paper)}
.home-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 80% 20%,rgba(200,164,92,.12),transparent 55%),radial-gradient(ellipse at 20% 80%,rgba(45,106,106,.06),transparent 55%);pointer-events:none}
.home-hero .wrap{position:relative;z-index:1}
.home-h1{font-size:clamp(2.5rem,7vw,5rem);line-height:1.02;letter-spacing:-.025em;font-weight:400;max-width:14em}
.home-h1 em{font-style:italic;color:var(--gold-deep);font-weight:400}
.bucket{position:relative;background:var(--white);border:1px solid var(--line);border-radius:8px;padding:2rem;display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s,border-color .25s}
.bucket:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--gold)}
.bucket-num{position:absolute;top:1.5rem;right:1.5rem;font-family:var(--mono);font-size:.6875rem;color:var(--mute);letter-spacing:.1em}
.bucket h3{font-size:1.5rem;margin:.5rem 0 .75rem}
.bucket p.bucket-lead{color:var(--mute);font-size:.9375rem;margin:0 0 1.25rem;flex:1}
.bucket-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.25rem;border-top:1px solid var(--line);padding-top:1rem}
.bucket-links a{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;font-size:.9375rem;color:var(--ink-2);border-bottom:1px solid transparent;transition:color .2s,border-color .2s}
.bucket-links a:hover{color:var(--gold-deep);border-bottom-color:var(--gold)}
.bucket-links a::after{content:"→";color:var(--mute-2);transition:color .2s,transform .2s}
.bucket-links a:hover::after{color:var(--gold-deep);transform:translateX(3px)}
.bucket-eyebrow{font-family:var(--mono);font-size:.6875rem;color:var(--gold-deep);letter-spacing:.1em;text-transform:uppercase}
.buckets-grid{display:grid;gap:1.25rem;grid-template-columns:1fr}
@media(min-width:48em){.buckets-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:75em){.buckets-grid{grid-template-columns:repeat(3,1fr)}}
.case-strip{display:grid;gap:1.25rem;grid-template-columns:1fr}
@media(min-width:48em){.case-strip{grid-template-columns:repeat(3,1fr)}}
.case-tile{background:linear-gradient(155deg,var(--ink) 0%,#16273F 100%);color:var(--paper);padding:2rem;border-radius:8px;display:flex;flex-direction:column;min-height:280px;text-decoration:none;transition:transform .25s,box-shadow .25s}
.case-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);color:var(--paper)}
.case-tile .kicker{color:var(--gold)}
.case-tile h3{color:var(--paper);font-size:1.375rem;margin:.75rem 0 1rem;flex:1}
.case-tile .case-stat{font-family:var(--serif);font-size:2rem;color:var(--gold);line-height:1;margin-bottom:.25rem}
.case-tile .case-stat-lab{font-size:.75rem;opacity:.7}
.case-tile .case-arrow{margin-top:1rem;font-size:.875rem;display:inline-flex;gap:.5rem;align-items:center}
.case-tile .case-arrow::after{content:"→";transition:transform .2s}
.case-tile:hover .case-arrow::after{transform:translateX(4px)}
.teasers{display:grid;gap:1rem;grid-template-columns:1fr}
@media(min-width:48em){.teasers{grid-template-columns:repeat(3,1fr)}}
.teaser{background:var(--white);border:1px solid var(--line);border-radius:6px;padding:1.5rem;text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:.75rem;transition:border-color .2s,transform .2s}
.teaser:hover{border-color:var(--gold);transform:translateY(-2px)}
.teaser h4{font-family:var(--serif);font-size:1.125rem;font-weight:500;color:var(--ink);margin:0;line-height:1.3}
.teaser p{font-size:.8125rem;color:var(--mute);margin:0;flex:1}
.t-mini{display:grid;gap:1.25rem;grid-template-columns:1fr;margin-top:2rem}
@media(min-width:62em){.t-mini{grid-template-columns:repeat(3,1fr)}}
.t-mini-card{background:var(--paper-2);border-left:3px solid var(--gold);padding:1.5rem;border-radius:0 6px 6px 0}
.t-mini-card p{font-family:var(--serif);font-style:italic;font-size:1rem;color:var(--ink);line-height:1.5;margin:0 0 1rem}
.t-mini-card cite{font-style:normal;font-size:.8125rem;color:var(--mute);font-family:var(--sans)}
.home-hero-art{position:absolute;right:-2rem;bottom:0;width:46%;max-width:500px;opacity:.45;pointer-events:none;display:none}
@media(min-width:75em){.home-hero-art{display:block;opacity:.7}}

/* COOKIE BANNER */
.cookie-banner{position:fixed;bottom:1rem;left:1rem;right:1rem;max-width:32rem;margin-left:auto;margin-right:auto;background:var(--ink);color:var(--paper);border-radius:12px;padding:1.25rem 1.5rem;box-shadow:0 16px 48px rgba(15,27,45,.4);z-index:100;display:none;border:1px solid rgba(200,164,92,.2)}
.cookie-banner.show{display:block;animation:slide-up .4s cubic-bezier(.2,.8,.2,1)}
@keyframes slide-up{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.cookie-banner h4{color:var(--paper);font-family:var(--sans);font-size:.9375rem;margin:0 0 .5rem;font-weight:600}
.cookie-banner p{font-size:.8125rem;color:rgba(250,248,243,.75);margin:0 0 1rem;line-height:1.5}
.cookie-banner p a{color:var(--gold);text-decoration:underline}
.cookie-actions{display:flex;flex-wrap:wrap;gap:.5rem}
.cookie-actions button{padding:.5rem 1rem;border-radius:999px;font-size:.8125rem;font-weight:500;cursor:pointer;border:0;font-family:var(--sans);transition:background .2s,color .2s}
.cookie-actions .accept{background:var(--gold);color:var(--ink)}
.cookie-actions .accept:hover{background:var(--paper)}
.cookie-actions .decline{background:transparent;color:var(--paper);border:1px solid rgba(250,248,243,.3)}
.cookie-actions .decline:hover{background:rgba(250,248,243,.1)}

/* AI-SUMMARY (visually hidden but available to crawlers + screen readers) */
.ai-summary{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:normal;border:0}

/* ARTICLE prose for insights/freelance pages */
.prose{max-width:42rem;margin:0 auto;font-size:1.0625rem;line-height:1.7;color:var(--ink-2)}
.prose h2{font-size:clamp(1.5rem,3vw,2rem);margin-top:2.5rem;margin-bottom:.75rem}
.prose h3{font-size:1.25rem;margin-top:2rem;margin-bottom:.5rem}
.prose p{margin-bottom:1.25rem}
.prose ul,.prose ol{margin:0 0 1.25rem;padding-left:1.25rem}
.prose li{margin-bottom:.5rem}
.prose blockquote{border-left:3px solid var(--gold);padding-left:1.25rem;margin:1.5rem 0;font-style:italic;color:var(--ink)}
.prose code{font-family:var(--mono);font-size:.875rem;background:var(--paper-2);padding:.125rem .375rem;border-radius:3px}
.prose strong{color:var(--ink);font-weight:600}
.prose a{color:var(--gold-deep);text-decoration:underline;text-decoration-color:rgba(200,164,92,.5);text-underline-offset:.2em}
.prose a:hover{text-decoration-color:var(--gold-deep)}

/* ============ MEGA MENU ============ */
.has-mega{position:static}
.has-mega>a::after{content:" ▾";font-size:.625rem;opacity:.6}
.mega{position:absolute;top:100%;left:0;right:0;background:var(--white);border-top:1px solid var(--line);border-bottom:1px solid var(--line);box-shadow:0 18px 38px -16px rgba(15,27,45,.18);padding:0;display:none;z-index:60}
.has-mega:hover .mega,.has-mega:focus-within .mega{display:block}
.mega-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1.75rem 2rem;max-width:1320px;margin:0 auto;padding:2rem 2rem 1.5rem}
.mega-col{display:flex;flex-direction:column;gap:.0625rem}
.mega-col a{display:block;padding:.375rem .25rem;font-size:.8125rem;color:var(--ink-2);line-height:1.3;border-radius:3px;text-decoration:none;letter-spacing:-.005em}
.mega-col a:hover{background:var(--paper-2);color:var(--gold-deep);padding-left:.5rem;transition:padding .15s}
.mega-title{font-family:var(--mono);font-size:.6875rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:.5rem;font-weight:700;display:block}
.mega-foot{display:flex;justify-content:space-between;align-items:center;background:var(--paper-2);padding:1rem 2rem;font-family:var(--mono);font-size:.75rem;color:var(--mute);border-top:1px solid var(--line)}
.mega-foot .btn{font-size:.8125rem;padding:.625rem 1.125rem}
@media (max-width:1100px){.mega-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:880px){.has-mega .mega{display:none!important}}

/* Mobile accordion menu */
.m-acc{margin:0;border-bottom:1px solid var(--line)}
.m-acc>summary{cursor:pointer;list-style:none;padding:.875rem 0;font-family:var(--mono);font-size:.6875rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;display:flex;justify-content:space-between;align-items:center}
.m-acc>summary::-webkit-details-marker{display:none}
.m-acc>summary::after{content:"+";font-family:var(--sans);font-size:1.25rem;color:var(--mute);transition:transform .2s;font-weight:300}
.m-acc[open]>summary::after{content:"−"}
.m-acc>a{padding:.5rem 0 .5rem 0;display:block;font-size:.9375rem;color:var(--ink-2)}

/* ============ GLOBAL ENQUIRY FORM (every page) ============ */
.global-enq{background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%);padding:clamp(3rem,6vw,4.5rem) 0;border-top:1px solid var(--line);scroll-margin-top:80px}
.global-enq .geh{max-width:42rem;margin-bottom:2.5rem}
.global-enq h2{margin-bottom:.5em}
.gef-wrap{display:grid;grid-template-columns:1.1fr 1fr;gap:2rem;align-items:start;max-width:1100px}
@media (max-width:880px){.gef-wrap{grid-template-columns:1fr}}
.gef-side{padding:1.5rem 0}
.gef-side h3{font-family:var(--serif);font-size:1.375rem;font-weight:500;color:var(--ink);margin-bottom:1rem;line-height:1.3}
.gef-side p{color:var(--ink-2);line-height:1.6;margin-bottom:1rem}
.gef-langs{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:1.25rem}
.gef-langs span{font-size:.75rem;padding:.25rem .625rem;background:var(--white);border:1px solid var(--line);border-radius:999px;color:var(--ink-2);font-family:var(--mono);letter-spacing:.02em}
.gef-tz{display:grid;grid-template-columns:auto 1fr;gap:.5rem 1rem;font-size:.8125rem;color:var(--ink-2);margin-top:1rem;font-family:var(--mono)}
.gef-tz strong{color:var(--ink);font-weight:600}
.gef{background:var(--ink);color:var(--paper);padding:2rem;border-radius:12px;display:flex;flex-direction:column;gap:1rem;box-shadow:0 18px 38px -16px rgba(15,27,45,.3)}
.gef p.kicker{color:var(--gold)}
.gef label{display:flex;flex-direction:column;gap:.375rem;font-size:.8125rem}
.gef label span{font-family:var(--mono);font-size:.6875rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);font-weight:600}
.gef input,.gef select,.gef textarea{font-family:var(--sans);font-size:.9375rem;background:rgba(250,248,243,.06);border:1px solid rgba(200,164,92,.25);color:var(--paper);padding:.625rem .75rem;border-radius:6px;transition:border-color .15s,background .15s}
.gef input:focus,.gef select:focus,.gef textarea:focus{outline:0;border-color:var(--gold);background:rgba(250,248,243,.1)}
.gef textarea{resize:vertical;min-height:60px;font-family:inherit}
.gef select{cursor:pointer}
.gef select option{background:var(--ink);color:var(--paper)}
.gef-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
@media (max-width:520px){.gef-row{grid-template-columns:1fr}}
.gef-consent{display:flex;align-items:flex-start;gap:.5rem;font-size:.75rem;color:rgba(250,248,243,.7);line-height:1.4}
.gef-consent input{width:auto;margin-top:.125rem}
.gef-consent a{color:var(--gold)}
.gef button{margin-top:.25rem}

/* Floating "quick enquiry" button */
.float-cta{position:fixed;bottom:1.25rem;right:1.25rem;z-index:90;background:var(--ink);color:var(--paper);padding:.875rem 1.25rem;border-radius:999px;font-size:.8125rem;font-weight:500;text-decoration:none;display:none;align-items:center;gap:.5rem;box-shadow:0 8px 24px -8px rgba(15,27,45,.4);transition:transform .2s,background .2s}
.float-cta.show{display:inline-flex}
.float-cta:hover{transform:translateY(-2px);background:var(--gold-deep)}
.float-cta .x{position:absolute;top:-6px;right:-6px;width:18px;height:18px;background:var(--paper);color:var(--ink);border-radius:50%;font-size:.6875rem;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);cursor:pointer}
@media (max-width:520px){.float-cta{bottom:1rem;right:1rem;font-size:.75rem;padding:.75rem 1rem}}
