/* ============================================================
   teas.co.uk, About page layout
   Page-specific styles. Shared components live in design-system.css.
   Activates the AMBER accent for warmth (vs cyan default).
   ============================================================ */

body.page-template-page-about,
body.page-about{
  --acc: #FFB347;
}

/* ===== HERO, magazine spread ===== */
.about-hero{
  display:grid;grid-template-columns:1.4fr 1fr;gap:var(--gap);margin-bottom:36px;
}
.hero-l{
  background:#fff;border-radius:var(--r-3xl);padding:36px;box-shadow:var(--sh-card);
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;justify-content:space-between;min-height:520px;
}
.hero-l .kicker{
  font-family:var(--fm);font-size:11px;text-transform:uppercase;letter-spacing:.10em;
  color:var(--slate);font-weight:600;
}
.hero-l h1{
  font-family:var(--fb);font-size:96px;font-weight:800;letter-spacing:-.032em;
  line-height:.92;margin:14px 0 0;text-wrap:balance;
}
.hero-l h1 em{font-family:var(--fd);font-style:italic;font-weight:400;letter-spacing:-.012em}
.hero-l h1 .underline{position:relative;display:inline-block}
.hero-l h1 .underline::after{
  content:'';position:absolute;left:-4px;right:-4px;bottom:-4px;height:14px;
  background:var(--acc);z-index:-1;border-radius:6px;transform:rotate(-.5deg);
}
.hero-l .signoff{display:flex;align-items:center;gap:14px;margin-top:24px}
.hero-l .signoff .av{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg,var(--acc),#D88B2C);color:#0A0B0F;
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--fd);font-style:italic;font-size:22px;
}
.hero-l .signoff .meta{display:flex;flex-direction:column;gap:2px}
.hero-l .signoff .meta .nm{font-size:13.5px;font-weight:700}
.hero-l .signoff .meta .role{
  font-family:var(--fm);font-size:11px;color:var(--slate);font-weight:500;
  text-transform:uppercase;letter-spacing:.06em;
}

.hero-r{display:flex;flex-direction:column;gap:var(--gap)}
.facts{
  background:#042220;color:#eff7f6;border-radius:var(--r-3xl);padding:28px;
  box-shadow:var(--sh-card);
}
.facts .kicker{
  font-family:var(--fm);font-size:10.5px;text-transform:uppercase;letter-spacing:.10em;
  color:var(--acc);font-weight:600;
}
.facts h3{
  font-family:var(--fd);font-style:italic;font-weight:400;font-size:30px;
  letter-spacing:-.012em;margin:6px 0 18px;color:#eff7f6;line-height:1.05;
}
.fact-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fact{
  display:flex;flex-direction:column;gap:2px;padding:14px 0;
  border-top:1px solid rgba(239,247,246,.10);
}
.fact .v{
  font-family:var(--fb);font-weight:800;font-size:34px;letter-spacing:-.022em;
  line-height:1;color:#eff7f6;
}
.fact .v em{
  font-family:var(--fd);font-style:italic;font-weight:400;font-size:22px;
  color:rgba(239,247,246,.5);
}
.fact .lbl{
  font-family:var(--fm);font-size:10.5px;color:rgba(239,247,246,.55);font-weight:500;
  margin-top:8px;text-transform:uppercase;letter-spacing:.06em;
}

/* Trustpilot card, REAL teas.co.uk Trustpilot is FREE TIER with 5 reviews.
   Never overstate. The card is sized to match Claus's design but content is honest. */
