:root{
  --ink:#0b0b0c; --ink-soft:#5f5a53; --paper:#ffffff; --paper-soft:#fbfaf7;
  --line:#e8e2d8; --line-2:#efebe4; --navy:#16254a; --red:#c0271d; --red-dark:#a11f18; --green:#b7c56f;
  --fd:'Cormorant Garamond', Georgia, serif; --fb:'DM Sans', system-ui, sans-serif; --shadow:0 12px 36px rgba(15,15,15,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);background:var(--paper);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%} a{text-decoration:none;color:inherit}
.container{max-width:1240px;margin:0 auto;padding:0 2rem}
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(10,10,10,.95);border-bottom:1px solid rgba(255,255,255,.08);backdrop-filter:blur(10px)}
.header-inner{min-height:84px;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.logo{height:40px;width:auto}
.nav{display:flex;align-items:center;gap:1.55rem}
.nav a{font-size:.69rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.74)}
.nav a:hover,.nav a.active{color:#fff}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:50px;padding:0 1.4rem;border-radius:999px;border:1px solid transparent;font-size:.73rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;transition:all .22s ease;cursor:pointer}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--red);color:#fff}.btn-primary:hover{background:var(--red-dark)}
.btn-outline-dark{border-color:rgba(255,255,255,.18);color:#fff}
.btn-outline-light{border-color:#d9d2c7;color:#232323;background:#fff}
.btn-navy{background:var(--navy);color:#fff}
.mobile-toggle{display:none;background:none;border:none;color:#fff;font:inherit;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;padding:.4rem 0}
.mobile-panel{display:none;border-top:1px solid rgba(255,255,255,.08);background:rgba(10,10,10,.98)}
.mobile-panel.open{display:block}
.mobile-inner{padding:1rem 2rem 1.25rem}
.mobile-inner nav{display:grid;gap:.75rem}
.mobile-inner a{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.86);padding:.35rem 0}
.hero-dark{padding:7.2rem 0 4rem;background:var(--ink);color:#fff}
.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:3rem;align-items:center;min-height:620px}
.eyebrow{display:inline-flex;align-items:center;gap:.75rem;font-size:.63rem;letter-spacing:.2em;text-transform:uppercase}
.eyebrow::before{content:"";width:2.35rem;height:1px;background:currentColor;display:block}
.eyebrow.dark{color:rgba(255,255,255,.48)} .eyebrow.red{color:var(--red)} .eyebrow.lime{color:var(--green)}
.display{margin-top:1rem;font-family:var(--fd);font-size:clamp(3.2rem,6vw,5.4rem);font-weight:600;line-height:.93;letter-spacing:-.03em}
.display em{font-style:italic;color:var(--red)}
.lead{margin-top:1.1rem;max-width:640px;font-size:1.04rem;line-height:1.9;color:rgba(255,255,255,.72)}
.hero-actions,.cta-row{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.6rem}
.hero-card{max-width:530px;margin-left:auto}
.hero-photo{overflow:hidden;border-radius:30px;background:#111;box-shadow:0 18px 50px rgba(0,0,0,.22)}
.hero-photo img{width:100%;height:430px;object-fit:cover;object-position:58% 42%;filter:grayscale(100%)}
.hero-meta{padding:1rem .15rem 0}.hero-name{font-family:var(--fb);font-size:1.1rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;line-height:1.2}.hero-role{margin-top:.3rem;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.46)}
.metrics{background:var(--paper-soft);border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);padding:2.35rem 0}
.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr)} .metric{padding:0 1.7rem} .metric + .metric{border-left:1px solid var(--line)}
.metric-value{font-family:var(--fd);font-size:clamp(3rem,4.2vw,4.2rem);line-height:.9;color:#121212}.metric-value span{font-size:.42em;vertical-align:top;color:var(--red);margin-left:.04em}
.metric-label{margin-top:.55rem;font-size:1rem;line-height:1.45;color:#7f786f;max-width:250px}.metric-label strong{color:#5f584f;font-weight:500}
.section{padding:5rem 0;background:#fff}.section-soft{padding:5rem 0;background:var(--paper-soft)}.section-dark{padding:5rem 0;background:var(--navy);color:#fff}
.h2{font-family:var(--fd);font-size:clamp(2.2rem,4.2vw,3.9rem);font-weight:600;line-height:1.04;letter-spacing:-.02em}.h2 span{color:var(--red)}
.h2-dark{font-family:var(--fd);font-size:clamp(2.2rem,4.2vw,3.9rem);font-weight:600;line-height:1.04;letter-spacing:-.02em;color:#fff}.h2-dark span{color:#ff6670}
.intro{margin-top:1rem;max-width:780px;font-size:1.03rem;line-height:1.9;color:var(--ink-soft)} .intro-dark{margin-top:1rem;max-width:860px;font-size:1.03rem;line-height:1.9;color:rgba(255,255,255,.8)}
.problem-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:3.5rem;align-items:start;margin-top:1.8rem}
.problem-copy p{margin-top:1rem;font-size:1rem;line-height:1.9;color:var(--ink-soft)} .problem-list{display:grid}
.problem-item{display:grid;grid-template-columns:74px 1fr;gap:1rem;padding:1.7rem 0;border-top:1px solid var(--line-2)} .problem-item:last-child{border-bottom:1px solid var(--line-2)}
.problem-num{font-family:var(--fd);font-size:3rem;line-height:1;color:#d3cbc0}
.problem-title{font-family:var(--fd);font-size:1.18rem;line-height:1.3}
.problem-text{margin-top:.45rem;font-size:1rem;line-height:1.82;color:#6f695f}
.focus-grid,.reason-grid,.overview-grid{display:grid;gap:1rem;margin-top:2rem}
/* 2x2 grid for 4 service cards */
.focus-grid{grid-template-columns:repeat(2,1fr)}
.reason-grid{grid-template-columns:repeat(4,1fr)}
.overview-grid{grid-template-columns:repeat(4,1fr)}
.insight-grid{display:grid;gap:1rem;margin-top:2rem;grid-template-columns:repeat(3,1fr)}
.card,.insight-card,.overview-card,.reason-card{border:1px solid var(--line);border-radius:22px;background:#fff;padding:1.45rem;box-shadow:var(--shadow)}
.kicker{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#7d776f}
.card-title{margin-top:.8rem;font-family:var(--fd);font-size:1.65rem;line-height:1.08}
.card-copy{margin-top:.7rem;font-size:1rem;line-height:1.82;color:var(--ink-soft)}
.card-link{display:inline-flex;align-items:center;gap:.4rem;margin-top:1.1rem;font-size:.76rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--red)}
.card-link:hover{gap:.7rem}
.method-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}
.method-card{border:1px solid rgba(255,255,255,.08);border-radius:0;background:#050505;padding:2rem 1.7rem;min-height:260px}
.method-pill{display:inline-flex;align-items:center;justify-content:center;padding:.55rem 1.1rem;border-radius:999px;color:#fff;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase}
.method-card h3{margin-top:1.5rem;font-family:var(--fd);font-size:1.7rem;line-height:1.08;color:#fff}
.method-card p{margin-top:.8rem;font-size:1rem;line-height:1.82;color:rgba(255,255,255,.74)}
/* Testimonials */
.testimonials{padding:5rem 0;background:var(--paper-soft);border-top:1px solid var(--line-2)}
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2.5rem}
.testimonial-card{border:1px solid var(--line);border-radius:22px;background:#fff;padding:2rem 1.7rem;box-shadow:var(--shadow);display:flex;flex-direction:column;justify-content:space-between}
.testimonial-quote{font-family:var(--fd);font-size:1.22rem;line-height:1.6;color:#1a1a1a;font-style:italic}
.testimonial-quote::before{content:"\201C";font-size:3rem;line-height:.5;vertical-align:-.6rem;color:var(--red);margin-right:.1rem;font-style:normal}
.testimonial-author{margin-top:1.5rem;display:flex;align-items:center;gap:.85rem}
.testimonial-avatar{width:44px;height:44px;border-radius:999px;background:var(--line-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:1.1rem;color:var(--navy);font-weight:600;flex-shrink:0}
.testimonial-name{font-size:.88rem;font-weight:600;color:#111}
.testimonial-role{font-size:.76rem;color:#8a8279;margin-top:.1rem;letter-spacing:.02em}
/* CTA band */
.cta-band{padding:4.2rem 0;background:var(--paper-soft);border-top:1px solid var(--line)}
.cta-band p{margin-top:1rem;max-width:860px;font-size:1.04rem;line-height:1.9;color:#657188}
/* Footer */
.footer{border-top:1px solid #f1ede7;background:#fff;padding:2.5rem 0}
.footer-grid{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:start}
.footer-copy{margin-top:1rem;font-size:.78rem;line-height:1.8;color:var(--ink-soft);max-width:520px}
.footer-bottom{margin-top:1.4rem;padding-top:1.2rem;border-top:1px solid var(--line-2);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}
.footer-bottom span{font-size:.72rem;color:#a09890;letter-spacing:.04em}
.footer-nav{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:flex-end}
.footer-nav a{font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:#677188}
.footer-nav a:hover{color:var(--ink)}
.footer-social{display:flex;gap:.75rem;margin-top:1rem}
.footer-social a{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1px solid var(--line);color:#677188;transition:all .2s ease}
.footer-social a:hover{border-color:var(--navy);color:var(--navy)}
.footer-social svg{width:16px;height:16px;fill:currentColor}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .45s ease, transform .45s ease}.reveal.in{opacity:1;transform:none}
.to-top{position:fixed;right:18px;bottom:18px;z-index:50;width:46px;height:46px;border-radius:999px;background:#111;color:#fff;border:none;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 24px rgba(0,0,0,.16);opacity:0;visibility:hidden;transition:all .24s ease;cursor:pointer}.to-top.show{opacity:1;visibility:visible}
@media (max-width:1180px){.hero-grid,.metrics-grid,.problem-grid,.focus-grid,.reason-grid,.insight-grid,.overview-grid,.method-grid,.footer-grid,.testimonial-grid{grid-template-columns:1fr 1fr}.metrics-grid{grid-template-columns:repeat(2,1fr)}.metric{padding:1rem 0}.metric + .metric{border-left:none;border-top:1px solid var(--line);padding-top:1.4rem}}
@media (max-width:900px){.container{padding:0 1.2rem}.nav,.header-inner .btn{display:none}.mobile-toggle{display:block}.focus-grid,.testimonial-grid,.reason-grid,.metrics-grid{grid-template-columns:1fr}.hero-grid,.method-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column;align-items:flex-start}}


/* ═══ Page-specific styles ═══ */

/* [about] */
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;align-items:start;margin-top:2rem}

/* [about] */
.team-photo,.portrait-photo{border:1px solid var(--line);border-radius:22px;overflow:hidden;background:#fff}

/* [about] */
.team-photo img,.portrait-photo img{width:100%;height:auto;filter:grayscale(100%)}

/* [about] */
.card{border:1px solid var(--line);border-radius:22px;background:#fff;padding:1.45rem;box-shadow:var(--shadow)}

/* [about] */
/* Values section */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}

/* [about] */
.value-card{border:1px solid var(--line);border-radius:22px;padding:1.6rem;background:#fff;box-shadow:var(--shadow)}

/* [about] */
.value-icon{font-family:var(--fd);font-size:2.4rem;line-height:1;color:var(--red)}

/* [about] */
.value-title{margin-top:.7rem;font-family:var(--fd);font-size:1.3rem;line-height:1.1}

/* [about] */
.value-copy{margin-top:.5rem;font-size:.97rem;line-height:1.8;color:var(--ink-soft)}

/* [about] */
/* Bio section */
.bio-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:3rem;align-items:start;margin-top:2.5rem}

/* [about] */
.bio-photo{border:1px solid var(--line);border-radius:22px;overflow:hidden}

/* [about] */
.bio-photo img{width:100%;height:auto;filter:grayscale(100%)}

/* [about] */
.bio-name{font-family:var(--fd);font-size:2.4rem;line-height:1.04;margin-top:.6rem}

/* [about] */
.bio-role{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-top:.3rem}

/* [about] */
.bio-divider{width:2.5rem;height:2px;background:var(--red);margin:1.2rem 0}

/* [about] */
.bio-text p{font-size:1rem;line-height:1.9;color:var(--ink-soft);margin-top:.9rem}

/* [about] */
.bio-text p:first-child{margin-top:0}

/* [about] */
.cta-row{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.6rem}

/* [contact] */
/* Hero — compact for contact page */
.hero-contact{padding:7.2rem 0 3.5rem;background:var(--ink);color:#fff}

/* [contact] */
/* Contact layout */
.contact-section{padding:5rem 0;background:#fff}

/* [contact] */
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:3.5rem;align-items:start}

/* [contact] */
/* Info panel */
.info-panel{position:sticky;top:108px}

/* [contact] */
.info-title{font-family:var(--fd);font-size:1.9rem;line-height:1.1}

/* [contact] */
.info-copy{margin-top:.8rem;font-size:1rem;line-height:1.86;color:var(--ink-soft)}

/* [contact] */
.info-divider{margin:1.6rem 0;border:none;border-top:1px solid var(--line-2)}

/* [contact] */
.contact-detail{display:flex;align-items:flex-start;gap:.85rem;margin-top:1.2rem}

/* [contact] */
.contact-detail:first-of-type{margin-top:0}

/* [contact] */
.contact-icon{width:40px;height:40px;border-radius:10px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--red)}

/* [contact] */
.contact-icon svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

/* [contact] */
.contact-label{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#9d9690;margin-bottom:.2rem}

/* [contact] */
.contact-value{font-size:1rem;font-weight:500;color:var(--ink)}

/* [contact] */
.contact-value a{color:var(--ink)}

/* [contact] */
.contact-value a:hover{color:var(--red)}

/* [contact] */
.coverage-tag{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.5rem;padding:.55rem 1rem;border-radius:999px;background:var(--paper-soft);border:1px solid var(--line);font-size:.76rem;letter-spacing:.08em;color:var(--ink-soft)}

/* [contact] */
.coverage-tag svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}

/* [contact] */
/* Form */
.form-card{border:1px solid var(--line);border-radius:24px;padding:2.2rem;box-shadow:var(--shadow)}

/* [contact] */
.form-title{font-family:var(--fd);font-size:1.9rem;line-height:1.1}

/* [contact] */
.form-subtitle{margin-top:.5rem;font-size:.97rem;color:var(--ink-soft);line-height:1.7}

/* [contact] */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.6rem}

/* [contact] */
.form-group{display:flex;flex-direction:column;gap:.45rem}

/* [contact] */
.form-group.full{grid-column:1/-1}

/* [contact] */
.form-label{font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;color:#7d776f;font-weight:600}

/* [contact] */
.form-input,.form-select,.form-textarea{width:100%;padding:.75rem 1rem;border:1px solid var(--line);border-radius:12px;font-family:var(--fb);font-size:.97rem;color:var(--ink);background:#fff;transition:border-color .2s ease,box-shadow .2s ease;-webkit-appearance:none;appearance:none}

/* [contact] */
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(22,37,74,.08)}

/* [contact] */
.form-textarea{resize:vertical;min-height:120px;line-height:1.6}

/* [contact] */
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235f5a53' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem;cursor:pointer}

/* [contact] */
.form-submit{margin-top:1.4rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}

/* [contact] */
.form-note{font-size:.8rem;color:#9d9690;line-height:1.5;max-width:320px}

/* [contact] */
/* Success state */
.form-success{display:none;text-align:center;padding:2rem 1rem}

/* [contact] */
.success-icon{width:56px;height:56px;border-radius:999px;background:#f0f7ec;border:1px solid #c2e0b0;display:flex;align-items:center;justify-content:center;margin:0 auto}

/* [contact] */
.success-icon svg{width:24px;height:24px;stroke:#4a6b1a;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* [contact] */
.success-title{margin-top:1.1rem;font-family:var(--fd);font-size:1.8rem;line-height:1.1}

/* [contact] */
.success-copy{margin-top:.7rem;font-size:1rem;color:var(--ink-soft);line-height:1.8}

/* [services] */
.hero{padding:7.2rem 0 3.8rem;background:var(--ink2);color:#fff}

/* [services] */
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.6rem}

/* [services] */
.subnav{position:sticky;top:84px;z-index:40;background:rgba(255,255,255,.96);border-bottom:1px solid var(--line);backdrop-filter:blur(8px)}

/* [services] */
.subnav-row{display:flex;gap:.8rem;overflow:auto;padding:.9rem 0}

/* [services] */
.subnav-row a{white-space:nowrap;padding:.55rem .9rem;border-radius:999px;border:1px solid transparent;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#625d56}

/* [services] */
.subnav-row a:hover{border-color:var(--line);background:#fff;color:#111}

/* [services] */
.overview-card{border:1px solid var(--line);border-radius:22px;background:#fff;padding:1.45rem;box-shadow:var(--shadow)}

/* [services] */
.service{padding:4rem 0;border-top:1px solid var(--line2)}

/* [services] */
.service:first-of-type{border-top:none}

/* [services] */
.service-head{display:grid;grid-template-columns:.86fr 1.14fr;gap:1.7rem;align-items:start}

/* [services] */
.service-tag{display:inline-flex;align-items:center;gap:.6rem;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--red)}

/* [services] */
.service-tag::before{content:"";width:2rem;height:1px;background:currentColor;display:block}

/* [services] */
.service-title{margin-top:.55rem;font-family:var(--fd);font-size:2.45rem;line-height:1.02}

/* [services] */
.service-summary{font-size:1.12rem;line-height:1.72;color:#4f4942;max-width:920px}

/* [services] */
.service-grid{display:grid;grid-template-columns:1fr 1fr .95fr;gap:1.15rem;margin-top:1.7rem;align-items:stretch}

/* [services] */
.panel{border:1px solid var(--line);border-radius:22px;background:#fff;padding:1.55rem}

/* [services] */
.panel h4{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:#6f685f;font-weight:700}

/* [services] */
.panel ul{list-style:none;margin-top:1rem}

/* [services] */
.panel li{display:flex;gap:.55rem;margin:.7rem 0;font-size:1rem;line-height:1.75;color:#4b453f}

/* [services] */
.panel li::before{content:"›";color:var(--red);font-weight:700}

/* [services] */
.outcome-title{margin-top:1.05rem;font-family:var(--fd);font-size:2.15rem;line-height:1.12;font-weight:700}

/* [services] */
.service-footer{display:flex;justify-content:flex-end;margin-top:1.35rem}

/* [services] */
.cta-band{padding:4.2rem 0;background:var(--paper-soft);border-top:1px solid var(--line)}

/* [insights] */
.insight-card{border:1px solid var(--line);border-radius:22px;background:#fff;padding:1.55rem;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:box-shadow .2s ease,transform .2s ease}

/* [insights] */
.insight-card:hover{box-shadow:0 20px 50px rgba(15,15,15,.1);transform:translateY(-2px)}

/* [insights] */
/* Divider tag */
.tag{display:inline-block;padding:.25rem .75rem;border-radius:999px;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600}

/* [insights] */
.tag-red{background:#fdf0ef;color:var(--red);border:1px solid #f5d4d2}

/* [insights] */
.tag-navy{background:#edf0f6;color:var(--navy);border:1px solid #cdd5e8}

/* [insights] */
.tag-green{background:#f3f6e8;color:#4a6b1a;border:1px solid #d5e2a8}

/* [insights] */
/* Full-page insight reader */
.reader-panel{display:none;position:fixed;inset:0;z-index:100;background:#fff;overflow-y:auto}

/* [insights] */
.reader-panel.open{display:block}

/* [insights] */
.reader-topbar{position:sticky;top:0;z-index:10;background:rgba(255,255,255,.96);border-bottom:1px solid var(--line-2);backdrop-filter:blur(8px);padding:.85rem 0}

/* [insights] */
.reader-topbar-inner{max-width:780px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}

/* [insights] */
.reader-back{display:inline-flex;align-items:center;gap:.5rem;font-size:.76rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);background:none;border:1px solid var(--line);border-radius:999px;padding:.45rem 1rem;cursor:pointer;transition:all .2s ease}

/* [insights] */
.reader-back:hover{border-color:var(--ink);color:var(--ink)}

/* [insights] */
.reader-back svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}

/* [insights] */
.reader-actions{display:flex;gap:.6rem;align-items:center}

/* [insights] */
.reader-print{display:inline-flex;align-items:center;gap:.45rem;font-size:.73rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);background:none;border:1px solid var(--line);border-radius:999px;padding:.45rem 1rem;cursor:pointer;transition:all .2s ease}

/* [insights] */
.reader-print:hover{border-color:var(--navy);color:var(--navy)}

/* [insights] */
.reader-print svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* [insights] */
.reader-content{max-width:780px;margin:0 auto;padding:3.5rem 2rem 6rem}

/* [insights] */
.reader-kicker{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#7d776f}

/* [insights] */
.reader-title{margin-top:.7rem;font-family:var(--fd);font-size:clamp(2rem,5vw,3.4rem);font-weight:600;line-height:1.04;letter-spacing:-.02em}

/* [insights] */
.reader-lead{margin-top:1rem;font-size:1.12rem;line-height:1.88;color:#3a3530;font-weight:500;border-left:3px solid var(--red);padding-left:1.1rem}

/* [insights] */
.reader-divider{margin:2rem 0;border:none;border-top:1px solid var(--line-2)}

/* [insights] */
.reader-body p{font-size:1.04rem;line-height:1.96;color:#4a4540;margin-top:1.2rem}

/* [insights] */
.reader-body p:first-child{margin-top:0}

/* [insights] */
.reader-cta{margin-top:3rem;padding:2rem;background:var(--paper-soft);border:1px solid var(--line-2);border-radius:20px}

/* [insights] */
.reader-cta-title{font-family:var(--fd);font-size:1.5rem;line-height:1.1}

/* [insights] */
.reader-cta-copy{margin-top:.5rem;font-size:.96rem;color:var(--ink-soft)}

/* [insights] */
.reader-cta-actions{margin-top:1.2rem;display:flex;gap:.75rem;flex-wrap:wrap}

/* [insights] */
@media print{
  .reader-topbar{display:none}
  .reader-content{padding:1rem 0}
  .reader-cta{display:none}
}
/* ═══ WordPress compatibility fixes ═══ */

/* Prevent WP default styles from breaking our layouts */
.entry-content img, .wp-block-image img { max-width: 100%; }

/* Portrait/bio photo — constrain in grid */
.portrait-photo { max-width: 100%; }
.portrait-photo img { width: 100%; height: auto; max-height: 600px; object-fit: cover; object-position: center top; filter: grayscale(100%); }

/* Team photo */
.team-photo img { width: 100%; height: auto; filter: grayscale(100%); }

/* Bio grid — enforce 2-column layout */
.bio-grid { display: grid !important; grid-template-columns: 1fr 1.6fr !important; gap: 3rem; align-items: start; margin-top: 2.5rem; }

/* Contact grid — enforce 2-column layout */
.contact-grid { display: grid !important; grid-template-columns: 1fr 1.6fr !important; gap: 3.5rem; align-items: start; }

/* Services subnav — fix display */
.subnav { position: sticky; top: 84px; z-index: 40; background: rgba(255,255,255,.96); border-bottom: 1px solid var(--line); backdrop-filter: blur(8px); }
.subnav-row { display: flex !important; gap: .8rem; overflow: auto; padding: .9rem 0; }
.subnav-row a { white-space: nowrap; padding: .55rem .9rem; border-radius: 999px; border: 1px solid transparent; font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: #625d56; text-decoration: none; }
.subnav-row a:hover { border-color: var(--line); background: #fff; color: #111; }

/* Remove WP's default margins on paragraphs inside our components */
.bio-text p { margin-top: .9rem !important; margin-bottom: 0 !important; }
.card-copy p { margin: 0 !important; }

/* Fix form card rendering */
.form-card { border: 1px solid var(--line) !important; border-radius: 24px !important; padding: 2.2rem !important; }
.form-input, .form-select, .form-textarea { width: 100% !important; padding: .75rem 1rem !important; border: 1px solid var(--line) !important; border-radius: 12px !important; font-family: var(--fb) !important; font-size: .97rem !important; box-sizing: border-box !important; }

@media (max-width: 1180px) {
  .bio-grid { grid-template-columns: 1fr !important; }
  .contact-grid { grid-template-columns: 1fr !important; }
}


/* mix-blend-mode: screen makes black transparent on dark surfaces */
.site-header .logo {
  mix-blend-mode: screen;
  height: 48px !important;
  width: auto !important;
}

/* Footer logo — dark bg blends on white, show colored version */
.footer .logo,
footer img[alt="TRISSA"] {
  mix-blend-mode: multiply;
  height: auto !important;
  max-height: 56px !important;
  width: auto !important;
  max-width: 200px !important;
}

/* ═══ Subnav fixes — override WP defaults ═══ */
div.subnav {
  display: block !important;
  position: sticky !important;
  top: 84px !important;
  z-index: 40 !important;
  background: rgba(255,255,255,.96) !important;
  border-bottom: 1px solid var(--line) !important;
  width: 100% !important;
}

div.subnav-row,
.subnav .container {
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: .8rem !important;
  overflow-x: auto !important;
  padding: .9rem 2rem !important;
  list-style: none !important;
}

.subnav-row a,
div.subnav a {
  display: inline-flex !important;
  white-space: nowrap !important;
  padding: .55rem .9rem !important;
  border-radius: 999px !important;
  border: 1px solid transparent !important;
  font-size: .72rem !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  color: #625d56 !important;
  text-decoration: none !important;
  font-family: var(--fb) !important;
}

.subnav-row a:hover,
div.subnav a:hover {
  border-color: var(--line) !important;
  background: #fff !important;
  color: #111 !important;
}

/* ═══ Hero top padding fix — WP adds extra padding ═══ */
.hero-dark, .hero-contact, .hero {
  padding-top: 7.2rem !important;
}

/* ═══ WP content wrappers — prevent extra padding ═══ */
.site-content, .entry-content, .page-content,
.wp-site-blocks, .is-layout-flow {
  padding: 0 !important;
  margin: 0 !important;
  max-width: none !important;
}

/* Remove WP default title that shows above our template */
.entry-header, .page-header {
  display: none !important;
}

/* ═══ Hero consistency — all pages use dark hero ═══ */
.hero-dark, .hero, .hero-contact {
  padding: 7.2rem 0 4rem !important;
  background: var(--ink) !important;
  color: #fff !important;
}
.hero-dark .display,
.hero .display,
.hero-contact .display {
  color: #fff !important;
}
.hero-dark .lead,
.hero .lead,
.hero-contact .lead {
  color: rgba(255,255,255,0.72) !important;
}
.hero-dark .eyebrow.dark,
.hero .eyebrow,
.hero-contact .eyebrow.dark {
  color: rgba(255,255,255,0.48) !important;
}



.site-header .logo {
  height: 48px !important;
  width: auto !important;
  filter: brightness(0) invert(1) !important;
}
footer img[alt="TRISSA"] {
  height: auto !important;
  max-height: 56px !important;
  width: auto !important;
  max-width: 200px !important;
  filter: none !important;
}

/* ═══ Logo ═══ */
.site-header .logo {
  height: 44px !important;
  width: auto !important;
  filter: none !important;
  mix-blend-mode: normal !important;
}
footer img[alt="TRISSA"] {
  height: auto !important;
  max-height: 52px !important;
  width: auto !important;
  max-width: 180px !important;
  filter: none !important;
  mix-blend-mode: normal !important;
}


/* ═══ TRISSA CSS Fixes — agregar al final de trissa.css ═══ */

@media (max-width: 900px) {

  /* Footer — menú en columna vertical */
  .footer-nav {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.6rem !important;
  }
  .footer-grid {
    grid-template-columns: 1fr !important;
    gap: 2rem;
  }

  /* Services — service-head de 2 a 1 columna */
  .service-head {
    grid-template-columns: 1fr !important;
    gap: 0.75rem;
  }

  /* Services — service-grid de 3 a 1 columna */
  .service-grid {
    grid-template-columns: 1fr !important;
    gap: 1rem;
  }

  /* Services — títulos más pequeños en móvil */
  .service-title {
    font-size: 1.8rem !important;
  }
  .outcome-title {
    font-size: 1.45rem !important;
    line-height: 1.3 !important;
  }

}