/*
Theme Name: Harper Polling
Theme URI: https://www.harperpolling.com
Author: Harper Polling
Description: Custom editorial "data-intelligence" theme for Harper Polling — public opinion research & data strategy. News via native Posts; Polls via a custom post type with topline & methodology fields.
Version: 2.6
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: harper-polling
*/
/* =============================================================================
   HARPER POLLING — DESIGN SYSTEM
   Editorial "data-intelligence": warm paper, deep ink, a precise signature red.
   ============================================================================= */

:root{
  /* palette */
  --paper:        #F6F2E9;   /* warm off-white base            */
  --paper-2:      #FBF8F1;   /* lighter card paper             */
  --ink:          #11161F;   /* near-black navy ink            */
  --ink-2:        #2A323D;   /* secondary ink                  */
  --ink-soft:     #5A626E;   /* muted text                     */
  --hair:         #D8D0C0;   /* hairline rule on paper         */
  --hair-strong:  #C4BAA6;
  --red:          #E14E18;   /* brand orange (accents/fills)   */
  --red-deep:     #C2410C;   /* deeper orange (hover/text)     */
  --brand:        #F05418;   /* bright brand orange (pops)     */
  --gold:         #B8862F;   /* tertiary data accent           */
  --blue:         #2F4A78;   /* data accent                    */
  --slate:        #6B7686;
  --green:        #2E6F4E;

  /* type */
  --display: "Fraunces", Georgia, serif;
  --sans: "Hanken Grotesk", -apple-system, system-ui, sans-serif;
  --mono: "Spline Sans Mono", ui-monospace, monospace;

  /* metrics */
  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 4px;
  --nav-h: 72px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--sans); font-size:17px; line-height:1.6;
  font-weight:420; letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
/* faint engineering grid + plotted dots across the whole page */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(var(--hair) 1px, transparent 1px),
    linear-gradient(90deg, var(--hair) 1px, transparent 1px);
  background-size: 64px 64px, 64px 64px;
  opacity:.16; mask-image:radial-gradient(circle at 50% 30%, #000 0%, transparent 90%);
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); position:relative; z-index:1; }

/* ---- typography helpers ---------------------------------------------- */
.eyebrow{
  font-family:var(--mono); font-size:.72rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--red); font-weight:500;
  display:inline-flex; align-items:center; gap:.6em;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--red); display:inline-block; }
h1,h2,h3{ font-family:var(--display); font-weight:540; line-height:1.04;
  letter-spacing:-0.02em; margin:0; font-optical-sizing:auto; }
h1{ font-size:clamp(2.6rem, 6vw, 5rem); }
h2{ font-size:clamp(2rem, 4vw, 3.2rem); }
h3{ font-size:clamp(1.3rem, 2vw, 1.7rem); }
p{ margin:0 0 1.1em; color:var(--ink-2); }
.lead{ font-size:clamp(1.1rem,1.6vw,1.35rem); color:var(--ink-2); line-height:1.55; }

/* ---- buttons --------------------------------------------------------- */
.btn{
  display:inline-flex; align-items:center; gap:.65em; padding:.85em 1.5em;
  font-family:var(--mono); font-size:.8rem; letter-spacing:.08em; text-transform:uppercase;
  border:1px solid var(--ink); border-radius:var(--radius); background:var(--ink); color:var(--paper);
  transition:transform .25s ease, background .25s ease, color .25s ease, box-shadow .25s ease;
  font-weight:500;
}
.btn:hover{ background:var(--red); border-color:var(--red); transform:translateY(-2px);
  box-shadow:0 10px 30px -12px rgba(240,84,24,.6); }
.btn .arr{ transition:transform .25s ease; }
.btn:hover .arr{ transform:translateX(4px); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--hair-strong); }
.btn--ghost:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); box-shadow:none; }