.tp-card{
  background:linear-gradient(135deg,#00B67A,#00925E);color:#fff;
  border-radius:var(--r-3xl);padding:24px;box-shadow:var(--sh-card);
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;gap:8px;
}
.tp-card .corner{
  position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:8px;
  background:rgba(255,255,255,.18);
  display:inline-flex;align-items:center;justify-content:center;
}
.tp-card .corner svg{width:20px;height:20px;color:#fff}
.tp-card .kicker{
  font-family:var(--fm);font-size:11px;text-transform:uppercase;letter-spacing:.08em;
  color:rgba(255,255,255,.85);font-weight:600;
}
.tp-card .stars{display:flex;gap:3px;margin:6px 0 4px}
.tp-card .star{
  width:24px;height:24px;background:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:3px;color:#00B67A;
}
.tp-card .star svg{width:16px;height:16px}
.tp-card .rating{
  font-family:var(--fb);font-weight:800;font-size:36px;letter-spacing:-.020em;
  line-height:1;color:#fff;
}
.tp-card .rating em{
  font-family:var(--fd);font-style:italic;font-weight:400;font-size:22px;
  color:rgba(255,255,255,.7);
}
.tp-card .sub{
  font-size:13px;color:rgba(255,255,255,.85);font-weight:500;margin:0;line-height:1.45;
}
.tp-card .cta{
  margin-top:8px;align-self:flex-start;background:#fff;color:#00925E;
  padding:8px 14px;border-radius:99px;font-weight:700;font-size:12.5px;
  display:inline-flex;align-items:center;gap:6px;
}
.tp-card .cta svg{width:11px;height:11px}

/* ===== BIG STORY pull ===== */
.story{
  background:#fff;border-radius:var(--r-3xl);padding:48px;box-shadow:var(--sh-card);
  margin-bottom:36px;display:grid;grid-template-columns:1fr 2fr;gap:48px;position:relative;
}
.story .label{
  font-family:var(--fm);font-size:11px;text-transform:uppercase;letter-spacing:.10em;
  color:var(--slate);font-weight:600;
}
.story .label::before{content:'01 ';color:var(--acc);font-weight:800}
.story h2{
  font-family:var(--fb);font-size:36px;font-weight:800;letter-spacing:-.020em;
  line-height:1.1;margin:8px 0 0;text-wrap:balance;
}
.story h2 em{font-family:var(--fd);font-style:italic;font-weight:400}
.story .pull{
  font-family:var(--fd);font-style:italic;font-weight:400;font-size:30px;
  line-height:1.25;color:var(--ink);letter-spacing:-.008em;margin:0;text-wrap:balance;
}
.story .pull::before{
  content:'\201C';font-size:64px;line-height:0;vertical-align:-22px;
  color:var(--acc);margin-right:6px;
}
.story p{font-size:15px;color:var(--ink);line-height:1.7;margin:0 0 14px}
.story p.muted{color:var(--slate)}
.story .body{display:flex;flex-direction:column;gap:0}

/* ===== STORY V2, chaptered, polished ===== */
.story-v2 {
  grid-template-columns: 1fr 2fr;
  padding: 56px 56px 48px;
  gap: 64px;
}
.story-v2 .story-head {
  position: sticky;
  top: 96px;
  align-self: start;
}
.story-v2 .story-head .label {
  font-family: var(--fm);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .10em;
  color: var(--slate);
  font-weight: 600;
}
.story-v2 .story-head .label::before {
  content: '01 ';
  color: var(--acc);
  font-weight: 800;
}
.story-v2 .story-head h2 {
  font-family: var(--fb);
  font-size: 42px;
  font-weight: 800;
  letter-spacing: -.024em;
  line-height: 1.05;
  margin: 12px 0 0;
  text-wrap: balance;
}
.story-v2 .story-head h2 em {
  font-family: var(--fd);
  font-style: italic;
  font-weight: 400;
  color: var(--acc);
}
.story-v2 .story-body {
  display: flex;
  flex-direction: column;
  gap: 36px;
  max-width: 60ch;
}
.story-v2 .pull {
  font-family: var(--fd);
  font-style: italic;
  font-weight: 400;
  font-size: 28px;
  line-height: 1.3;
  color: var(--ink);
  letter-spacing: -.005em;
  margin: 0;
  text-wrap: balance;
  padding: 4px 0 4px 20px;
  border-left: 3px solid var(--acc);
}
.story-v2 .pull::before {
  content: none;
}
.story-v2 .pull-acc {
  background: linear-gradient(135deg, rgba(255,179,71,.18), rgba(255,179,71,.05));
  border-left-color: var(--acc);
  padding: 22px 24px;
  border-radius: 16px;
  font-size: 24px;
  margin: 8px 0;
}
.story-v2 .story-chapter {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 0;
  margin: 0;
  scroll-margin-top: 100px;
}
.story-v2 .chapter-head {
  display: flex;
  align-items: baseline;
  gap: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--hair);
  margin-bottom: 6px;
}
.story-v2 .chapter-num {
  font-family: var(--fd);
  font-style: italic;
  font-weight: 400;
  font-size: 36px;
  color: var(--acc);
  letter-spacing: -.018em;
  line-height: 1;
  flex-shrink: 0;
}
.story-v2 .chapter-head h3 {
  font-family: var(--fb);
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -.018em;
  line-height: 1.15;
  margin: 0;
  color: var(--ink);
  text-wrap: balance;
}
.story-v2 .chapter-head h3 em {
  font-family: var(--fd);
  font-style: italic;
  font-weight: 400;
  color: var(--acc);
}
.story-v2 .story-chapter p {
  font-size: 16px;
  line-height: 1.7;
  color: var(--ink);
  margin: 0;
  max-width: 60ch;
}
.story-v2 .story-chapter p + p {
  margin-top: 10px;
}
.story-v2 .dropcap::first-letter {
  font-family: var(--fd);
  font-style: italic;
  font-weight: 400;
  font-size: 64px;
  line-height: .85;
  float: left;
  padding: 4px 10px 0 0;
  color: var(--acc);
}
.story-v2 .story-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.story-v2 .story-list li {
  font-size: 15.5px;
  line-height: 1.55;
  color: var(--ink);
  padding-left: 22px;
  position: relative;
}
.story-v2 .story-list li::before {
  content: '×';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--acc);
  font-family: var(--fd);
  font-style: italic;
  font-size: 22px;
  font-weight: 400;
  line-height: 1.1;
}
.story-v2 .story-list li strong {
  font-weight: 700;
  color: var(--ink);
}
.story-v2 .story-coda {
  font-family: var(--fm);
  font-size: 12.5px;
  letter-spacing: .01em;
  line-height: 1.65;
  color: var(--slate);
  background: var(--paper-2);
  padding: 18px 22px;
  border-radius: 14px;
  margin: 12px 0 0;
}

