/* =====================================================================
   Reliance Corporate Advisors — Redesign Stylesheet
   Premium international law-firm aesthetic, refined maroon/navy palette
   ===================================================================== */

:root{
  /* Brand anchors (refined) */
  --maroon:#6a0f12;        /* primary brand anchor */
  --maroon-deep:#4d090c;   /* darker maroon for depth */
  --maroon-tint:#f4e9e7;   /* soft maroon wash */
  --navy:#14233a;          /* authoritative secondary */
  --navy-deep:#0c1726;
  --brass:#b08d57;         /* premium accent */
  --brass-soft:#caa873;

  /* Warm neutrals */
  --ivory:#faf7f2;
  --paper:#ffffff;
  --sand:#efe9df;
  --sand-line:#e3dccf;

  /* Text */
  --ink:#1b1b1b;
  --ink-soft:#54514c;
  --ink-mute:#8a857d;
  --on-dark:#f3efe8;
  --on-dark-mute:#b9b2a6;

  --maxw:1200px;
  --gutter:clamp(20px,5vw,64px);
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --shadow:0 18px 50px -28px rgba(20,35,58,.35);
  --radius:2px;
  --t:.35s cubic-bezier(.2,.7,.3,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--ivory);
  font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--maroon);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--maroon-deep)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;color:var(--navy);line-height:1.12;margin:0 0 .5em}
h1{font-size:clamp(2.3rem,5.2vw,4.1rem);letter-spacing:-.01em}
h2{font-size:clamp(1.8rem,3.6vw,2.9rem)}
h3{font-size:clamp(1.3rem,2.4vw,1.7rem)}
p{margin:0 0 1.1em}
.container{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.eyebrow{font-family:var(--sans);font-weight:600;font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--brass);margin:0 0 1rem}
.lede{font-size:1.18rem;color:var(--ink-soft);max-width:62ch}
.center{text-align:center}.center .lede{margin-inline:auto}
section{padding-block:clamp(56px,8vw,110px)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--sans);font-weight:600;
  font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;padding:.95rem 1.8rem;
  border:1px solid var(--maroon);background:var(--maroon);color:#fff;cursor:pointer;
  border-radius:var(--radius);transition:all var(--t)}
.btn:hover{background:var(--maroon-deep);border-color:var(--maroon-deep);color:#fff;transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--navy);border-color:var(--sand-line)}
.btn--ghost:hover{background:var(--navy);border-color:var(--navy);color:#fff}
.btn--light{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn--light:hover{background:#fff;color:var(--navy);border-color:#fff}
.btn .arr{transition:transform var(--t)}.btn:hover .arr{transform:translateX(4px)}

/* ---------- Top bar / Header ---------- */
.topbar{background:var(--navy-deep);color:var(--on-dark-mute);font-size:.78rem;letter-spacing:.03em}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding-block:.5rem;flex-wrap:wrap}
.topbar a{color:var(--on-dark-mute)}.topbar a:hover{color:#fff}
.topbar .tb-right{display:flex;gap:1.4rem;align-items:center}
.tb-portal{color:var(--brass-soft);font-weight:600}

.site-header{position:sticky;top:0;z-index:60;background:rgba(250,247,242,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--sand-line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding-block:.85rem}
.brand img{height:46px;width:auto}
.nav-links{display:flex;align-items:center;gap:1.7rem;list-style:none;margin:0;padding:0}
.nav-links>li{position:relative}
.nav-links a{font-family:var(--sans);font-weight:500;font-size:.92rem;color:var(--navy);
  letter-spacing:.01em;padding-block:1.2rem;display:inline-flex;align-items:center;gap:.3rem}
.nav-links a:hover{color:var(--maroon)}
.nav-links .has-menu>a::after{content:"";width:6px;height:6px;border-right:1.5px solid currentColor;
  border-bottom:1.5px solid currentColor;transform:rotate(45deg) translateY(-2px);opacity:.6}
.dropdown{position:absolute;top:100%;left:-1rem;min-width:290px;background:var(--paper);
  border:1px solid var(--sand-line);box-shadow:var(--shadow);padding:.6rem;opacity:0;visibility:hidden;
  transform:translateY(8px);transition:all var(--t)}
.nav-links li:hover>.dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:block;padding:.6rem .8rem;font-size:.88rem;border-radius:var(--radius)}
.dropdown a:hover{background:var(--maroon-tint)}
.dropdown .grp{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass);
  padding:.7rem .8rem .3rem;font-weight:700}
.nav-cta{display:inline-flex}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:.4rem}
.burger span{width:26px;height:2px;background:var(--navy);transition:var(--t)}

/* ---------- Hero ---------- */
.hero{position:relative;background:linear-gradient(120deg,var(--navy-deep) 0%,var(--navy) 55%,var(--maroon-deep) 140%);
  color:var(--on-dark);overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 78% 20%,rgba(176,141,87,.16),transparent 45%);}
.hero::after{content:"";position:absolute;right:-6%;top:50%;transform:translateY(-50%);
  width:520px;height:520px;border:1px solid rgba(176,141,87,.22);border-radius:50%;}
.hero .container{position:relative;z-index:2;padding-block:clamp(70px,11vw,140px);max-width:1180px}
.hero h1{color:#fff;max-width:16ch}
.hero h1 em{font-style:italic;color:var(--brass-soft)}
.hero .lede{color:var(--on-dark-mute);font-size:1.25rem;max-width:54ch;margin-block:1.5rem 2.3rem}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}
.hero-meta{display:flex;gap:2.4rem;margin-top:3.4rem;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.12);padding-top:1.8rem}
.hero-meta .num{font-family:var(--serif);font-size:2.4rem;color:var(--brass-soft);line-height:1}
.hero-meta span{display:block;font-size:.8rem;letter-spacing:.06em;color:var(--on-dark-mute);margin-top:.4rem}

/* ---------- Trust / credentials strip ---------- */
.trust{background:var(--paper);border-bottom:1px solid var(--sand-line)}
.trust .container{display:flex;align-items:center;justify-content:center;gap:clamp(1.5rem,5vw,4rem);
  flex-wrap:wrap;padding-block:1.8rem}
.trust .label{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);font-weight:600}
.trust img{height:54px;width:auto;filter:grayscale(1);opacity:.72;transition:var(--t)}
.trust img:hover{filter:grayscale(0);opacity:1}

/* ---------- Generic layout helpers ---------- */
.grid{display:grid;gap:clamp(1.4rem,3vw,2.4rem)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.bg-paper{background:var(--paper)}
.bg-sand{background:var(--sand)}
.bg-navy{background:var(--navy);color:var(--on-dark)}
.bg-navy h2,.bg-navy h3{color:#fff}
.bg-maroon{background:var(--maroon-deep);color:var(--on-dark)}
.bg-maroon h2{color:#fff}
.section-head{max-width:64ch;margin-bottom:clamp(2rem,4vw,3.2rem)}
.section-head.center{margin-inline:auto}

/* ---------- Service / practice cards ---------- */
.pcard{background:var(--paper);border:1px solid var(--sand-line);padding:2rem 1.9rem;
  display:flex;flex-direction:column;height:100%;transition:all var(--t);position:relative;overflow:hidden}
.pcard::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--maroon);transition:width var(--t)}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--maroon-tint)}
.pcard:hover::before{width:100%}
.pcard .ico{width:44px;height:44px;margin-bottom:1.1rem;color:var(--maroon)}
.pcard h3{font-size:1.32rem;margin-bottom:.5rem}
.pcard p{font-size:.96rem;color:var(--ink-soft);margin-bottom:1.1rem}
.pcard ul{list-style:none;margin:0 0 1.3rem;padding:0;font-size:.88rem;color:var(--ink-mute)}
.pcard ul li{padding:.18rem 0 .18rem 1.1rem;position:relative}
.pcard ul li::before{content:"";position:absolute;left:0;top:.7rem;width:5px;height:5px;background:var(--brass);border-radius:50%}
.pcard .more{margin-top:auto;font-weight:600;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--maroon);display:inline-flex;align-items:center;gap:.4rem}
.pcard .more .arr{transition:transform var(--t)}.pcard:hover .more .arr{transform:translateX(4px)}

/* ---------- Tabbed expertise (homepage) ---------- */
.tabs{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:2.6rem}
.tab-btn{font-family:var(--sans);font-weight:600;font-size:.85rem;letter-spacing:.04em;padding:.7rem 1.4rem;
  border:1px solid var(--sand-line);background:transparent;color:var(--navy);cursor:pointer;border-radius:40px;transition:var(--t)}