/* ============================ NAV ===================================== */
.nav{
  position:sticky; top:0; z-index:50; background:rgba(246,242,233,.92);
  backdrop-filter:saturate(140%) blur(8px); -webkit-backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--hair); transform:translateZ(0); -webkit-backface-visibility:hidden;
}
.nav__bar{ display:flex; align-items:center; justify-content:space-between; height:var(--nav-h); }
.brand{ display:flex; align-items:center; gap:.7rem; }
.brand__logo{ height:46px; width:auto; display:block; }
.brand__logo--mark{ height:46px; width:auto; display:none; }
@media (max-width:680px){ .brand__logo{ display:none; } .brand__logo--mark{ display:block; } }
.nav__links{ display:flex; align-items:center; gap:.3rem; }
.nav__links a{
  font-family:var(--mono); font-size:.78rem; letter-spacing:.04em; text-transform:uppercase;
  padding:.55rem .8rem; color:var(--ink-2); border-radius:var(--radius); position:relative;
}
.nav__links a::after{ content:""; position:absolute; left:.8rem; right:.8rem; bottom:.32rem; height:1px;
  background:var(--red); transform:scaleX(0); transform-origin:left; transition:transform .3s ease; }
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after, .nav__links a.is-active::after{ transform:scaleX(1); }
.nav__links a.is-active{ color:var(--ink); }
.nav__cta{ margin-left:.5rem; background:var(--red); border-color:var(--red); color:#fff; }
.nav__cta:hover{ background:var(--red); border-color:var(--red); color:var(--ink);
  transform:translateY(-2px); box-shadow:0 10px 30px -12px rgba(240,84,24,.55); }
.nav__toggle{ display:none; background:none; border:1px solid var(--hair-strong); border-radius:var(--radius);
  width:42px; height:38px; flex-direction:column; gap:4px; align-items:center; justify-content:center; }
.nav__toggle span{ width:18px; height:2px; background:var(--ink); transition:.3s; }
.nav__progress{ height:2px; background:var(--red); width:0; transition:width .1s linear; }

/* ============================ HERO ==================================== */
.hero{ padding:clamp(48px,8vw,96px) 0 clamp(40px,6vw,72px); position:relative; overflow:clip; }
.hero__mark{ position:absolute; right:30px; bottom:26px; width:min(350px,37vw); height:auto;
  opacity:.34; z-index:0; pointer-events:none; user-select:none; transform:rotate(-6deg); }
@media (max-width:680px){ .hero__mark{ width:190px; right:14px; bottom:14px; opacity:.3; } }
.hero__grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(28px,5vw,64px); align-items:center; }
.hero h1{ margin:.5rem 0 1.1rem; }
.hero h1 .accent{ color:var(--red); font-style:italic; }
.hero__cta{ display:flex; gap:.8rem; flex-wrap:wrap; margin-top:1.8rem; }
.hero__meta{ margin-top:2.4rem; display:flex; gap:1.6rem; flex-wrap:wrap;
  font-family:var(--mono); font-size:.72rem; letter-spacing:.06em; color:var(--ink-soft); text-transform:uppercase; }
.hero__meta b{ color:var(--ink); }