@media (max-width: 900px) {
  .story-v2 {
    grid-template-columns: 1fr;
    padding: 32px 24px;
    gap: 28px;
  }
  .story-v2 .story-head { position: static; }
  .story-v2 .story-head h2 { font-size: 32px; }
  .story-v2 .pull { font-size: 22px; padding-left: 16px; }
  .story-v2 .pull-acc { font-size: 19px; padding: 18px 20px; }
  .story-v2 .chapter-num { font-size: 30px; }
  .story-v2 .chapter-head h3 { font-size: 22px; }
}

/* ===== TIMELINE / origin ===== */
.origin{margin-bottom:36px}
.origin-head{
  display:flex;justify-content:space-between;align-items:flex-end;gap:14px;
  margin-bottom:18px;
}
.origin-head h2{
  font-family:var(--fb);font-size:42px;font-weight:800;letter-spacing:-.025em;
  margin:0;text-wrap:balance;
}
.origin-head h2 em{font-family:var(--fd);font-style:italic;font-weight:400}
.origin-head .meta{
  font-family:var(--fm);font-size:11.5px;color:var(--slate);font-weight:500;
  letter-spacing:.04em;text-transform:uppercase;
}
.origin-rail{
  background:#fff;border-radius:var(--r-3xl);padding:36px;box-shadow:var(--sh-card);
  position:relative;
}
.origin-rail::before{
  content:'';position:absolute;left:48px;right:48px;top:80px;height:2px;
  background:repeating-linear-gradient(to right,var(--ash) 0 8px,transparent 8px 14px);
}
.year-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative;
}
.year{padding:0 10px}
.year .yr{
  font-family:var(--fd);font-style:italic;font-weight:400;font-size:48px;
  color:var(--ink);letter-spacing:-.018em;line-height:1;
}
.year.active .yr{color:var(--acc)}
.year .dot{
  width:18px;height:18px;border-radius:50%;background:#fff;border:3px solid var(--ash);
  margin:18px 0 18px;position:relative;z-index:2;
}
.year.active .dot{
  background:var(--acc);border-color:#042220;
  box-shadow:0 0 0 6px rgba(255,179,71,.20);
}
.year h4{
  font-family:var(--fb);font-size:15px;font-weight:700;letter-spacing:-.008em;
  margin:0 0 4px;line-height:1.3;
}
.year h4 em{font-family:var(--fd);font-style:italic;font-weight:400}
.year p{font-size:12.5px;color:var(--slate);margin:0;line-height:1.55;max-width:24ch}