.tab-btn.active,.tab-btn:hover{background:var(--navy);border-color:var(--navy);color:#fff}
.tab-panel{display:none}.tab-panel.active{display:block;animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------- Stats band ---------- */
.stats .container{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.stat .n{font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.6rem);color:var(--brass-soft);line-height:1}
.stat .l{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--on-dark-mute);margin-top:.5rem}

/* ---------- People grid ---------- */
.people-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem}
.person{background:var(--paper);border:1px solid var(--sand-line);transition:var(--t);overflow:hidden}
.person:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.person .ph{aspect-ratio:1/1;background:var(--sand);overflow:hidden}
.person .ph img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:var(--t)}
.person:hover .ph img{transform:scale(1.04)}
.person .body{padding:1.1rem 1.2rem 1.4rem}
.person h3{font-size:1.18rem;margin-bottom:.15rem}
.person .role{font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;color:var(--maroon);font-weight:600;margin-bottom:.6rem}
.person .exp{font-size:.85rem;color:var(--ink-soft);margin:0}
.person .group-label{grid-column:1/-1;font-family:var(--serif);color:var(--navy);font-size:1.5rem;
  border-bottom:1px solid var(--sand-line);padding-bottom:.6rem;margin-top:1.5rem}

/* ---------- Publications ---------- */
.pub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.pub{background:var(--paper);border:1px solid var(--sand-line);overflow:hidden;display:flex;flex-direction:column;transition:var(--t)}
.pub:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.pub .thumb{aspect-ratio:16/10;overflow:hidden;background:var(--sand)}
.pub .thumb img{width:100%;height:100%;object-fit:cover;transition:var(--t)}
.pub:hover .thumb img{transform:scale(1.05)}
.pub .body{padding:1.2rem 1.3rem 1.5rem;display:flex;flex-direction:column;flex:1}
.pub .tag{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass);font-weight:700;margin-bottom:.5rem}
.pub h3{font-size:1.12rem;line-height:1.25;margin-bottom:.8rem}
.pub .more{margin-top:auto;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--maroon)}
.pub-list{columns:2;column-gap:3rem;list-style:none;padding:0;margin:0}
.pub-list li{break-inside:avoid;padding:.55rem 0;border-bottom:1px solid var(--sand-line)}
.pub-list a{font-size:.95rem;color:var(--navy)}.pub-list a:hover{color:var(--maroon)}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(120deg,var(--maroon-deep),var(--maroon));color:#fff;text-align:center}
.cta-band h2{color:#fff;max-width:20ch;margin-inline:auto}
.cta-band p{color:rgba(255,255,255,.85);max-width:54ch;margin-inline:auto}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{background:linear-gradient(120deg,var(--navy-deep),var(--navy));color:#fff;
  padding-block:clamp(54px,8vw,96px);position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-4%;bottom:-40%;width:380px;height:380px;
  border:1px solid rgba(176,141,87,.2);border-radius:50%}
.page-hero h1{color:#fff;position:relative;z-index:1;max-width:20ch}
.page-hero .lede{color:var(--on-dark-mute);position:relative;z-index:1}
.crumbs{font-size:.8rem;color:var(--on-dark-mute);margin-bottom:1.2rem;letter-spacing:.03em;position:relative;z-index:1}
.crumbs a{color:var(--brass-soft)}.crumbs a:hover{color:#fff}

/* ---------- Prose ---------- */
.prose{max-width:760px}
.prose h2{margin-top:2.4rem}
.prose h3{color:var(--maroon);margin-top:1.8rem;font-size:1.4rem}
.prose ul{padding-left:0;list-style:none}
.prose ul li{position:relative;padding:.35rem 0 .35rem 1.6rem}
.prose ul li::before{content:"";position:absolute;left:0;top:.95rem;width:7px;height:7px;background:var(--brass);transform:rotate(45deg)}
.callout{background:var(--maroon-tint);border-left:3px solid var(--maroon);padding:1.4rem 1.6rem;margin:1.8rem 0}
.callout p:last-child{margin:0}

/* sidebar layout for service pages */
.with-aside{display:grid;grid-template-columns:1fr 320px;gap:clamp(2rem,5vw,4rem);align-items:start}
.aside-card{background:var(--paper);border:1px solid var(--sand-line);padding:1.6rem;position:sticky;top:120px}
.aside-card h4{font-family:var(--sans);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);margin-bottom:1rem}
.aside-card ul{list-style:none;padding:0;margin:0 0 1.4rem}
.aside-card ul li{border-bottom:1px solid var(--sand-line)}
.aside-card ul li a{display:block;padding:.6rem 0;font-size:.9rem;color:var(--navy)}
.aside-card ul li a:hover{color:var(--maroon);padding-left:.3rem}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem)}
.field{margin-bottom:1.2rem}
.field label{display:block;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;font-weight:600;color:var(--navy);margin-bottom:.4rem}
.field input,.field textarea,.field select{width:100%;padding:.85rem 1rem;border:1px solid var(--sand-line);
  background:var(--paper);font-family:var(--sans);font-size:.96rem;border-radius:var(--radius);transition:var(--t)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--maroon);box-shadow:0 0 0 3px var(--maroon-tint)}
.info-row{display:flex;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--sand-line)}
.info-row .ic{color:var(--maroon);flex-shrink:0}
.info-row strong{display:block;color:var(--navy);font-family:var(--serif);font-size:1.15rem}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-deep);color:var(--on-dark-mute);padding-block:clamp(48px,7vw,80px) 0}
.site-footer h4{font-family:var(--sans);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-soft);margin-bottom:1.1rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.2rem}
.site-footer a{color:var(--on-dark-mute);font-size:.92rem}.site-footer a:hover{color:#fff}
.site-footer ul{list-style:none;padding:0;margin:0}.site-footer ul li{padding:.32rem 0}
.footer-brand img{height:48px;margin-bottom:1.2rem;filter:brightness(0) invert(1);opacity:.92}
.footer-brand p{font-size:.9rem;max-width:34ch}
.socials{display:flex;gap:.8rem;margin-top:1.2rem}
.socials a{width:38px;height:38px;border:1px solid rgba(255,255,255,.18);display:grid;place-items:center;border-radius:50%}
.socials a:hover{background:var(--maroon);border-color:var(--maroon)}
.socials svg{width:17px;height:17px;fill:currentColor}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:2.8rem;padding-block:1.5rem;
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.82rem}
.footer-bottom a{margin-left:1.2rem}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .cols-4{grid-template-columns:repeat(2,1fr)}
  .cols-3{grid-template-columns:repeat(2,1fr)}
  .people-grid{grid-template-columns:repeat(2,1fr)}
  .pub-grid{grid-template-columns:repeat(2,1fr)}
  .stats .container{grid-template-columns:repeat(2,1fr);gap:2.4rem}
  .split,.with-aside,.contact-grid{grid-template-columns:1fr}
  .aside-card{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
  .pub-list{columns:1}
}
@media(max-width:760px){
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(82vw,360px);background:var(--paper);
    flex-direction:column;align-items:flex-start;gap:0;padding:5rem 1.6rem 2rem;
    transform:translateX(100%);transition:transform var(--t);box-shadow:var(--shadow);overflow-y:auto}
  .nav-links.open{transform:translateX(0)}
  .nav-links>li{width:100%;border-bottom:1px solid var(--sand-line)}
  .nav-links a{padding-block:.95rem;width:100%}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;
    min-width:0;padding:0 0 .6rem 1rem;display:none}
  .nav-links li.show-sub>.dropdown{display:block}
  .burger{display:flex}
  .nav-cta{display:none}
  .cols-2,.cols-3,.cols-4,.people-grid,.pub-grid{grid-template-columns:1fr}
  .stats .container{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  body{font-size:16px}
}

/* =====================================================================
   APPLE-STYLE HOMEPAGE (light theme) — scoped to .ap-* classes
   Huge centered type · full-bleed imagery · bento · scroll reveals
   ===================================================================== */
:root{
  --ap-bg:#ffffff;
  --ap-bg2:#f5f5f7;      /* Apple section grey */
  --ap-ink:#1d1d1f;      /* Apple near-black */
  --ap-ink2:#6e6e73;     /* Apple secondary grey */
  --ap-line:#d2d2d7;
  --ap-accent:#6a0f12;   /* RCA maroon */
  --ap-accent2:#9b6a2f;  /* brass */
  --ap-rad:22px;
  --ap-rad-lg:30px;
}
.ap{background:var(--ap-bg);color:var(--ap-ink);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  -webkit-font-smoothing:antialiased;line-height:1.5}
.ap *{box-sizing:border-box}
.ap-wrap{max-width:1024px;margin:0 auto;padding-inline:22px}
.ap-wrap--wide{max-width:1200px}
.ap h1,.ap h2,.ap h3{font-family:inherit;color:var(--ap-ink);font-weight:600;letter-spacing:-.02em;line-height:1.05;margin:0}
.ap-section{padding-block:clamp(64px,11vw,130px)}
.ap-bg2{background:var(--ap-bg2)}
.ap-center{text-align:center}
.ap-accent{color:var(--ap-accent)}
.ap-link{color:var(--ap-accent);font-weight:500;font-size:1.18rem;display:inline-flex;align-items:center;gap:.25rem}
.ap-link::after{content:"›";font-size:1.25em;line-height:0;transition:transform .3s}
.ap-link:hover{color:var(--ap-accent)}.ap-link:hover::after{transform:translateX(3px)}
.ap-pill{display:inline-flex;align-items:center;gap:.5rem;background:var(--ap-accent);color:#fff;
  font-weight:500;font-size:1.05rem;padding:.7rem 1.5rem;border-radius:980px;transition:opacity .3s}