/* data panel (right side of hero) */
.datacard{
  background:var(--paper-2); border:1px solid var(--hair-strong); border-radius:8px;
  padding:26px 26px 30px; box-shadow:0 30px 60px -40px rgba(17,22,31,.5); position:relative; overflow:hidden;
}
.datacard::after{ content:""; position:absolute; inset:0; pointer-events:none;
  background-image:radial-gradient(var(--hair-strong) 1px, transparent 1px); background-size:18px 18px; opacity:.4;
  mask-image:linear-gradient(180deg,transparent,#000 40%); }
.datacard__head{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:18px; position:relative; }
.datacard__head .t{ font-family:var(--mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); }
.datacard__head .live{ font-family:var(--mono); font-size:.66rem; color:var(--red); display:flex; align-items:center; gap:.4em; }
.datacard__head .live::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--red); box-shadow:0 0 0 0 rgba(240,84,24,.5); animation:pulse 2s infinite; }
@keyframes pulse{ 70%{ box-shadow:0 0 0 8px rgba(240,84,24,0);} 100%{ box-shadow:0 0 0 0 rgba(240,84,24,0);} }
.bar{ position:relative; margin:14px 0; }
.bar__top{ display:flex; justify-content:space-between; font-size:.84rem; margin-bottom:5px; }
.bar__top .v{ font-family:var(--mono); font-weight:500; }
.bar__track{ height:9px; background:#e7dfce; border-radius:20px; overflow:hidden; }
.bar__fill{ height:100%; width:0; border-radius:20px; transition:width 1.1s cubic-bezier(.2,.8,.2,1); }
.fill-red{ background:linear-gradient(90deg,var(--red),var(--red-deep)); }
.fill-blue{ background:linear-gradient(90deg,#3a5a90,var(--blue)); }
.fill-ink{ background:linear-gradient(90deg,#3a4452,var(--ink)); }
.fill-gold{ background:linear-gradient(90deg,#d2a04a,var(--gold)); }
.fill-slate{ background:linear-gradient(90deg,#8b95a5,var(--slate)); }
.fill-green{ background:linear-gradient(90deg,#3e8a64,var(--green)); }
.datacard__foot{ margin-top:18px; padding-top:14px; border-top:1px solid var(--hair);
  font-family:var(--mono); font-size:.66rem; letter-spacing:.05em; color:var(--ink-soft); display:flex; justify-content:space-between; }

/* ============================ STAT BAND =============================== */
.stats{ border-top:1px solid var(--hair); border-bottom:1px solid var(--hair); background:var(--paper-2); }
.stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); }
.stat{ padding:34px var(--gutter); border-right:1px solid var(--hair); }
.stat:last-child{ border-right:none; }
.stat__num{ font-family:var(--display); font-size:clamp(2.4rem,4vw,3.4rem); font-weight:560; line-height:1; }
.stat__num .sfx{ color:var(--red); }
.stat__lbl{ font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); margin-top:.5rem; }

/* ============================ SECTIONS =============================== */
.section{ padding:clamp(56px,9vw,110px) 0; }
.section--tight{ padding:clamp(40px,6vw,72px) 0; }
.section__head{ max-width:720px; margin-bottom:clamp(32px,5vw,56px); }
.section__head h2{ margin:.6rem 0 .8rem; }

/* intro split */
.split{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(28px,6vw,72px); align-items:start; }
.split__aside{ position:sticky; top:calc(var(--nav-h) + 24px); }
.split__aside .eyebrow{ margin-bottom:1rem; }
.split__body p{ font-size:1.08rem; }

/* practice cards */
.practices{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--hair);
  border:1px solid var(--hair); border-radius:8px; overflow:hidden; }
.practice{ background:var(--paper-2); padding:30px 26px 34px; transition:background .3s ease; position:relative; }
.practice:hover{ background:#fff; }
.practice__ic{ width:46px; height:46px; color:var(--red); margin-bottom:20px; }
.practice h3{ font-size:1.35rem; margin-bottom:.5rem; }
.practice p{ font-size:.96rem; color:var(--ink-soft); margin:0; }
.practice__n{ position:absolute; top:18px; right:22px; font-family:var(--mono); font-size:.7rem; color:var(--hair-strong); }

/* ============================ NEWS / POLLS LISTS ===================== */
.toolbar{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; margin-bottom:34px;
  padding-bottom:22px; border-bottom:1px solid var(--hair); }
.search{ flex:1; min-width:220px; display:flex; align-items:center; gap:.6rem;
  border:1px solid var(--hair-strong); border-radius:var(--radius); padding:.6rem .9rem; background:var(--paper-2); }
.search input{ border:none; background:none; outline:none; font-family:var(--sans); font-size:.95rem; width:100%; color:var(--ink); }
.search svg{ width:16px; height:16px; color:var(--ink-soft); flex:none; }
.chips{ display:flex; gap:.5rem; flex-wrap:wrap; }
.chip{ font-family:var(--mono); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase;
  padding:.5rem .85rem; border:1px solid var(--hair-strong); border-radius:30px; background:transparent; color:var(--ink-2); transition:.2s; }
.chip:hover{ border-color:var(--ink); }
.chip.is-active{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

/* dropdown filters (polls) */
.filters{ display:flex; gap:14px; flex-wrap:wrap; }
.filtersel{ display:flex; align-items:center; gap:.55rem; }
.filtersel label{ font-family:var(--mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); }
.filtersel select{ font-family:var(--mono); font-size:.78rem; letter-spacing:.04em; color:var(--ink);
  background:var(--paper-2); border:1px solid var(--hair-strong); border-radius:30px; padding:.55rem 2.2rem .55rem 1rem;
  outline:none; cursor:pointer; appearance:none; transition:.2s;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235A626E' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right .85rem center; }
.filtersel select:hover{ border-color:var(--ink); }
.filtersel select:focus{ border-color:var(--ink); box-shadow:0 0 0 3px rgba(17,22,31,.07); }

/* news rows */
.newslist{ display:flex; flex-direction:column; }
.newsrow{ display:grid; grid-template-columns:120px 1fr auto; gap:24px; align-items:center;
  padding:26px 4px; border-bottom:1px solid var(--hair); transition:.25s; }
.newsrow:hover{ background:var(--paper-2); padding-inline:18px; }
.newsrow__date{ font-family:var(--mono); font-size:.74rem; color:var(--ink-soft); letter-spacing:.04em; }
.newsrow__date b{ display:block; color:var(--ink); font-size:1.4rem; font-family:var(--display); letter-spacing:0; }
.newsrow__title{ font-family:var(--display); font-size:1.35rem; line-height:1.18; }
.newsrow__src{ display:inline-block; font-family:var(--mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--red); margin-bottom:.4rem; }
.newsrow__ex{ color:var(--ink-soft); font-size:.95rem; margin:.4rem 0 0; max-width:62ch; }
.newsrow__go{ font-family:var(--mono); font-size:.74rem; color:var(--ink); white-space:nowrap; opacity:.5; transition:.25s; }
.newsrow:hover .newsrow__go{ opacity:1; color:var(--red); }
.tag{ display:inline-block; font-family:var(--mono); font-size:.62rem; letter-spacing:.1em; text-transform:uppercase;
  padding:.25em .6em; border:1px solid var(--hair-strong); border-radius:3px; color:var(--ink-soft); margin-left:.5rem; vertical-align:middle; }

/* poll cards */
.pollgrid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(330px,1fr)); gap:22px; }
.pollcard{ background:var(--paper-2); border:1px solid var(--hair-strong); border-radius:8px; padding:24px;
  display:flex; flex-direction:column; transition:.28s; position:relative; overflow:hidden; }
.pollcard:hover{ transform:translateY(-4px); box-shadow:0 26px 50px -34px rgba(17,22,31,.6); border-color:var(--ink); }
.pollcard__meta{ display:flex; gap:.5rem; flex-wrap:wrap; margin-bottom:14px; }
.pollcard h3{ font-size:1.28rem; line-height:1.16; margin-bottom:10px; }
.pollcard__sum{ font-size:.92rem; color:var(--ink-soft); margin-bottom:18px; flex:1; }
.pollcard__foot{ display:flex; justify-content:space-between; align-items:center; padding-top:14px; border-top:1px solid var(--hair);
  font-family:var(--mono); font-size:.7rem; color:var(--ink-soft); letter-spacing:.04em; }
.pollcard__foot .go{ color:var(--red); }
.minibars{ margin:4px 0 16px; }
.empty-note{ font-family:var(--mono); font-size:.72rem; color:var(--ink-soft); border:1px dashed var(--hair-strong);
  border-radius:var(--radius); padding:10px 12px; }

/* ============================ ARTICLE / DETAIL ======================= */
.article{ max-width:780px; }
.article__back{ font-family:var(--mono); font-size:.74rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft);
  display:inline-flex; gap:.5em; align-items:center; margin-bottom:28px; }
.article__back:hover{ color:var(--red); }
.article__meta{ display:flex; gap:.7rem; flex-wrap:wrap; align-items:center; font-family:var(--mono);
  font-size:.74rem; color:var(--ink-soft); letter-spacing:.05em; margin-bottom:16px; }
.article h1{ font-size:clamp(2rem,4vw,3rem); margin-bottom:18px; }
.article__body p{ font-size:1.1rem; }
.method{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--hair); border:1px solid var(--hair);
  border-radius:8px; overflow:hidden; margin:8px 0 30px; }
.method div{ background:var(--paper-2); padding:16px 18px; }
.method .k{ font-family:var(--mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); }
.method .v{ font-family:var(--display); font-size:1.25rem; margin-top:4px; }
.topline{ background:var(--paper-2); border:1px solid var(--hair-strong); border-radius:8px; padding:26px 28px; margin:26px 0 34px; }
.topline h4{ font-family:var(--mono); font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); margin:0 0 18px; }

/* ============================ ABOUT / TEAM =========================== */
.aboutgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:8px; }
.member{ background:var(--paper-2); border:1px solid var(--hair-strong); border-radius:8px; overflow:hidden; transition:.28s; }
.member:hover{ transform:translateY(-4px); box-shadow:0 26px 50px -34px rgba(17,22,31,.55); }
.member__img{ aspect-ratio:1/1; background:var(--ink); position:relative; overflow:hidden; }
.member__img img{ position:relative; z-index:1; width:100%; height:100%; object-fit:cover; filter:grayscale(1) contrast(1.02); transition:.5s; }
.member:hover .member__img img{ filter:grayscale(0); transform:scale(1.04); }
.monogram{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-family:var(--display); font-size:2.6rem; color:var(--paper); background:
    radial-gradient(120% 120% at 30% 20%, #28303c, var(--ink)); letter-spacing:.04em; }
.member__body{ padding:20px 22px 24px; }
.member__body h3{ font-size:1.3rem; }
.member__role{ font-family:var(--mono); font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; color:var(--red); margin:.4rem 0 0; }

.bio{ margin-top:48px; display:none; }
.bio.is-open{ display:block; }

/* client portraits grid */
.clients{ display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:16px; }
.client{ text-align:center; }
.client__img{ aspect-ratio:1/1; border-radius:8px; overflow:hidden; background:var(--ink); border:1px solid var(--hair-strong); position:relative; }
.client__img img{ position:relative; z-index:1; width:100%; height:100%; object-fit:cover; transition:.4s; }
.client__name{ font-family:var(--display); font-size:1rem; margin-top:10px; line-height:1.15; }
.client__role{ font-family:var(--mono); font-size:.64rem; letter-spacing:.06em; color:var(--ink-soft); text-transform:uppercase; margin-top:3px; }
.monogram--sm{ font-size:1.8rem; }

/* testimonials */
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--hair); border:1px solid var(--hair); border-radius:8px; overflow:hidden; }
.quote{ background:var(--paper-2); padding:34px 30px; display:flex; flex-direction:column; }
.quote__mark{ font-family:var(--display); font-size:3.4rem; line-height:.6; color:var(--red); height:30px; }
.quote p{ font-family:var(--display); font-size:1.12rem; line-height:1.4; color:var(--ink); flex:1; }
.quote__by{ margin-top:18px; }
.quote__by b{ display:block; font-size:1rem; }
.quote__by span{ font-family:var(--mono); font-size:.68rem; letter-spacing:.04em; color:var(--ink-soft); }

/* partners marquee/grid */
.partners{ display:flex; flex-wrap:wrap; gap:10px; }
.partner{ font-family:var(--mono); font-size:.78rem; letter-spacing:.02em; color:var(--ink-2);
  border:1px solid var(--hair-strong); border-radius:30px; padding:.55rem 1rem; background:var(--paper-2); transition:.2s; }
.partner:hover{ border-color:var(--red); color:var(--red); }

/* ============================ SERVICES =============================== */
.svc-group{ margin-top:54px; }
.svc-group__label{ font-family:var(--mono); font-size:.76rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--red); padding-bottom:14px; border-bottom:1px solid var(--ink); margin-bottom:30px; display:flex; justify-content:space-between; }
.svc-group__label span{ color:var(--ink-soft); }
.svc{ display:grid; grid-template-columns:64px 1fr; gap:26px; padding:26px 0; border-bottom:1px solid var(--hair); align-items:start; }
.svc__ic{ width:56px; height:56px; color:var(--red); }
.svc h3{ font-size:1.5rem; margin-bottom:.6rem; }
.svc p{ font-size:1.02rem; color:var(--ink-2); margin:0; max-width:70ch; }

/* ============================ CONTACT ================================ */
.contact{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,6vw,72px); align-items:start; }
.field{ display:flex; flex-direction:column; gap:.4rem; margin-bottom:18px; }
.field label{ font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); }
.field input, .field textarea, .field select{ font-family:var(--sans); font-size:1rem; color:var(--ink);
  background:var(--paper-2); border:1px solid var(--hair-strong); border-radius:var(--radius); padding:.8rem .9rem; outline:none; transition:.2s; }
.field input:focus, .field textarea:focus, .field select:focus{ border-color:var(--ink); box-shadow:0 0 0 3px rgba(17,22,31,.07); }
.field textarea{ resize:vertical; min-height:130px; }
.contact__side .infoblock{ padding:22px 0; border-top:1px solid var(--hair); }
.contact__side .infoblock:first-child{ border-top:none; }
.contact__side .k{ font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:.5rem; }
.contact__side a.big{ font-family:var(--display); font-size:1.4rem; color:var(--ink); }
.contact__side a.big:hover{ color:var(--red); }
.formnote{ font-family:var(--mono); font-size:.72rem; color:var(--ink-soft); margin-top:8px; }

/* opt-in consent */
.consent{ display:flex; gap:.7rem; align-items:flex-start; margin-top:6px;
  background:var(--paper-2); border:1px solid var(--hair-strong); border-radius:var(--radius); padding:14px 16px; }
.consent input{ margin-top:.25rem; width:18px; height:18px; flex:none; accent-color:var(--red); cursor:pointer; }
.consent span{ font-size:.82rem; line-height:1.5; color:var(--ink-soft); }
.consent a{ color:var(--red-deep); text-decoration:underline; }

/* legal pages (privacy) */
.legal__updated{ font-family:var(--mono); font-size:.76rem; letter-spacing:.04em; color:var(--ink-soft); margin-top:1rem; }
.legal{ max-width:820px; }
.legal__sec{ padding:26px 0; border-top:1px solid var(--hair); }
.legal__sec:first-child{ border-top:none; padding-top:8px; }
.legal__sec h3{ font-size:1.5rem; display:flex; align-items:baseline; gap:.7rem; margin-bottom:14px; }
.legal__n{ font-family:var(--mono); font-size:.8rem; color:var(--red); border:1px solid var(--hair-strong);
  border-radius:6px; padding:.2rem .55rem; flex:none; }
.legal__sub{ font-family:var(--sans); font-weight:650; font-size:1.02rem; color:var(--ink); margin:18px 0 8px; }
.legal p{ font-size:1rem; color:var(--ink-2); }
.legal__list{ margin:0 0 1.1em; padding-left:0; list-style:none; display:flex; flex-direction:column; gap:12px; }
.legal__list li{ position:relative; padding-left:22px; font-size:1rem; color:var(--ink-2); line-height:1.55; }
.legal__list li::before{ content:""; position:absolute; left:2px; top:.62em; width:8px; height:2px; background:var(--red); }
.legal__addr{ font-family:var(--mono); font-size:.92rem; color:var(--ink); line-height:1.7;
  border-left:2px solid var(--red); padding-left:16px; }

/* footer legal links */
.footer__legal{ display:flex; gap:18px; }
.footer__legal a{ font-family:var(--mono); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); }
.footer__legal a:hover{ color:var(--red); }