/* ===== VALUES ===== */
.values{
  display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap);margin-bottom:36px;
}
.value{
  background:#fff;border-radius:var(--r-3xl);padding:28px;box-shadow:var(--sh-card);
  position:relative;display:flex;flex-direction:column;gap:8px;min-height:240px;
}
.value.dark{background:#042220;color:#eff7f6}
.value .num{
  font-family:var(--fd);font-style:italic;font-weight:400;font-size:64px;
  line-height:1;color:var(--acc);letter-spacing:-.018em;
}
.value h3{
  font-family:var(--fb);font-size:22px;font-weight:800;letter-spacing:-.012em;
  margin:8px 0 0;line-height:1.15;
}
.value h3 em{font-family:var(--fd);font-style:italic;font-weight:400}
.value p{
  font-size:13.5px;color:var(--slate);line-height:1.55;margin:6px 0 0;max-width:28ch;
}
.value.dark p{color:rgba(239,247,246,.65)}
.value .check{
  margin-top:auto;font-family:var(--fm);font-size:10.5px;text-transform:uppercase;
  letter-spacing:.08em;font-weight:600;color:var(--ink);
  display:inline-flex;align-items:center;gap:8px;
}
.value.dark .check{color:#eff7f6}
.value .check .dot{width:8px;height:8px;border-radius:50%;background:var(--lime)}

/* ===== CATEGORY MAP ===== */
.catmap{
  margin-bottom:36px;background:var(--paper-2);border-radius:var(--r-3xl);
  padding:36px;box-shadow:var(--sh-card);
}
.catmap-head{
  display:flex;justify-content:space-between;align-items:flex-end;gap:14px;
  margin-bottom:24px;
}
.catmap-head h2{
  font-family:var(--fb);font-size:36px;font-weight:800;letter-spacing:-.022em;
  margin:0;text-wrap:balance;
}
.catmap-head h2 em{font-family:var(--fd);font-style:italic;font-weight:400}
.catmap-head p{font-size:14px;color:var(--slate);max-width:40ch;margin:0}
.catmap-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}
.cat-col{
  background:#fff;border-radius:var(--r-2xl);padding:22px;
  display:flex;flex-direction:column;gap:10px;
}
.cat-col .axis{
  font-family:var(--fm);font-size:10.5px;text-transform:uppercase;letter-spacing:.10em;
  font-weight:700;color:var(--ink);padding-bottom:10px;border-bottom:1px solid var(--hair);
  display:flex;justify-content:space-between;align-items:baseline;
}
.cat-col .axis .ct{color:var(--slate);font-size:10px;font-weight:500}
.cat-col .axis .num{color:var(--acc);font-weight:800}
.cat-col ul{
  list-style:none;padding:0;margin:6px 0 0;
  display:flex;flex-direction:column;gap:4px;
}
.cat-col li{
  display:grid;grid-template-columns:1fr auto;align-items:baseline;gap:10px;
  padding:6px 0;border-bottom:1px dotted rgba(14,15,18,.08);
}
.cat-col li:last-child{border-bottom:none}
.cat-col li a{
  display:contents;color:inherit;
}
.cat-col li:hover .nm{color:var(--ink)}
.cat-col li .nm{
  font-size:13.5px;font-weight:600;letter-spacing:-.005em;
  transition:color .14s var(--ease);
}
.cat-col li .ct{
  font-family:var(--fm);font-size:11px;color:var(--slate);font-weight:500;
}
.cat-col li.hot .nm::after{
  content:'·';margin-left:6px;color:var(--acc);font-weight:800;
}

/* ===== CURATOR / SOLO-OPERATOR strip ===== */
.curator-strip{display:grid;grid-template-columns:1fr 2fr;gap:var(--gap);margin-bottom:36px}
.curator-l{
  background:#042220;color:#eff7f6;border-radius:var(--r-3xl);padding:32px;
  box-shadow:var(--sh-card);
  display:flex;flex-direction:column;justify-content:space-between;min-height:300px;
}
.curator-l .kicker{
  font-family:var(--fm);font-size:11px;text-transform:uppercase;letter-spacing:.10em;
  color:var(--acc);font-weight:600;
}
.curator-l h2{
  font-family:var(--fd);font-style:italic;font-weight:400;font-size:48px;
  letter-spacing:-.018em;line-height:1.05;margin:8px 0 0;color:#eff7f6;
}
.curator-l p{
  font-size:13.5px;color:rgba(239,247,246,.65);line-height:1.55;
  margin:14px 0 0;max-width:28ch;
}
.curator-l .meta{display:flex;gap:8px;margin-top:18px;flex-wrap:wrap}
.curator-l .pill{
  padding:6px 12px;border-radius:99px;background:rgba(239,247,246,.08);
  font-family:var(--fm);font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;
  font-weight:600;color:#eff7f6;
}

.curator-r{
  background:#fff;border-radius:var(--r-3xl);padding:32px;
  box-shadow:var(--sh-card);
  display:flex;flex-direction:column;gap:18px;
}
.curator-r .self{display:flex;gap:18px;align-items:center}
.curator-r .self .av{
  width:88px;height:88px;border-radius:50%;
  background:linear-gradient(135deg,var(--acc),#D88B2C);color:#0A0B0F;
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--fd);font-style:italic;font-size:48px;font-weight:400;
  flex-shrink:0;
}
.curator-r .self .body{display:flex;flex-direction:column;gap:6px;min-width:0}
.curator-r .self .nm{
  font-family:var(--fb);font-size:22px;font-weight:800;letter-spacing:-.012em;line-height:1;
}
.curator-r .self .role{
  font-family:var(--fm);font-size:11px;color:var(--slate);font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;
}
.curator-r .self .quote{
  font-family:var(--fd);font-style:italic;font-weight:400;font-size:16px;
  color:var(--slate);line-height:1.4;margin:6px 0 0;
}

.curator-r .brands-list{
  border-top:1px solid var(--hair);padding-top:18px;
  display:flex;flex-direction:column;gap:8px;
}
.curator-r .brands-list .lbl{
  font-family:var(--fm);font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;
  color:var(--slate);font-weight:600;
}
.curator-r .brands-list .brands{
  display:flex;flex-wrap:wrap;gap:6px;
}
.curator-r .brands-list .brand-chip{
  padding:6px 12px;border-radius:99px;background:var(--paper-2);
  font-size:12.5px;font-weight:600;color:var(--ink);
  transition:background .14s var(--ease);
}
.curator-r .brands-list .brand-chip:hover{background:#042220;color:var(--acc)}

/* ===== CTA strip ===== */
.cta-strip{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);margin-bottom:36px}
.cta{
  border-radius:var(--r-3xl);padding:32px;box-shadow:var(--sh-card);
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;gap:14px;min-height:240px;
}
.cta.acc{background:var(--acc);color:#0A0B0F}
.cta.dark{background:#042220;color:#eff7f6}
.cta .kicker{
  font-family:var(--fm);font-size:11px;text-transform:uppercase;letter-spacing:.10em;
  font-weight:600;
}
.cta.acc .kicker{color:rgba(10,11,15,.65)}
.cta.dark .kicker{color:var(--acc)}
.cta h3{
  font-family:var(--fd);font-style:italic;font-weight:400;font-size:42px;
  letter-spacing:-.012em;margin:0;line-height:1.05;max-width:14ch;
}
.cta.dark h3{color:#eff7f6}
.cta p{font-size:14px;line-height:1.55;margin:0;max-width:36ch}
.cta.acc p{color:rgba(10,11,15,.75)}
.cta.dark p{color:rgba(239,247,246,.7)}
.cta .btn{
  align-self:flex-start;margin-top:auto;
  padding:12px 18px;border-radius:99px;font-weight:700;font-size:13px;
  display:inline-flex;align-items:center;gap:10px;
}
.cta.acc .btn{background:#042220;color:var(--acc)}
.cta.dark .btn{background:var(--acc);color:#0A0B0F}
.cta .btn svg{width:13px;height:13px}

/* ===== RESPONSIVE ===== */
@media (max-width:1180px){
  .about-hero,.story,.curator-strip,.cta-strip{grid-template-columns:1fr}
  .values,.catmap-grid{grid-template-columns:1fr 1fr}
  .year-grid{grid-template-columns:repeat(2,1fr);row-gap:20px}
  .origin-rail::before{display:none}
}
@media (max-width:760px){
  .hero-l h1{font-size:54px}
  .story{padding:28px}
  .story h2{font-size:28px}
  .values,.catmap-grid{grid-template-columns:1fr}
  .curator-r .self{flex-direction:column;align-items:flex-start;text-align:left}
}