.ap-pill:hover{opacity:.85;color:#fff}
.ap-pill--ghost{background:transparent;color:var(--ap-accent);border:1px solid var(--ap-accent)}
.ap-pill--ghost:hover{background:var(--ap-accent);color:#fff;opacity:1}

/* Chapter sticky sub-nav (Apple local nav) */
.ap-subnav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);
  backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--ap-line)}
.ap-subnav .row{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:52px}
.ap-subnav .title{font-weight:600;font-size:1.18rem;letter-spacing:-.01em}
.ap-subnav nav{display:flex;gap:1.6rem;overflow-x:auto;scrollbar-width:none}
.ap-subnav nav::-webkit-scrollbar{display:none}
.ap-subnav a{color:var(--ap-ink2);font-size:.86rem;font-weight:400;white-space:nowrap;padding:.2rem 0;border-bottom:2px solid transparent}
.ap-subnav a:hover{color:var(--ap-ink)}
.ap-subnav a.active{color:var(--ap-ink);font-weight:500;border-bottom-color:var(--ap-accent)}
.ap-subnav .cta{background:var(--ap-accent);color:#fff;padding:.4rem 1rem;border-radius:980px;font-size:.84rem;font-weight:500}
.ap-subnav .cta:hover{color:#fff;opacity:.85}

/* HERO */
.ap-hero{background:var(--ap-bg);text-align:center;padding-top:clamp(40px,7vw,72px);overflow:hidden}
.ap-eyebrow{color:var(--ap-accent);font-weight:600;font-size:1.25rem;letter-spacing:-.01em;margin-bottom:.4rem}
.ap-hero h1{font-size:clamp(3.2rem,9vw,7rem);font-weight:600;letter-spacing:-.03em}
.ap-hero h1 .thin{font-weight:600;background:linear-gradient(120deg,var(--ap-accent),var(--ap-accent2));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.ap-hero .sub{font-size:clamp(1.3rem,3vw,1.9rem);color:var(--ap-ink2);max-width:24ch;margin:1rem auto 1.4rem;font-weight:400;letter-spacing:-.01em}
.ap-hero .links{display:flex;gap:1.6rem;justify-content:center;flex-wrap:wrap;margin-bottom:2.5rem}
.ap-hero-media{max-width:1100px;margin:0 auto;border-radius:var(--ap-rad-lg);overflow:hidden;
  box-shadow:0 30px 80px -40px rgba(0,0,0,.4);position:relative}
.ap-hero-media img{width:100%;display:block}
.ap-hero-badges{display:flex;gap:clamp(1.4rem,4vw,3rem);justify-content:center;align-items:center;flex-wrap:wrap;margin-top:2.6rem}
.ap-hero-badges img{height:46px;filter:grayscale(1);opacity:.6;transition:.3s}
.ap-hero-badges img:hover{filter:none;opacity:1}
.ap-hero-badges .b500{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ap-ink2);border:1px solid var(--ap-line);padding:.5rem .9rem;border-radius:6px}

/* Big typographic statement */
.ap-statement{text-align:center}
.ap-statement h2{font-size:clamp(2rem,5.5vw,4rem);font-weight:600;letter-spacing:-.025em;max-width:18ch;margin:0 auto}
.ap-statement .muted{color:var(--ap-ink2)}
.ap-statement p{font-size:clamp(1.15rem,2.2vw,1.5rem);color:var(--ap-ink2);max-width:60ch;margin:1.6rem auto 0;font-weight:400}

/* Highlights row */
.ap-highlights{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center;margin-top:3rem}
.ap-hi .ic{font-size:2rem;color:var(--ap-accent);margin-bottom:.5rem}
.ap-hi .n{font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:600;letter-spacing:-.02em;color:var(--ap-ink)}
.ap-hi .l{font-size:.98rem;color:var(--ap-ink2);margin-top:.3rem}

/* Bento grid */
.ap-bento{display:grid;grid-template-columns:repeat(6,1fr);gap:18px;grid-auto-rows:minmax(180px,auto)}
.ap-tile{background:var(--ap-bg2);border-radius:var(--ap-rad);padding:1.8rem;display:flex;flex-direction:column;
  justify-content:flex-end;color:var(--ap-ink);transition:transform .4s cubic-bezier(.2,.7,.3,1)}
.ap-tile:hover{transform:translateY(-5px);color:var(--ap-ink)}
.ap-tile .cat{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ap-accent);font-weight:600;margin-bottom:.5rem}
.ap-tile h3{font-size:clamp(1.3rem,2vw,1.7rem);font-weight:600;letter-spacing:-.02em;margin-bottom:.4rem}
.ap-tile p{font-size:.98rem;color:var(--ap-ink2);margin:0}
.ap-tile .ti{font-size:1.7rem;color:var(--ap-accent);margin-bottom:auto}
.ap-tile.span-3{grid-column:span 3}
.ap-tile.span-2{grid-column:span 2}
.ap-tile.span-4{grid-column:span 4}
.ap-tile.dark{background:#1d1d1f;color:#f5f5f7}
.ap-tile.dark h3{color:#fff}.ap-tile.dark p{color:#a1a1a6}.ap-tile.dark .cat{color:var(--ap-accent2)}
.ap-tile.maroon{background:linear-gradient(150deg,#6a0f12,#3c0809);color:#fff}
.ap-tile.maroon h3{color:#fff}.ap-tile.maroon p{color:#e9cfcf}.ap-tile.maroon .cat,.ap-tile.maroon .ti{color:#e7b98a}

/* Full-bleed feature */
.ap-feature{text-align:center;padding-block:clamp(60px,9vw,110px)}
.ap-feature .cat{color:var(--ap-accent);font-weight:600;font-size:1.1rem;margin-bottom:.6rem}
.ap-feature h2{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:600;letter-spacing:-.025em;max-width:16ch;margin:0 auto .9rem}
.ap-feature p{font-size:clamp(1.1rem,2vw,1.35rem);color:var(--ap-ink2);max-width:54ch;margin:0 auto 1.4rem}
.ap-feature .media{max-width:980px;margin:2.6rem auto 0;border-radius:var(--ap-rad-lg);overflow:hidden;box-shadow:0 30px 80px -45px rgba(0,0,0,.45)}
.ap-feature .media img{width:100%;display:block}

/* Stats huge type */
.ap-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.ap-stat .n{font-size:clamp(2.6rem,6vw,4.4rem);font-weight:600;letter-spacing:-.03em;
  background:linear-gradient(120deg,var(--ap-accent),var(--ap-accent2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.ap-stat .l{font-size:1rem;color:var(--ap-ink2);margin-top:.4rem}

/* People row */
.ap-people{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.ap-pp{background:var(--ap-bg);border-radius:var(--ap-rad);overflow:hidden;transition:transform .4s}
.ap-pp:hover{transform:translateY(-5px)}
.ap-pp .ph{aspect-ratio:1/1;background:var(--ap-bg2);overflow:hidden}
.ap-pp .ph img{width:100%;height:100%;object-fit:cover;object-position:top center}
.ap-pp .bd{padding:1.1rem 1.2rem 1.4rem}
.ap-pp h3{font-size:1.18rem;font-weight:600;letter-spacing:-.01em}
.ap-pp .role{font-size:.82rem;color:var(--ap-accent);font-weight:500;margin-top:.2rem}

/* Insights cards */
.ap-ins{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.ap-ic{background:var(--ap-bg);border-radius:var(--ap-rad);overflow:hidden;transition:transform .4s;display:flex;flex-direction:column}
.ap-ic:hover{transform:translateY(-5px)}
.ap-ic .th{aspect-ratio:16/10;overflow:hidden;background:var(--ap-bg2)}
.ap-ic .th img{width:100%;height:100%;object-fit:cover;transition:.5s}.ap-ic:hover .th img{transform:scale(1.04)}
.ap-ic .bd{padding:1.2rem 1.3rem 1.5rem;display:flex;flex-direction:column;flex:1}
.ap-ic .tag{font-size:.7rem;letter-spacing:.13em;text-transform:uppercase;color:var(--ap-accent);font-weight:600;margin-bottom:.5rem}
.ap-ic h3{font-size:1.12rem;font-weight:600;letter-spacing:-.01em;line-height:1.25;color:var(--ap-ink)}
.ap-ic .more{margin-top:auto;padding-top:.9rem;color:var(--ap-accent);font-weight:500;font-size:.95rem}

/* Closing CTA */
.ap-cta{text-align:center;background:var(--ap-bg2)}
.ap-cta h2{font-size:clamp(2.2rem,5.5vw,4rem);font-weight:600;letter-spacing:-.03em;max-width:16ch;margin:0 auto .8rem}
.ap-cta p{font-size:clamp(1.1rem,2vw,1.35rem);color:var(--ap-ink2);max-width:50ch;margin:0 auto 2rem}
.ap-cta .links{display:flex;gap:1.4rem;justify-content:center;flex-wrap:wrap}

/* Reveal */
.ap-rev{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.2,.7,.3,1),transform .8s cubic-bezier(.2,.7,.3,1)}
.ap-rev.in{opacity:1;transform:none}

@media(max-width:900px){
  .ap-highlights{grid-template-columns:repeat(2,1fr);gap:2.4rem}
  .ap-bento{grid-template-columns:repeat(2,1fr)}
  .ap-tile.span-3,.ap-tile.span-2,.ap-tile.span-4{grid-column:span 1}
  .ap-stats{grid-template-columns:repeat(2,1fr);gap:2.6rem}
  .ap-people{grid-template-columns:repeat(2,1fr)}
  .ap-ins{grid-template-columns:1fr}
  .ap-subnav .title{display:none}
}
@media(max-width:560px){
  .ap-highlights,.ap-stats,.ap-people{grid-template-columns:1fr 1fr}
  .ap-bento{grid-template-columns:1fr}
}

/* =====================================================================
   A&O SHEARMAN-STYLE HOMEPAGE  (.ao-* scoped) — editorial, white base,
   signature red accent, oversized grotesque type, full-bleed motion hero
   ===================================================================== */
:root{
  --ao-bg:#ffffff; --ao-grey:#f4f3f1; --ao-ink:#161616; --ao-mute:#6c6c6c;
  --ao-line:#e4e2de; --ao-red:#c1121f; --ao-maroon:#6a0f12; --ao-dark:#0e0e10;
}
.ao{background:var(--ao-bg);color:var(--ao-ink);
  font-family:'Archivo','Inter',-apple-system,BlinkMacSystemFont,sans-serif;-webkit-font-smoothing:antialiased}
.ao *{box-sizing:border-box}
.ao-wrap{max-width:1280px;margin:0 auto;padding-inline:clamp(20px,4vw,56px)}
.ao h1,.ao h2,.ao h3{font-family:'Archivo','Inter',sans-serif;font-weight:700;color:var(--ao-ink);
  letter-spacing:-.02em;line-height:1.02;margin:0}
.ao-kicker{font-size:.74rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--ao-red)}
.ao-kicker.on-dark{color:#ff5b4d}
.ao-sec{padding-block:clamp(70px,10vw,140px)}
.ao-grey{background:var(--ao-grey)}
.ao-dark{background:var(--ao-dark);color:#f2f1ef}
.ao-dark h2,.ao-dark h3{color:#fff}

/* buttons / links */
.ao-btn{display:inline-flex;align-items:center;gap:.6rem;font-family:'Inter',sans-serif;font-weight:600;
  font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;padding:1rem 1.9rem;background:var(--ao-red);
  color:#fff;border:1px solid var(--ao-red);transition:.3s}
.ao-btn:hover{background:#9d0e18;border-color:#9d0e18;color:#fff}
.ao-btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.ao-btn--ghost:hover{background:#fff;color:var(--ao-ink);border-color:#fff}
.ao-btn--dark{background:var(--ao-ink);border-color:var(--ao-ink);color:#fff}
.ao-btn--dark:hover{background:var(--ao-red);border-color:var(--ao-red)}
.ao-tlink{font-family:'Inter',sans-serif;font-weight:600;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ao-ink);display:inline-flex;align-items:center;gap:.5rem}
.ao-tlink::after{content:"→";color:var(--ao-red);transition:transform .3s}
.ao-tlink:hover{color:var(--ao-red)}.ao-tlink:hover::after{transform:translateX(5px)}
.ao-tlink.on-dark{color:#fff}.ao-tlink.on-dark:hover{color:#ff5b4d}

/* HERO — full-bleed video */
.ao-hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;overflow:hidden;background:#0a0a0c}
.ao-hero video,.ao-hero .fallback{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.ao-hero .fallback{background:linear-gradient(120deg,#0e0e10,#2a0a0c 60%,#6a0f12 140%)}
.ao-hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(8,6,8,.55) 0%,rgba(8,6,8,.32) 38%,rgba(8,6,8,.9) 100%),
             linear-gradient(90deg,rgba(8,6,8,.6) 0%,rgba(8,6,8,.12) 55%,transparent 100%)}
.ao-hero .ao-wrap{position:relative;z-index:2;width:100%;padding-block:clamp(48px,8vw,96px)}
.ao-hero .bar{width:54px;height:4px;background:var(--ao-red);margin-bottom:1.6rem}
.ao-hero h1{color:#fff;font-size:clamp(2.8rem,7.5vw,6.4rem);font-weight:700;letter-spacing:-.03em;max-width:16ch}
.ao-hero h1 .swap{color:#ff5b4d;display:inline-block}
.ao-hero .sub{color:rgba(255,255,255,.82);font-family:'Inter',sans-serif;font-size:clamp(1.05rem,1.8vw,1.4rem);
  max-width:52ch;margin:1.4rem 0 2.2rem;font-weight:400;line-height:1.55}
.ao-hero .cta{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}
.ao-scroll{position:absolute;right:clamp(20px,4vw,56px);bottom:2rem;z-index:2;color:rgba(255,255,255,.7);
  font-family:'Inter',sans-serif;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  writing-mode:vertical-rl;display:flex;align-items:center;gap:.8rem}
.ao-scroll::after{content:"";width:1px;height:46px;background:rgba(255,255,255,.5);animation:aoScroll 1.8s infinite}
@keyframes aoScroll{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* big editorial statement */
.ao-statement h2{font-size:clamp(1.9rem,4.6vw,3.6rem);font-weight:700;letter-spacing:-.025em;max-width:20ch;line-height:1.08}
.ao-statement .red{color:var(--ao-red)}
.ao-statement .mute{color:var(--ao-mute)}
.ao-statement .row{display:grid;grid-template-columns:1fr;gap:2rem;align-items:end}
.ao-statement p{font-family:'Inter',sans-serif;font-size:1.12rem;color:var(--ao-mute);max-width:60ch;line-height:1.7;margin:1.6rem 0 0}

/* expertise index (big interactive list) */
.ao-idx-head{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}
.ao-idx-head h2{font-size:clamp(1.6rem,3vw,2.4rem)}
.ao-idx{border-top:1px solid var(--ao-line)}
.ao-row{display:flex;align-items:center;gap:1.4rem;padding:clamp(1.1rem,2.4vw,1.9rem) 0;border-bottom:1px solid var(--ao-line);
  color:var(--ao-ink);transition:padding .35s,color .35s;position:relative}
.ao-row .no{font-family:'Inter',sans-serif;font-size:.78rem;font-weight:600;color:var(--ao-mute);width:2.6rem;flex:none;letter-spacing:.05em}
.ao-row .nm{font-size:clamp(1.5rem,3.6vw,2.7rem);font-weight:700;letter-spacing:-.02em;flex:1}
.ao-row .meta{font-family:'Inter',sans-serif;font-size:.86rem;color:var(--ao-mute);max-width:30ch;display:none}
.ao-row .ar{color:var(--ao-red);font-size:1.4rem;transform:translateX(-6px);opacity:0;transition:.35s}
.ao-row:hover{color:var(--ao-red);padding-left:1.2rem}
.ao-row:hover .ar{opacity:1;transform:translateX(0)}
.ao-row:hover .no{color:var(--ao-red)}
@media(min-width:880px){.ao-row .meta{display:block}}

/* featured insights — asymmetric editorial grid */
.ao-feat{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(16px,2vw,28px)}
.ao-card{position:relative;overflow:hidden;background:var(--ao-grey);color:var(--ao-ink);display:flex;flex-direction:column;min-height:300px}
.ao-card .img{overflow:hidden;flex:1;min-height:200px}
.ao-card .img img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.7,.3,1)}
.ao-card:hover .img img{transform:scale(1.05)}
.ao-card .bd{padding:1.4rem 1.5rem 1.7rem}
.ao-card .tag{font-family:'Inter',sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ao-red);margin-bottom:.6rem;display:block}
.ao-card h3{font-size:clamp(1.15rem,1.8vw,1.5rem);font-weight:700;letter-spacing:-.01em;line-height:1.18}
.ao-card .more{font-family:'Inter',sans-serif;font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ao-ink);margin-top:1rem;display:inline-flex;gap:.4rem}
.ao-card .more::after{content:"→";color:var(--ao-red)}
.ao-card.lg{grid-column:span 6}.ao-card.md{grid-column:span 6}.ao-card.sm{grid-column:span 4}
.ao-card.tall{grid-column:span 6;min-height:520px}
.ao-card.feature{grid-column:span 6;background:var(--ao-dark);color:#fff;justify-content:flex-end}
.ao-card.feature h3{color:#fff;font-size:clamp(1.5rem,2.6vw,2.2rem)}
.ao-card.feature .bd{padding:2rem}
.ao-card.feature .more{color:#fff}

/* stats */
.ao-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.ao-st{border-top:2px solid var(--ao-red);padding-top:1.1rem}
.ao-st .n{font-size:clamp(2.4rem,5vw,4rem);font-weight:700;letter-spacing:-.03em;line-height:1}
.ao-st .l{font-family:'Inter',sans-serif;font-size:.92rem;color:#bdbcbf;margin-top:.6rem}
.ao-dark .ao-st .n{color:#fff}

/* people */
.ao-people{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,26px)}
.ao-pe{position:relative;overflow:hidden;background:var(--ao-grey)}
.ao-pe .ph{aspect-ratio:3/4;overflow:hidden}
.ao-pe .ph img{width:100%;height:100%;object-fit:cover;object-position:top center;filter:grayscale(1);transition:.5s}
.ao-pe:hover .ph img{filter:grayscale(0);transform:scale(1.04)}
.ao-pe .bd{padding:1rem 1.1rem 1.3rem}
.ao-pe h3{font-size:1.15rem;font-weight:700}
.ao-pe .role{font-family:'Inter',sans-serif;font-size:.78rem;color:var(--ao-red);font-weight:600;margin-top:.2rem}

/* closing CTA */
.ao-end{position:relative;overflow:hidden;background:var(--ao-maroon);color:#fff;text-align:left}
.ao-end::before{content:"";position:absolute;right:-8%;top:-30%;width:540px;height:540px;border:1px solid rgba(255,255,255,.14);border-radius:50%}
.ao-end h2{color:#fff;font-size:clamp(2.4rem,6vw,4.6rem);font-weight:700;letter-spacing:-.03em;max-width:14ch;position:relative;z-index:1}
.ao-end p{font-family:'Inter',sans-serif;color:rgba(255,255,255,.82);font-size:1.15rem;max-width:48ch;margin:1.2rem 0 2rem;position:relative;z-index:1}

/* reveal */
.ao-rev{opacity:0;transform:translateY(34px);transition:opacity .8s cubic-bezier(.2,.7,.3,1),transform .8s cubic-bezier(.2,.7,.3,1)}
.ao-rev.in{opacity:1;transform:none}

@media(max-width:880px){
  .ao-feat{grid-template-columns:repeat(6,1fr)}
  .ao-card.lg,.ao-card.md,.ao-card.tall,.ao-card.feature{grid-column:span 6}
  .ao-card.sm{grid-column:span 3}
  .ao-stats{grid-template-columns:repeat(2,1fr);gap:2.4rem}
  .ao-people{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .ao-card.sm{grid-column:span 6}
  .ao-stats,.ao-people{grid-template-columns:1fr 1fr}
  .ao-row .no{width:1.8rem}
}

/* ---------- Publications: filter + uniform cards ---------- */
.pub-filter{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-bottom:2.6rem}
.pub-chip{font-family:var(--sans);font-weight:600;font-size:.82rem;letter-spacing:.02em;padding:.55rem 1.15rem;
  border:1px solid var(--sand-line);background:var(--paper);color:var(--navy);cursor:pointer;border-radius:40px;transition:var(--t)}
.pub-chip:hover{border-color:var(--maroon);color:var(--maroon)}
.pub-chip.active{background:var(--maroon);border-color:var(--maroon);color:#fff}
.pub.is-hidden{display:none}
.pub .thumb.noimg{display:flex;align-items:flex-end;padding:1.2rem;
  background:linear-gradient(150deg,var(--maroon-deep),var(--maroon) 70%,#84161a);position:relative}
.pub .thumb.noimg::before{content:"";position:absolute;right:-30px;top:-30px;width:140px;height:140px;
  border:1px solid rgba(255,255,255,.18);border-radius:50%}
.pub .thumb.noimg .doc{color:rgba(255,255,255,.92);font-family:var(--serif);font-size:1.05rem;line-height:1.25;position:relative;z-index:1}
.pub-count{text-align:center;color:var(--ink-mute);font-size:.9rem;margin-bottom:1.4rem}


/* =====================================================================
   KINN COLLECTIVE-STYLE THEME — warm cream luxury editorial
   Site-wide override (appended = wins) + .kn-* homepage classes
   ===================================================================== */
:root{
  --kn-cream:#f4efe6; --kn-cream2:#ece4d6; --kn-paper:#faf7f0; --kn-ink:#1d1a14;
  --kn-mute:#6f685c; --kn-faint:#9a9384; --kn-line:#ded4c3; --kn-accent:#6a0f12; --kn-gold:#9a7b3f;
  --serif:'Cormorant Garamond',Georgia,serif;
}
body{background:var(--kn-cream);color:var(--kn-ink);font-size:17px}
h1,h2,h3,h4{font-family:var(--serif);color:var(--kn-ink);font-weight:600;letter-spacing:0}
a{color:var(--kn-ink)}a:hover{color:var(--kn-accent)}
.eyebrow{color:var(--kn-gold);letter-spacing:.26em}
.lede{color:var(--kn-mute)}

/* top bar + header */
.topbar{background:#23201a;color:#c8c0b1;border-bottom:0}
.topbar a{color:#c8c0b1}.topbar a:hover{color:#fff}.tb-portal{color:var(--kn-gold)}
.site-header{background:rgba(244,239,230,.9);backdrop-filter:saturate(150%) blur(14px);border-bottom:1px solid var(--kn-line)}
.brand img{filter:none}
.nav-links a{font-family:var(--sans);color:var(--kn-ink);font-weight:500;letter-spacing:.04em;font-size:.82rem;text-transform:uppercase}
.nav-links a:hover{color:var(--kn-accent)}
.dropdown{background:var(--kn-paper);border-color:var(--kn-line)}
.dropdown a{text-transform:none;letter-spacing:0}
.dropdown a:hover{background:var(--kn-cream2)}
.dropdown .grp{color:var(--kn-gold)}
.burger span{background:var(--kn-ink)}
@media(max-width:760px){.nav-links{background:var(--kn-paper)}.nav-links>li{border-color:var(--kn-line)}}

/* buttons — refined */
.btn{background:var(--kn-ink);border-color:var(--kn-ink);color:var(--kn-cream);border-radius:40px;
  font-family:var(--sans);text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;padding:.95rem 1.9rem}
.btn:hover{background:var(--kn-accent);border-color:var(--kn-accent);color:#fff;transform:none}
.btn--ghost{background:transparent;color:var(--kn-ink);border-color:var(--kn-ink)}
.btn--ghost:hover{background:var(--kn-ink);color:var(--kn-cream)}
.btn--light{color:#fff;border-color:rgba(255,255,255,.6);border-radius:40px}
.btn--light:hover{background:#fff;color:var(--kn-ink)}

/* sections */
.bg-paper{background:var(--kn-paper)}
.bg-sand{background:var(--kn-cream2)}
.bg-navy{background:#23201a;color:#efe9dd}
.bg-maroon{background:linear-gradient(140deg,#4d090c,#6a0f12)}
.trust{background:var(--kn-paper);border-color:var(--kn-line)}
.trust .label{color:var(--kn-faint)}
.trust img{filter:grayscale(1);opacity:.55}.trust img:hover{filter:none;opacity:1}
.trust .b500,.b500{color:var(--kn-mute) !important;border-color:var(--kn-line) !important}

/* page hero (inner pages) — light warm */
.page-hero{background:var(--kn-cream2);color:var(--kn-ink)}
.page-hero::after{display:none}
.page-hero h1{color:var(--kn-ink)}
.page-hero .lede{color:var(--kn-mute)}
.crumbs{color:var(--kn-mute)}.crumbs a{color:var(--kn-accent)}

/* cards */
.pcard{background:var(--kn-paper);border-color:var(--kn-line);color:var(--kn-ink)}
.pcard::before{background:var(--kn-accent)}
.pcard:hover{box-shadow:0 22px 50px -34px rgba(40,30,10,.5);border-color:var(--kn-line)}
.pcard p{color:var(--kn-mute)}.pcard ul{color:var(--kn-faint)}.pcard .ico{color:var(--kn-accent)}
.pcard .more,.pcard .tag,.pcard span.tag{color:var(--kn-accent) !important}
.prose{color:var(--kn-ink)}.prose h3{color:var(--kn-accent)}.prose ul li::before{background:var(--kn-gold)}
.callout{background:var(--kn-cream2);border-left:3px solid var(--kn-accent);color:var(--kn-mute)}
.aside-card{background:var(--kn-paper);border-color:var(--kn-line)}
.aside-card h4{color:var(--kn-gold)}.aside-card ul li{border-color:var(--kn-line)}
.aside-card ul li a{color:var(--kn-ink)}.aside-card ul li a:hover{color:var(--kn-accent)}

/* people + publications */
.person{background:var(--kn-paper);border-color:var(--kn-line)}
.person .ph{background:var(--kn-cream2)}
.person h3{color:var(--kn-ink)}.person .role{color:var(--kn-accent)}.person .exp{color:var(--kn-mute)}
.person .ph img{filter:grayscale(.6) sepia(.06)}.person:hover .ph img{filter:none}
.pub{background:var(--kn-paper);border-color:var(--kn-line)}
.pub .thumb{background:var(--kn-cream2)}.pub h3{color:var(--kn-ink)}.pub .tag,.pub .more{color:var(--kn-accent)}
.pub-chip{background:var(--kn-paper);border-color:var(--kn-line);color:var(--kn-ink)}
.pub-chip:hover{border-color:var(--kn-accent);color:var(--kn-accent)}
.pub-chip.active{background:var(--kn-ink);border-color:var(--kn-ink);color:var(--kn-cream)}
.pub-count{color:var(--kn-faint)}

/* forms */
.field label{color:var(--kn-ink)}
.field input,.field textarea,.field select{background:var(--kn-paper);border-color:var(--kn-line);color:var(--kn-ink)}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--kn-accent);box-shadow:0 0 0 3px rgba(106,15,18,.12)}
.info-row{border-color:var(--kn-line)}.info-row strong{color:var(--kn-ink)}.info-row .ic{color:var(--kn-accent)}

/* cta + footer */
.cta-band{background:linear-gradient(140deg,#2a2018,#4d090c 80%,#6a0f12)}
.site-footer{background:#23201a;border-top:0}
.site-footer h4{color:var(--kn-gold)}

/* ---------- KINN homepage classes ---------- */
.kn{background:var(--kn-cream);color:var(--kn-ink)}
.kn-wrap{max-width:1280px;margin:0 auto;padding-inline:clamp(20px,4vw,56px)}
.kn-sec{padding-block:clamp(64px,9vw,128px)}
.kn-kick{font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--kn-gold)}

/* HERO — typographic luxury editorial */
.kn-hero{min-height:92vh;display:flex;flex-direction:column;justify-content:center;position:relative;
  background:radial-gradient(120% 100% at 80% 10%,#efe6d6 0%,var(--kn-cream) 55%)}
.kn-hero .kn-wrap{padding-block:clamp(40px,7vw,90px)}
.kn-hero .bar{width:48px;height:3px;background:var(--kn-accent);margin-bottom:1.6rem}
.kn-hero h1{font-size:clamp(2.6rem,7.2vw,6.2rem);font-weight:600;line-height:1.02;max-width:18ch;letter-spacing:-.01em}
.kn-hero h1 em{font-style:italic;color:var(--kn-accent)}
.kn-hero .sub{font-family:var(--sans);font-size:clamp(1.05rem,1.7vw,1.32rem);color:var(--kn-mute);max-width:54ch;margin:1.6rem 0 2.2rem;line-height:1.6;font-weight:400}
.kn-hero .cta{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}

/* marquee (phrases) */
.kn-marquee{overflow:hidden;white-space:nowrap;border-block:1px solid var(--kn-line);background:var(--kn-paper);padding-block:1.1rem}
.kn-marquee .track{display:inline-flex;gap:0;animation:knMarq 36s linear infinite;will-change:transform}
.kn-marquee:hover .track{animation-play-state:paused}
.kn-marquee .it{font-family:var(--serif);font-size:clamp(1.2rem,2.4vw,1.9rem);color:var(--kn-ink);padding-inline:1.6rem;display:inline-flex;align-items:center;gap:1.6rem}
.kn-marquee .it::after{content:"✦";color:var(--kn-gold);font-size:.7em}
@keyframes knMarq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* logo marquee */
.kn-logos{overflow:hidden;white-space:nowrap;padding-block:.4rem}
.kn-logos .track{display:inline-flex;align-items:center;gap:clamp(2rem,5vw,4.5rem);animation:knMarq 30s linear infinite}
.kn-logos img{height:46px;width:auto;filter:grayscale(1);opacity:.55;transition:.3s}
.kn-logos img:hover{filter:none;opacity:1}
.kn-logos .txt{font-family:var(--serif);font-style:italic;font-size:1.4rem;color:var(--kn-faint)}

/* statement */
.kn-state h2{font-size:clamp(1.8rem,4.4vw,3.4rem);font-weight:600;max-width:24ch;line-height:1.12}
.kn-state .em{font-style:italic;color:var(--kn-accent)}
.kn-state p{font-family:var(--sans);font-size:1.12rem;color:var(--kn-mute);max-width:62ch;margin:1.6rem 0 0;line-height:1.75}

/* selected work — big image cards */
.kn-head{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:1rem;margin-bottom:2.4rem}
.kn-head h2{font-size:clamp(1.8rem,4vw,3rem);font-weight:600}
.kn-work{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.2rem,2.4vw,2rem)}
.kn-tile{position:relative;overflow:hidden;display:block;aspect-ratio:4/3;background:var(--kn-cream2)}
.kn-tile.tall{aspect-ratio:3/4}
.kn-tile img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.3,1)}
.kn-tile:hover img{transform:scale(1.06)}
.kn-tile .cap{position:absolute;inset:auto 0 0 0;padding:1.5rem 1.6rem;color:#fff;z-index:2;
  background:linear-gradient(0deg,rgba(20,15,8,.72),transparent)}
.kn-tile .cap .t{font-family:var(--serif);font-size:clamp(1.3rem,2.2vw,1.9rem);font-weight:600;line-height:1.1}
.kn-tile .cap .s{font-family:var(--sans);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-top:.4rem}

/* quote */
.kn-quote{text-align:center}
.kn-quote blockquote{font-family:var(--serif);font-style:italic;font-size:clamp(1.6rem,3.6vw,2.8rem);
  line-height:1.3;max-width:24ch;margin:0 auto;color:var(--kn-ink);font-weight:500}
.kn-quote .who{font-family:var(--sans);font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--kn-gold);margin-top:1.8rem}

/* reveal */
.kn-rev{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.2,.7,.3,1),transform .8s cubic-bezier(.2,.7,.3,1)}
.kn-rev.in{opacity:1;transform:none}

@media(max-width:760px){
  .kn-work{grid-template-columns:1fr}
  .kn-tile,.kn-tile.tall{aspect-ratio:4/3}
}

/* ---------- Individual profile pages ---------- */
.profile-grid{display:grid;grid-template-columns:360px 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.profile-card{position:sticky;top:110px}
.profile-photo{aspect-ratio:3/4;overflow:hidden;background:var(--kn-cream2);border:1px solid var(--kn-line)}
.profile-photo img{width:100%;height:100%;object-fit:cover;object-position:top center}
.profile-contact{margin-top:1.4rem;border:1px solid var(--kn-line);background:var(--kn-paper);padding:1.3rem 1.4rem}
.profile-contact h4{font-family:var(--sans);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--kn-gold);margin-bottom:.9rem}
.profile-contact a,.profile-contact span{display:block;font-size:.94rem;color:var(--kn-ink);padding:.3rem 0;word-break:break-word}
.profile-contact a:hover{color:var(--kn-accent)}
.profile-role{font-family:var(--sans);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--kn-accent);font-weight:600;margin-bottom:1.1rem}
.tagset{display:flex;flex-wrap:wrap;gap:.5rem;margin:.4rem 0 1.6rem}
.tagset span{font-family:var(--sans);font-size:.82rem;color:var(--kn-ink);background:var(--kn-cream2);
  border:1px solid var(--kn-line);padding:.4rem .85rem;border-radius:30px}
.profile-back{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);font-size:.78rem;
  letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--kn-mute);margin-bottom:1.4rem}
.profile-back:hover{color:var(--kn-accent)}
@media(max-width:760px){.profile-grid{grid-template-columns:1fr}.profile-card{position:static}.profile-photo{max-width:320px}}

/* =====================================================================
   HERO VIDEO BACKGROUND (homepage) + refined profile pages
   ===================================================================== */
.kn-hero{align-items:flex-end;min-height:94vh;background:#0e0c0a;justify-content:flex-start}
.kn-hero video,.kn-hero .gifbase{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.kn-hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(14,11,8,.30) 0%,rgba(14,11,8,.05) 32%,rgba(14,11,8,.55) 78%,rgba(14,11,8,.85) 100%)}
.kn-hero .kn-wrap{position:relative;z-index:2;padding-block:clamp(44px,8vw,96px)}
.kn-hero .bar{background:#e8c87f}
.kn-hero .kn-kick{color:#e8c87f}
.kn-hero h1{color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.kn-hero h1 em{color:#f0d9a0;font-style:italic}
.kn-hero .sub{color:rgba(255,255,255,.92);text-shadow:0 1px 18px rgba(0,0,0,.3)}
.kn-scroll-cue{position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);z-index:2;
  color:rgba(255,255,255,.8);font-family:var(--sans);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:.6rem}
.kn-scroll-cue::after{content:"";width:1px;height:40px;background:rgba(255,255,255,.6);animation:cdLine 1.9s infinite}

/* ---- refined profile page ---- */
.profile-grid{grid-template-columns:380px 1fr;gap:clamp(2.2rem,5vw,5rem)}
.profile-photo{aspect-ratio:4/5;border:1px solid var(--kn-line);box-shadow:0 30px 70px -44px rgba(40,25,10,.55);
  background:linear-gradient(160deg,#efe7d8,#e3d8c4);position:relative}
.profile-photo::after{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:var(--kn-accent)}
.profile-photo img{object-position:center top}
.profile-contact{box-shadow:0 18px 50px -38px rgba(40,25,10,.4)}
.profile-contact .ic{color:var(--kn-accent);width:1.1rem;display:inline-block}
.profile-lead{font-family:var(--serif);font-size:clamp(1.3rem,2.2vw,1.7rem);font-style:italic;color:var(--kn-mute);
  line-height:1.4;margin:0 0 1.6rem;padding-bottom:1.6rem;border-bottom:1px solid var(--kn-line)}
.profile-grid .prose h2{font-size:clamp(1.7rem,3vw,2.3rem)}
.profile-grid .prose h3{font-family:var(--sans);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--kn-gold);margin-top:2rem}
.profile-cta{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;margin-top:2rem;padding-top:1.8rem;border-top:1px solid var(--kn-line)}
.profile-nav{display:flex;justify-content:space-between;gap:1rem;border-top:1px solid var(--kn-line);margin-top:3.5rem;padding-top:1.6rem}
.profile-nav a{font-family:var(--sans);font-size:.84rem;color:var(--kn-ink)}
.profile-nav a:hover{color:var(--kn-accent)}
.profile-nav .lab{display:block;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--kn-faint);margin-bottom:.25rem}
.profile-nav .nx{text-align:right}

/* ---- Interactive header background (constellation) ---- */
.site-header{overflow:hidden}
.hdr-fx{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}
.site-header .nav{position:relative;z-index:1}
.brand img{height:46px;width:auto;filter:none}

/* ---- Transparent adaptive header ---- */
.site-header{overflow:visible;background:transparent;backdrop-filter:none;border-bottom:1px solid transparent;
  transition:background .35s ease,border-color .35s ease}
.site-header.scrolled{background:rgba(244,239,230,.92);backdrop-filter:saturate(160%) blur(14px);border-bottom-color:var(--kn-line)}
/* homepage: light nav while transparent over the video, dark once scrolled */
.kn .site-header:not(.scrolled) .nav-links a{color:#fff;text-shadow:0 1px 10px rgba(0,0,0,.4)}
.kn .site-header:not(.scrolled) .nav-links .has-menu>a::after{border-color:#fff}
.kn .site-header:not(.scrolled) .burger span{background:#fff}
.kn .site-header:not(.scrolled) .brand img{filter:drop-shadow(0 2px 12px rgba(0,0,0,.5))}
@media(max-width:760px){
  /* mobile drawer always solid for readability */
  .kn .site-header:not(.scrolled) .nav-links a{color:var(--kn-ink);text-shadow:none}
}

/* ---- Header: always transparent background, black text ---- */
.site-header,.site-header.scrolled{background:transparent !important;backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;border-bottom:1px solid transparent !important}
.site-header .nav-links a,
.kn .site-header:not(.scrolled) .nav-links a,
.kn .site-header.scrolled .nav-links a{color:#141210 !important;text-shadow:none}
.site-header .has-menu>a::after,
.kn .site-header:not(.scrolled) .has-menu>a::after{border-color:#141210 !important}
.site-header .burger span,
.kn .site-header:not(.scrolled) .burger span{background:#141210 !important}
/* keep maroon logo legible over the homepage video without changing the artwork */
.kn .site-header .brand img,
.kn .site-header:not(.scrolled) .brand img{filter:drop-shadow(0 1px 6px rgba(255,255,255,.7))}
.kn .site-header .nav-links a{text-shadow:0 0 10px rgba(255,255,255,.65),0 1px 2px rgba(255,255,255,.7)}
@media(max-width:760px){.kn .site-header .nav-links a{text-shadow:none}}

/* ---- Larger accreditation marquee logos ---- */
.kn-logos img{height:74px}
.kn-logos .txt{font-size:1.7rem}
.kn-logos .track{gap:clamp(2.6rem,6vw,5.5rem)}
@media(max-width:760px){.kn-logos img{height:58px}.kn-logos .txt{font-size:1.35rem}}

/* ---- Smaller "Selected expertise" tiles ---- */
.kn-work{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(1rem,1.8vw,1.4rem)}
.kn-tile,.kn-tile.tall{aspect-ratio:4/3}
.kn-tile .cap{padding:.95rem 1.05rem}
.kn-tile .cap .t{font-size:clamp(1rem,1.4vw,1.25rem)}
.kn-tile .cap .s{font-size:.64rem;letter-spacing:.12em;margin-top:.3rem}
@media(max-width:760px){.kn-work{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.kn-work{grid-template-columns:1fr}}

/* ---- Homepage: header overlays the hero video (truly transparent) ---- */
.kn .site-header{position:fixed;top:0;left:0;right:0;z-index:70}
.kn .kn-hero .kn-wrap{padding-top:clamp(120px,16vh,170px)}

/* ---- Homepage header: WHITE text over the video, dark once scrolled ---- */
.kn .site-header:not(.scrolled) .nav-links a{color:#ffffff !important;text-shadow:0 1px 16px rgba(0,0,0,.6)}
.kn .site-header:not(.scrolled) .has-menu>a::after{border-color:#ffffff !important}
.kn .site-header:not(.scrolled) .burger span{background:#ffffff !important}
.kn .site-header:not(.scrolled) .brand img{filter:drop-shadow(0 2px 10px rgba(0,0,0,.55))}
.kn .site-header.scrolled .nav-links a{color:#141210 !important;text-shadow:none}
.kn .site-header.scrolled .has-menu>a::after{border-color:#141210 !important}
.kn .site-header.scrolled .burger span{background:#141210 !important}
.kn .site-header.scrolled .brand img{filter:none}

/* ---- 1. Bigger logo ---- */
.brand img{height:58px}
@media(max-width:760px){.brand img{height:46px}}

/* ---- 2. Header: white top-level menu, BLACK dropdown text ---- */
.kn .site-header:not(.scrolled) .nav-links>li>a{color:#ffffff !important;text-shadow:0 1px 16px rgba(0,0,0,.6)}
.site-header .dropdown a{color:#141210 !important;text-shadow:none !important}
.site-header .dropdown a:hover{color:#6a0f12 !important}

/* ---- 3. Full-screen hero so the marquee sits below the fold ---- */
.kn-hero{min-height:100vh}

/* ---- Dropdown text always black (override white top-nav, higher specificity) ---- */
.kn .site-header:not(.scrolled) .nav-links .dropdown a,
.kn .site-header.scrolled .nav-links .dropdown a,
.site-header .nav-links .dropdown a{color:#141210 !important;text-shadow:none !important}
.kn .site-header .nav-links .dropdown a:hover,
.site-header .nav-links .dropdown a:hover{color:#6a0f12 !important}

/* ---- Accreditation strip: shorter section, bigger logos ---- */
.kn-logos-sec{padding-block:clamp(18px,2.6vw,30px) !important}
.kn-logos-sec .kn-kick{margin-bottom:.8rem !important}
.kn-logos img{height:96px}
.kn-logos .txt{font-size:1.9rem}
@media(max-width:760px){.kn-logos img{height:66px}.kn-logos .txt{font-size:1.4rem}}

/* ---- Accreditation logos: greyscale by default, full colour + bright on hover ---- */
.kn-logos:hover .track{animation-play-state:paused}
.kn-logos img{filter:grayscale(1);opacity:.6;transition:filter .35s ease,opacity .35s ease,transform .35s ease}
.kn-logos img:hover{filter:grayscale(0) saturate(1.12) brightness(1.05);opacity:1;transform:scale(1.06)}

/* ---- Dark "Expertise" list section (matches the hero video) ---- */
.kn-exp{position:relative;overflow:hidden;background:#0f0c0b;color:#efe9df;padding-block:clamp(62px,9vw,124px)}
.kn-exp::before{content:"";position:absolute;inset:0;z-index:0;
  background:radial-gradient(58% 80% at 86% 8%,rgba(150,30,42,.30),transparent 60%),
            radial-gradient(52% 64% at 4% 96%,rgba(42,60,120,.20),transparent 60%)}
.kn-exp::after{content:"";position:absolute;inset:0;z-index:0;opacity:.05;
  background-image:repeating-linear-gradient(125deg,#fff 0 1px,transparent 1px 26px)}
.kn-exp .kn-wrap{position:relative;z-index:1}
.kn-exp-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1.2rem;
  margin-bottom:2.8rem;border-bottom:1px solid rgba(255,255,255,.14);padding-bottom:1.6rem}
.kn-exp-head .kn-kick{color:#cfa15a;margin-bottom:.5rem}
.kn-exp-head h2{color:#fff;font-size:clamp(2rem,4.8vw,3.6rem);font-weight:600;line-height:1.02}
.kn-exp .more-light{font-family:var(--sans);font-weight:600;font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;
  color:#fff;border:1px solid rgba(255,255,255,.42);padding:.78rem 1.5rem;border-radius:40px;transition:.3s;white-space:nowrap}
.kn-exp .more-light:hover{background:#fff;color:#0f0c0b}
.kn-exp-cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem)}
.kn-exp-col h3{font-family:var(--sans);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:#cfa15a;margin:0 0 .4rem}
.kn-exp-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.02rem 0;
  border-bottom:1px solid rgba(255,255,255,.12);color:#e7e1d6;font-family:var(--serif);
  font-size:clamp(1.2rem,1.9vw,1.58rem);font-weight:500;transition:color .3s,padding .3s,background .3s}
.kn-exp-row .ar{color:#cfa15a;opacity:0;transform:translateX(-6px);transition:.3s;font-family:var(--sans);font-size:1.1rem}
.kn-exp-row:hover{color:#fff;padding-left:.85rem;background:linear-gradient(90deg,rgba(207,161,90,.08),transparent)}
.kn-exp-row:hover .ar{opacity:1;transform:none}
@media(max-width:760px){.kn-exp-cols{grid-template-columns:1fr;gap:2.4rem}}

/* ---- Bigger logo + larger header menu text (+2pt) ---- */
.brand img{height:72px}
@media(max-width:760px){.brand img{height:52px}}
.site-header .nav-links a{font-size:.96rem}
@media(max-width:760px){.site-header .nav-links a{font-size:1rem}}

/* ---- "Who we are" statement: text left, image right ---- */
.kn-state-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(2rem,5vw,4.6rem);align-items:center}
.kn-state-img{overflow:hidden;border:1px solid var(--kn-line);box-shadow:0 30px 70px -44px rgba(40,25,10,.5)}
.kn-state-img img{width:100%;height:100%;aspect-ratio:4/5;object-fit:cover;display:block}
.kn-state-grid h2{max-width:none}
@media(max-width:820px){.kn-state-grid{grid-template-columns:1fr}.kn-state-img{max-width:440px;margin-top:.5rem}}

/* =====================================================================
   PUBLICATION ARTICLE PAGE (.art-*) — replaces old PDF-viewer pages
   ===================================================================== */
.art-hero{background:var(--kn-cream2);border-bottom:1px solid var(--kn-line);padding-block:clamp(46px,7vw,84px)}
.art-hero .crumbs{color:var(--kn-mute)}.art-hero .crumbs a{color:var(--kn-accent)}
.art-tag{display:inline-block;font-family:var(--sans);font-size:.7rem;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--kn-accent);margin-bottom:1rem}
.art-hero h1{font-family:var(--serif);font-size:clamp(2.1rem,5vw,3.7rem);font-weight:600;line-height:1.05;max-width:20ch;color:var(--kn-ink)}
.art-hero .sub{font-family:var(--sans);font-size:clamp(1.05rem,1.8vw,1.3rem);color:var(--kn-mute);max-width:60ch;margin-top:1rem;line-height:1.55}
.art-meta{display:flex;flex-wrap:wrap;align-items:center;gap:1.4rem;margin-top:1.8rem;
  font-family:var(--sans);font-size:.9rem;color:var(--kn-mute)}
.art-meta .who{color:var(--kn-ink);font-weight:600}
.art-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--kn-faint)}
.art-meta .dl{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.76rem;letter-spacing:.06em;
  text-transform:uppercase;color:#fff;background:var(--kn-accent);padding:.6rem 1.15rem;border-radius:40px;transition:.3s}
.art-meta .dl:hover{background:#4d090c;color:#fff}

.art-sec{padding-block:clamp(48px,7vw,92px)}
.art-grid{display:grid;grid-template-columns:1fr 290px;gap:clamp(2.4rem,5vw,4.8rem);align-items:start}
.art-cover{margin:0 0 2.4rem;border:1px solid var(--kn-line);overflow:hidden}
.art-cover img{width:100%;display:block}
.art-body{font-family:var(--sans);color:var(--kn-ink);font-size:1.06rem;line-height:1.78;max-width:72ch}
.art-body .lede{font-size:1.22rem;line-height:1.7;color:var(--kn-ink)}
.art-body .lede::first-letter{float:left;font-family:var(--serif);font-size:3.6rem;line-height:.82;font-weight:600;
  color:var(--kn-accent);margin:.34rem .7rem 0 0}
.art-body h2{font-family:var(--serif);font-size:clamp(1.4rem,2.6vw,1.9rem);font-weight:600;color:var(--kn-ink);
  margin:2.6rem 0 .9rem;display:flex;gap:.8rem;align-items:baseline;scroll-margin-top:90px}
.art-body h2 .n{font-family:var(--sans);font-size:.92rem;font-weight:700;color:var(--kn-accent);
  border:1px solid var(--kn-accent);border-radius:50%;width:2rem;height:2rem;display:inline-flex;
  align-items:center;justify-content:center;flex:none;letter-spacing:0}
.art-body p{margin:0 0 1.1rem}
.art-body ul{list-style:none;padding:0;margin:0 0 1.4rem}
.art-body ul li{position:relative;padding:.34rem 0 .34rem 1.5rem}
.art-body ul li::before{content:"";position:absolute;left:0;top:.95rem;width:7px;height:7px;background:var(--kn-gold);transform:rotate(45deg)}
.art-body ul.crit li{padding-left:0;border-bottom:1px solid var(--kn-line)}
.art-body ul.crit li::before{display:none}
.art-body ul.crit li strong{color:var(--kn-accent)}
.art-disclaimer{background:var(--kn-cream2);border-left:3px solid var(--kn-gold);padding:1.3rem 1.5rem;
  font-size:.92rem;color:var(--kn-mute);margin-top:2.4rem;font-style:italic}

.art-aside{position:sticky;top:108px;display:flex;flex-direction:column;gap:1.6rem}
.art-card{background:var(--kn-paper);border:1px solid var(--kn-line);padding:1.4rem 1.5rem}
.art-card h4{font-family:var(--sans);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--kn-gold);margin-bottom:1rem}
.art-toc a{display:block;font-size:.92rem;color:var(--kn-ink);padding:.4rem 0;border-bottom:1px solid var(--kn-line)}
.art-toc a:hover{color:var(--kn-accent);padding-left:.3rem}
.art-author{display:flex;gap:.9rem;align-items:center;padding:.6rem 0}
.art-author .av{width:44px;height:44px;border-radius:50%;background:var(--kn-cream2);border:1px solid var(--kn-line);
  display:grid;place-items:center;font-family:var(--serif);font-weight:600;color:var(--kn-accent);flex:none}
.art-author .nm{font-weight:600;color:var(--kn-ink);font-size:.95rem;line-height:1.2}
.art-author .rl{font-size:.78rem;color:var(--kn-mute)}
.art-share{display:flex;gap:.6rem}
.art-share a{width:38px;height:38px;border:1px solid var(--kn-line);display:grid;place-items:center;border-radius:50%;color:var(--kn-ink)}
.art-share a:hover{background:var(--kn-accent);border-color:var(--kn-accent);color:#fff}
.art-share svg{width:16px;height:16px;fill:currentColor}
@media(max-width:900px){.art-grid{grid-template-columns:1fr}.art-aside{position:static;flex-direction:row;flex-wrap:wrap;margin-top:2rem}.art-card{flex:1;min-width:220px}}