/* page hero (interior) */
.pagehero{ padding:clamp(48px,7vw,84px) 0 clamp(20px,3vw,32px); border-bottom:1px solid var(--hair); }
.pagehero h1{ margin-top:.6rem; max-width:18ch; }
.pagehero p{ max-width:60ch; margin-top:1.1rem; }

/* CTA band */
.ctaband{ border-top:1px solid var(--hair); background:var(--ink); color:var(--paper); position:relative; overflow:hidden; }
.ctaband::before{ content:""; position:absolute; inset:0;
  background-image:radial-gradient(rgba(246,242,233,.14) 1px, transparent 1px); background-size:22px 22px;
  mask-image:radial-gradient(circle at 80% 50%, #000, transparent 70%); }
.ctaband__in{ position:relative; padding:clamp(48px,7vw,84px) 0; display:flex; justify-content:space-between; align-items:center; gap:30px; flex-wrap:wrap; }
.ctaband h2{ color:var(--paper); max-width:16ch; }
.ctaband .btn{ background:var(--red); border-color:var(--red); }
.ctaband .btn:hover{ background:var(--paper); color:var(--ink); border-color:var(--paper); }

/* ============================ FOOTER ================================= */
.footer{ background:var(--paper-2); border-top:1px solid var(--hair); padding:56px 0 28px; position:relative; z-index:1; }
.footer__top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:30px; padding-bottom:40px; border-bottom:1px solid var(--hair); }
.footer h4{ font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); margin:0 0 16px; }
.footer ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
.footer ul a{ color:var(--ink-2); font-size:.95rem; }
.footer ul a:hover{ color:var(--red); }
.footer__loc{ font-family:var(--mono); font-size:.8rem; color:var(--ink-2); display:flex; flex-direction:column; gap:8px; }
.footer__loc span::before{ content:"▸ "; color:var(--red); }
.footer__brand p{ font-size:.92rem; color:var(--ink-soft); max-width:34ch; margin-top:14px; }
.footer .brand__logo{ height:44px; }
.footer .brand__logo--mark{ height:44px; }
.footer__bottom{ display:flex; justify-content:space-between; align-items:center; padding-top:22px; flex-wrap:wrap; gap:14px; }
.footer__bottom small{ font-family:var(--mono); font-size:.72rem; color:var(--ink-soft); letter-spacing:.03em; }
.footer__social{ display:flex; gap:14px; }
.footer__social a{ width:34px; height:34px; border:1px solid var(--hair-strong); border-radius:50%;
  display:flex; align-items:center; justify-content:center; color:var(--ink-2); transition:.25s; }
.footer__social a:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.footer__social svg{ width:15px; height:15px; }

/* newsletter */
.newsletter{ display:flex; gap:10px; margin-top:14px; }
.newsletter input{ flex:1; background:var(--paper); border:1px solid var(--hair-strong); border-radius:var(--radius);
  padding:.7rem .85rem; font-family:var(--sans); outline:none; }
.newsletter input:focus{ border-color:var(--ink); }
.newsletter button{ background:var(--ink); color:var(--paper); border:none; border-radius:var(--radius); padding:0 1.1rem;
  font-family:var(--mono); font-size:.74rem; letter-spacing:.06em; text-transform:uppercase; transition:.2s; }
.newsletter button:hover{ background:var(--red); }

/* ---- scroll reveal --------------------------------------------------- */
/* Content is visible by default. The entrance animation only engages once JS adds
   ".reveal-on" to <html>, so a blocked, slow, or failed script can never leave content invisible. */
.reveal-on [data-reveal]{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1); }
.reveal-on [data-reveal].in{ opacity:1; transform:none; }

/* ---- responsive ------------------------------------------------------ */
@media (max-width:1000px){
  .hero__grid{ grid-template-columns:1fr; }
  .datacard{ max-width:520px; }
  .practices{ grid-template-columns:repeat(2,1fr); }
  .quotes{ grid-template-columns:1fr; }
  .aboutgrid{ grid-template-columns:repeat(2,1fr); }
  .stats__grid{ grid-template-columns:repeat(2,1fr); }
  .stat:nth-child(2){ border-right:none; }
  .stat:nth-child(1),.stat:nth-child(2){ border-bottom:1px solid var(--hair); }
  .footer__top{ grid-template-columns:1fr 1fr; }
  .split{ grid-template-columns:1fr; }
  .split__aside{ position:static; }
  .contact{ grid-template-columns:1fr; }
  .method{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:680px){
  .nav__links{ position:fixed; inset:var(--nav-h) 0 auto 0; background:var(--paper);
    flex-direction:column; align-items:stretch; padding:14px var(--gutter) 24px; gap:2px;
    border-bottom:1px solid var(--hair); transform:translateY(-130%); transition:transform .35s ease; box-shadow:0 20px 40px -30px rgba(0,0,0,.5); }
  .nav__links.is-open{ transform:none; }
  .nav__links a{ padding:.85rem .4rem; font-size:.9rem; }
  .nav__links a::after{ display:none; }
  .nav__cta{ margin:.5rem 0 0; }
  .nav__toggle{ display:flex; }
  .practices{ grid-template-columns:1fr; }
  .aboutgrid{ grid-template-columns:1fr; }
  .newsrow{ grid-template-columns:1fr; gap:8px; }
  .newsrow__go{ display:none; }
  .svc{ grid-template-columns:1fr; gap:14px; }
  .footer__top{ grid-template-columns:1fr; }
  .clients{ grid-template-columns:repeat(2,1fr); }
  .method{ grid-template-columns:1fr 1fr; }
}
.nav__toggle.is-open span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
.nav__toggle.is-open span:nth-child(2){ opacity:0; }
.nav__toggle.is-open span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

/* ============================ WORDPRESS INTEGRATION ============================ */
.admin-bar .nav{ top:32px; }
@media (max-width:782px){ .admin-bar .nav{ top:46px; } }
.screen-reader-text{ position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
img.wp-post-image, .wp-caption img, .entry-content img{ max-width:100%; height:auto; }
.entry-content img{ border-radius:6px; }
/* article body (post content) inherits .article__body look */
.entry-content p{ font-size:1.1rem; color:var(--ink-2); margin:0 0 1.1em; }
.entry-content h2{ font-size:clamp(1.4rem,2.4vw,1.9rem); margin:1.6rem 0 .6rem; }
.entry-content h3{ font-size:1.3rem; margin:1.3rem 0 .5rem; }
.entry-content ul, .entry-content ol{ padding-left:1.2rem; margin:0 0 1.1em; }
.entry-content li{ margin:.3rem 0; color:var(--ink-2); }
.entry-content a{ color:var(--red-deep); text-decoration:underline; }
.entry-content blockquote{ border-left:3px solid var(--red); margin:1.2rem 0; padding:.4rem 0 .4rem 1.1rem; font-family:var(--display); font-size:1.2rem; color:var(--ink); }
.pagination{ display:flex; gap:10px; justify-content:center; margin-top:40px; flex-wrap:wrap; }
.pagination .page-numbers{ font-family:var(--mono); font-size:.8rem; padding:.55rem .9rem; border:1px solid var(--hair-strong); border-radius:var(--radius); color:var(--ink-2); }
.pagination .page-numbers.current{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.pagination a.page-numbers:hover{ border-color:var(--ink); }

/* ============================ HERO VISUALIZATION PANEL ============================ */
.datapanel{ position:relative; z-index:1; background:var(--paper-2); border:1px solid var(--hair-strong);
  border-radius:8px; padding:22px 24px 16px; box-shadow:0 30px 60px -40px rgba(17,22,31,.5); overflow:hidden; }
.datapanel::after{ content:""; position:absolute; inset:0; pointer-events:none;
  background-image:radial-gradient(var(--hair-strong) 1px, transparent 1px); background-size:18px 18px; opacity:.4;
  mask-image:linear-gradient(180deg,transparent,#000 40%); }
.datapanel__head{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:12px; position:relative; z-index:1; }
.datapanel__head .t{ font-family:var(--mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); }
.datapanel__head .live{ font-family:var(--mono); font-size:.66rem; color:var(--red); display:flex; align-items:center; gap:.4em; }
.datapanel__head .live::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--red); box-shadow:0 0 0 0 rgba(240,84,24,.5); animation:pulse 2s infinite; }
.viz-stage{ position:relative; min-height:236px; z-index:1; }
.viz-slide{ position:absolute; inset:0; opacity:0; transform:translateY(8px); pointer-events:none;
  transition:opacity .5s ease, transform .5s ease; }
.viz-slide.is-active{ opacity:1; transform:none; pointer-events:auto; }
.viz-title{ font-family:var(--display); font-size:1.06rem; color:var(--ink); margin:0 0 14px; }
.viz-foot{ position:absolute; left:0; right:0; bottom:0; display:flex; justify-content:space-between;
  font-family:var(--mono); font-size:.64rem; letter-spacing:.05em; color:var(--ink-soft);
  padding-top:10px; border-top:1px solid var(--hair); }
.viz-dots{ display:flex; gap:7px; justify-content:center; margin-top:12px; position:relative; z-index:1; }
.viz-dot{ width:7px; height:7px; padding:0; border:0; border-radius:50%; background:var(--hair-strong);
  cursor:pointer; transition:background .25s, width .25s; }
.viz-dot.is-active{ background:var(--red); width:18px; border-radius:4px; }
.viz-dot:hover{ background:var(--red-deep); }
/* sparkline */
.spark{ width:100%; height:150px; display:block; }
.spark-grid{ stroke:var(--hair-strong); stroke-width:1; opacity:.5; }
.spark-area{ fill:url(#sparkgrad); opacity:0; transition:opacity .7s .25s ease; }
.viz-slide.is-active .spark-area{ opacity:1; }
.spark-line{ fill:none; stroke:var(--red); stroke-width:2.6; stroke-linecap:round; stroke-linejoin:round;
  stroke-dasharray:1; stroke-dashoffset:1; }
.viz-slide.is-active .spark-line{ animation:hp-draw 1.15s cubic-bezier(.4,0,.2,1) forwards; }
@keyframes hp-draw{ to{ stroke-dashoffset:0; } }
.spark-dot{ fill:var(--red); opacity:0; transition:opacity .3s .9s ease; }
.viz-slide.is-active .spark-dot{ opacity:1; }
.spark-tag{ font-family:var(--mono); font-size:11px; fill:var(--red); text-anchor:end; opacity:0; transition:opacity .3s 1s ease; }
.viz-slide.is-active .spark-tag{ opacity:1; }
.spark-axis{ font-family:var(--mono); font-size:9px; fill:var(--ink-soft); letter-spacing:.05em; }
/* donut */
.donut{ display:block; margin:2px auto 0; }
.donut-track{ fill:none; stroke:#e7dfce; stroke-width:18; }
.donut-seg{ fill:none; stroke:var(--red); stroke-width:18; stroke-linecap:butt;
  stroke-dasharray:0 364.42; transition:stroke-dasharray 1s cubic-bezier(.3,.8,.3,1); }
.donut-label{ font-family:var(--display); font-weight:600; fill:var(--ink); }
.donut-sub{ font-family:var(--mono); fill:var(--ink-soft); letter-spacing:.04em; }

/* two-segment donut + legend (hero "right direction / wrong track") */
.donut-row{ display:flex; align-items:center; justify-content:flex-start; gap:18px; }
.donut-row .donut{ margin:0; flex:0 0 auto; }
.donut-legend{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:14px; }
.donut-legend li{ font-size:.84rem; color:var(--ink-2); line-height:1.2; }
.donut-legend b{ font-family:var(--mono); color:var(--ink); font-size:1rem; margin-right:.4em; }
.donut-legend .sw{ display:inline-block; width:11px; height:11px; border-radius:2px; margin-right:.55em; vertical-align:middle; }
.donut-legend .sw-red{ background:var(--red); }
.donut-legend .sw-ink{ background:var(--ink); }

/* ---- client logo strip (scrolling marquee) ---- */
.logos{ background:var(--ink); color:#fff; padding:clamp(38px,5vw,64px) 0; overflow:hidden; }
.logos__head{ text-align:center; color:rgba(255,255,255,.66); font-family:var(--sans);
  font-size:clamp(.95rem,1.4vw,1.15rem); letter-spacing:.01em; margin:0 0 clamp(24px,3vw,36px); }
.logos__viewport{ position:relative; width:100%; overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);
          mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%); }
.logos__track{ display:flex; align-items:center; width:max-content; margin:0; padding:0; list-style:none;
  animation:hp-logos 42s linear infinite; will-change:transform; }
.logos__viewport:hover .logos__track{ animation-play-state:paused; }
.logos__item{ flex:0 0 auto; display:flex; align-items:center; padding:0 clamp(24px,3.6vw,48px); }
.logos__item img{ height:clamp(31px,4vw,45px); width:auto; display:block;
  filter:brightness(0) invert(1); opacity:.78; transition:opacity .25s ease; }
.logos__item img:hover{ opacity:1; }
@keyframes hp-logos{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){
  .logos__track{ animation:none; flex-wrap:wrap; justify-content:center; width:auto; row-gap:26px; }
  .logos__item--dup{ display:none; }
}

/* ---- share row (articles) · bio social · careers jobs · poll docs ---- */
.share{ display:flex; align-items:center; gap:10px; margin-top:34px; padding-top:22px; border-top:1px solid var(--hair); flex-wrap:wrap; }
.share__label{ font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); margin-right:2px; }
.share__btn, .bio__social-btn{ display:inline-flex; align-items:center; justify-content:center; width:38px; height:38px; border:1px solid var(--hair-strong); border-radius:8px; color:var(--ink); background:var(--paper-2); transition:border-color .2s ease,color .2s ease; }
.share__btn svg, .bio__social-btn svg{ width:17px; height:17px; }
.share__btn:hover, .bio__social-btn:hover{ border-color:var(--red); color:var(--red); }
.bio__social{ display:flex; align-items:center; gap:10px; margin-top:20px; }

.joblist{ margin-top:26px; display:flex; flex-direction:column; gap:22px; }
.job{ border:1px solid var(--hair-strong); border-radius:10px; padding:22px 24px; background:var(--paper-2); }
.job__title{ margin:0; font-size:1.18rem; }
.job__meta{ font-family:var(--mono); font-size:.74rem; letter-spacing:.04em; color:var(--red-deep); margin-top:5px; }
.job__desc{ margin-top:12px; color:var(--ink-soft); }
.job__desc p{ margin:0 0 .7em; }
.job__apply{ margin-top:16px; }

.polldocs{ margin-top:28px; }
.polldocs h4{ margin:0 0 12px; }
.polldocs__row{ display:flex; flex-wrap:wrap; gap:12px; }
.polldoc{ display:inline-flex; align-items:center; gap:8px; }
.polldoc svg{ width:16px; height:16px; }

/* safety net: hide any residual Jetpack/WordPress.com post flair (sharing, likes, related) */
#jp-post-flair, .sharedaddy, .jp-relatedposts, #jp-relatedposts,
.jetpack-likes-widget-wrapper, .sd-like{ display:none !important; }

/* ---- form handling: honeypot + status notes ---- */
.hp-hp{ position:absolute !important; left:-9999px !important; top:auto; width:1px; height:1px; overflow:hidden; }
.formnote.is-ok{ color:#2E6F4E; }
.formnote.is-error{ color:#C0392B; }
