/* ============================================================
   SafeRange · UX Case Study
   Editorial digital-health aesthetic. Warm cocoa / cream palette.
   ============================================================ */

:root {
  /* Brand palette */
  --cocoa:        #5C4033;
  --cocoa-deep:   #2C211B;
  --cocoa-mid:    #3D2C22;
  --beige:        #E8DCCB;
  --cream:        #F8F4EE;
  --cream-2:      #FBF8F3;
  --terracotta:   #C6865B;
  --terracotta-d: #A9683E;
  --sage:         #8FA98A;
  --amber:        #D9A441;
  --clay:         #C26D5A;

  --ink:          #2A211C;
  --ink-soft:     #5B4D43;
  --ink-faint:    #8C7C6E;
  --line:         #E4D8C7;

  --maxw: 1180px;
  --gap: clamp(1rem, 4vw, 2.5rem);
  --radius: 22px;
  --radius-sm: 14px;

  --serif: "Fraunces", Georgia, serif;
  --sans: "Hanken Grotesk", system-ui, sans-serif;

  --shadow-soft: 0 18px 50px -24px rgba(60, 42, 30, 0.45);
  --shadow-card: 0 2px 4px rgba(60,42,30,.04), 0 22px 48px -28px rgba(60,42,30,.40);
  --shadow-phone: 0 40px 90px -40px rgba(34, 22, 14, 0.65);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--sans);
  color: var(--ink);
  background: var(--cream);
  line-height: 1.62;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }

a { color: inherit; }

h1, h2, h3, h4 {
  font-family: var(--serif);
  font-weight: 560;
  line-height: 1.04;
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--ink);
}

p { margin: 0 0 1rem; }

.wrap { width: min(var(--maxw), 100% - 2.4rem); margin-inline: auto; }
.narrow { width: min(760px, 100% - 2.4rem); margin-inline: auto; }

section { position: relative; }

.eyebrow {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 0.72rem;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--terracotta-d);
  margin: 0 0 1.1rem;
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
}
.eyebrow::before {
  content: "";
  width: 26px; height: 1.5px;
  background: var(--terracotta);
  display: inline-block;
}

.section-pad { padding: clamp(4.5rem, 10vw, 8rem) 0; }

.lede {
  font-size: clamp(1.12rem, 2.2vw, 1.32rem);
  color: var(--ink-soft);
  max-width: 60ch;
}

/* ---------- Logo mark ---------- */
.mark { width: 100%; height: 100%; display: block; }
.logo-lockup { display: inline-flex; align-items: center; gap: 0.7rem; }
.logo-lockup .mark-wrap { width: 38px; height: 38px; flex: none; }
.logo-lockup .wordmark {
  font-family: var(--serif);
  font-weight: 600;
  font-size: 1.4rem;
  letter-spacing: -0.01em;
}
.wordmark .safe { color: var(--cream); }
.wordmark .range { color: var(--terracotta); }

/* ============================================================
   NАV
   ============================================================ */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(44, 33, 27, 0.82);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(232, 220, 203, 0.12);
}
.nav-inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0.85rem 0;
}
.nav .logo-lockup .wordmark { font-size: 1.15rem; }
.nav .logo-lockup .mark-wrap { width: 30px; height: 30px; }
.nav-links { display: flex; gap: 1.6rem; font-size: 0.85rem; font-weight: 600; }
.nav-links a {
  color: rgba(248,244,238,.72); text-decoration: none;
  letter-spacing: 0.01em; transition: color .2s;
}
.nav-links a:hover { color: var(--terracotta); }
@media (max-width: 860px){ .nav-links { display: none; } }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  background:
    radial-gradient(120% 90% at 78% 8%, rgba(198,134,91,.30), transparent 55%),
    radial-gradient(100% 80% at 12% 95%, rgba(169,104,62,.22), transparent 60%),
    linear-gradient(160deg, #1f1712 0%, var(--cocoa-deep) 45%, #3a281d 100%);
  color: var(--cream);
  padding: clamp(3rem, 7vw, 5.5rem) 0 clamp(4rem, 9vw, 7rem);
  overflow: hidden;
  position: relative;
}
.hero::after {
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
  position: relative; z-index: 1;
}
@media (max-width: 900px){ .hero-grid { grid-template-columns: 1fr; } }

/* hero eyebrow — sits on the dark gradient */
.hero-eyebrow { color: var(--terracotta); margin-bottom: 1.4rem; }
.hero-eyebrow::before { background: var(--terracotta); }

.hero-title {
  font-size: clamp(2.55rem, 5.6vw, 4.4rem);
  color: var(--cream);
  letter-spacing: -0.032em;
  line-height: 1.02;
}
.accent-word {
  color: var(--terracotta);
  background: linear-gradient(96deg, #D8A06E 0%, var(--terracotta) 55%, var(--clay) 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.hero-promise {
  font-family: var(--sans);
  font-weight: 600;
  font-size: clamp(1.08rem, 2vw, 1.32rem);
  color: var(--terracotta);
  letter-spacing: 0.005em;
  margin: 1.15rem 0 0;
}
.hero-sub {
  color: rgba(248,244,238,.74);
  max-width: 50ch;
  font-size: clamp(1rem, 1.3vw, 1.08rem);
  line-height: 1.62;
  margin-top: 1.05rem;
}

/* hero CTAs */
.hero-cta { display: flex; flex-wrap: wrap; gap: 0.85rem; margin-top: 1.9rem; }
.btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-family: var(--sans); font-size: 0.92rem; font-weight: 700;
  letter-spacing: 0.005em; text-decoration: none;
  padding: 0.82rem 1.5rem; border-radius: 100px;
  transition: transform .25s cubic-bezier(.2,.7,.2,1), background .25s, border-color .25s, box-shadow .25s;
  will-change: transform;
}
.btn-primary {
  color: var(--cream);
  background: linear-gradient(140deg, var(--terracotta) 0%, var(--terracotta-d) 100%);
  border: 1px solid rgba(232,220,203,.16);
  box-shadow: 0 14px 30px -14px rgba(198,134,91,.7);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 20px 40px -16px rgba(198,134,91,.85); }
.btn-ghost {
  color: var(--cream);
  background: rgba(248,244,238,.04);
  border: 1px solid rgba(232,220,203,.28);
}
.btn-ghost:hover { transform: translateY(-2px); border-color: var(--terracotta); background: rgba(198,134,91,.12); }
.btn-ghost .arr { transition: transform .25s cubic-bezier(.2,.7,.2,1); }
.btn-ghost:hover .arr { transform: translate(2px,-2px); }

/* hero metadata — three icon cards */
.hero-meta {
  margin: 2.3rem 0 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 0.8rem;
}
.hm-cell {
  background: rgba(28, 21, 17, .4);
  border: 1px solid rgba(232,220,203,.14);
  border-radius: var(--radius-sm);
  padding: 1rem 1.1rem;
  transition: border-color .25s, transform .25s, background .25s;
}
.hm-cell:hover { border-color: rgba(198,134,91,.5); transform: translateY(-3px); background: rgba(44,30,21,.55); }
.hm-cell dt {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-size: 0.66rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--terracotta); font-weight: 700;
}
.hm-cell dt svg { width: 16px; height: 16px; flex: none; }
.hm-cell dd {
  margin: 0.6rem 0 0; font-size: 0.86rem; color: rgba(248,244,238,.88);
  font-weight: 500; line-height: 1.45;
}
@media (max-width: 620px){ .hero-meta { grid-template-columns: 1fr; } }

/* phone device frame */
.device {
  position: relative;
  border-radius: 38px;
  padding: 9px;
  background: linear-gradient(160deg, #4a382c 0%, #241b15 100%);
  box-shadow: var(--shadow-phone);
  border: 1px solid rgba(232,220,203,.10);
}
.device::before {
  content:""; position:absolute; top:16px; left:50%; transform:translateX(-50%);
  width: 34%; height: 20px; background:#1c140f; border-radius: 0 0 14px 14px; z-index:2;
}
.device img { border-radius: 30px; width: 100%; }
.device-hero { max-width: 300px; margin-inline: auto; }
.hero-phone { position: relative; }
.hero-phone .device { transform: rotate(2deg); }

/* ============================================================
   AT A GLANCE (recruiter snapshot)
   ============================================================ */
.glance { background: var(--cocoa-deep); color: var(--cream); padding: clamp(2.6rem,5vw,3.4rem) 0; }
.glance h2 { color: var(--cream); font-size: 1.05rem; font-weight: 600; letter-spacing: .02em; opacity:.7; font-family: var(--sans); text-transform: uppercase; letter-spacing:.2em; font-size:.74rem; }
.glance-grid {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 1px;
  margin-top: 1.6rem; background: rgba(232,220,203,.14);
  border: 1px solid rgba(232,220,203,.14); border-radius: var(--radius-sm); overflow:hidden;
}
@media (max-width: 980px){ .glance-grid { grid-template-columns: repeat(3,1fr); } }
@media (max-width: 560px){ .glance-grid { grid-template-columns: repeat(2,1fr); } }
.glance-cell { background: rgba(20,15,11,.4); padding: 1.25rem 1.15rem; }
.glance-cell .n { font-family: var(--serif); font-size: 1.5rem; color: var(--terracotta); }
.glance-cell .k { font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color: var(--beige); opacity:.8; margin:.5rem 0 .35rem; font-weight:700;}
.glance-cell .v { font-size:.9rem; color: var(--cream); line-height:1.4; }

/* ============================================================
   GENERIC SECTION HEADING
   ============================================================ */
.section-head { max-width: 720px; margin-bottom: clamp(2rem,4vw,3rem); }
.section-head h2 { font-size: clamp(2rem, 4.6vw, 3.1rem); }
.section-head p { margin-top: 1rem; }
.alt { background: var(--cream-2); }
.dark { background: var(--cocoa-deep); color: var(--cream); }
.dark h2, .dark h3 { color: var(--cream); }
.dark .lede, .dark p { color: rgba(248,244,238,.78); }
.dark .eyebrow { color: var(--terracotta); }

/* ============================================================
   CARDS / GRIDS
   ============================================================ */
.card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 1.7rem;
  box-shadow: var(--shadow-card);
}
.grid { display: grid; gap: 1.2rem; }
.cols-2 { grid-template-columns: repeat(2,1fr); }
.cols-3 { grid-template-columns: repeat(3,1fr); }
.cols-4 { grid-template-columns: repeat(4,1fr); }
@media (max-width: 920px){ .cols-3, .cols-4 { grid-template-columns: repeat(2,1fr);} }
@media (max-width: 600px){ .cols-2, .cols-3, .cols-4 { grid-template-columns: 1fr; } }

.icon {
  width: 44px; height: 44px; border-radius: 12px;
  display: grid; place-items: center; margin-bottom: 1rem;
  background: var(--beige); color: var(--cocoa);
}
.icon svg { width: 22px; height: 22px; }
.card h3 { font-size: 1.28rem; margin-bottom: .5rem; }
.card p { color: var(--ink-soft); font-size: .96rem; margin-bottom: 0; }

/* pain point chips */
.painwrap { display:flex; flex-wrap:wrap; gap:.7rem; }
.chip {
  display:inline-flex; align-items:center; gap:.5rem;
  background:#fff; border:1px solid var(--line); border-radius: 100px;
  padding:.55rem 1rem; font-weight:600; font-size:.92rem; color: var(--cocoa);
  box-shadow: 0 6px 16px -12px rgba(60,42,30,.4);
}
.chip svg { width:16px; height:16px; color: var(--clay); }

/* pull quotes */
.quotes { display:grid; grid-template-columns: repeat(3,1fr); gap:1.2rem; }
@media (max-width: 880px){ .quotes { grid-template-columns:1fr; } }
.quote {
  position:relative; background: var(--cocoa);
  color: var(--cream); border-radius: var(--radius);
  padding: 2.2rem 1.6rem 1.5rem; box-shadow: var(--shadow-card);
  overflow:hidden;
}
.quote:nth-child(2){ background: var(--cocoa-mid); }
.quote:nth-child(3){ background: #6b4d3b; }
.quote::before {
  content:"\201C"; font-family: var(--serif); font-size: 5rem;
  position:absolute; top:-.6rem; left:.8rem; color: var(--terracotta); opacity:.55;
}
.quote p { font-family: var(--serif); font-size: 1.18rem; line-height:1.4; color: var(--cream); position:relative; }
.quote span { display:block; margin-top:1rem; font-family:var(--sans); font-size:.78rem; letter-spacing:.04em; color: var(--beige); opacity:.75; }

/* callout card */
.callout {
  background: linear-gradient(140deg, var(--terracotta) 0%, var(--terracotta-d) 100%);
  color:#fff; border-radius: var(--radius); padding: 2rem 2.2rem;
  box-shadow: var(--shadow-soft);
}
.callout .k { font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; font-weight:700; opacity:.85;}
.callout q, .callout .big {
  display:block; font-family:var(--serif); font-size: clamp(1.5rem,3vw,2.1rem);
  line-height:1.15; margin-top:.6rem; font-style: italic;
}

/* ============================================================
   PROCESS TIMELINE
   ============================================================ */
.flow { display:flex; align-items:stretch; gap: 0; flex-wrap:wrap; }
.flow-step { flex:1 1 160px; min-width:150px; padding:1.4rem 1.2rem; position:relative; }
.flow-step:not(:last-child)::after {
  content:"→"; position:absolute; right:-.1rem; top:1.4rem; color: var(--terracotta); font-size:1.1rem;
}
.flow-step .num {
  width:30px;height:30px;border-radius:50%;background:var(--cocoa);color:var(--cream);
  display:grid;place-items:center;font-weight:700;font-size:.85rem; margin-bottom:.8rem;
}
.flow-step h4 { font-family:var(--sans); font-weight:700; font-size:.98rem; }
.flow-step p { font-size:.85rem; color:var(--ink-soft); margin:.4rem 0 0;}

/* ============================================================
   AFFINITY MAP
   ============================================================ */
.affinity { display:grid; grid-template-columns: repeat(4,1fr); gap:1.1rem; }
@media (max-width:920px){ .affinity { grid-template-columns: repeat(2,1fr);} }
@media (max-width:560px){ .affinity { grid-template-columns:1fr;} }
.cluster h4 {
  font-family:var(--sans); font-weight:700; font-size:.8rem; letter-spacing:.12em;
  text-transform:uppercase; color: var(--terracotta-d); margin-bottom:.9rem;
}
.notes { display:flex; flex-direction:column; gap:.6rem; }
.note {
  font-size:.88rem; padding:.75rem .85rem; border-radius:6px; line-height:1.35;
  box-shadow: 2px 4px 10px -6px rgba(60,42,30,.45); transform: rotate(-.6deg);
  color: #3a2c20;
}
.note:nth-child(even){ transform: rotate(.8deg); }
.note.y { background: #F3E2B8; }
.note.t { background: #E9C7A6; }
.note.s { background: #CFE0C4; }
.note.c { background: #F0CBC0; }

/* ============================================================
   COMPARISON TABLE
   ============================================================ */
.cmp { width:100%; border-collapse: separate; border-spacing:0; font-size:.95rem; }
.cmp-wrap { overflow-x:auto; border-radius: var(--radius); border:1px solid var(--line); box-shadow: var(--shadow-card); background:#fff;}
.cmp th, .cmp td { padding: 1rem 1.2rem; text-align:left; vertical-align:top; }
.cmp thead th {
  background: var(--cocoa); color: var(--cream); font-family:var(--sans);
  font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; font-weight:700;
}
.cmp tbody tr:not(:last-child) td { border-bottom:1px solid var(--line); }
.cmp tbody tr:hover { background: var(--cream-2); }
.cmp .plat { font-family:var(--serif); font-size:1.05rem; font-weight:600; color: var(--cocoa); }
.cmp .gap { color: var(--clay); font-weight:600; }
.cmp .sr-row td { background: linear-gradient(90deg, rgba(198,134,91,.14), rgba(198,134,91,.05)); }
.cmp .sr-row .plat { color: var(--terracotta-d); }

/* ============================================================
   FEATURE SHOWCASE
   ============================================================ */
.feature {
  display:grid; grid-template-columns: 1fr 0.85fr; gap: clamp(2rem,5vw,4rem);
  align-items:center;
}
.feature.flip { grid-template-columns: 0.85fr 1fr; }
.feature.flip .feature-media { order:-1; }
@media (max-width: 900px){
  .feature, .feature.flip { grid-template-columns:1fr; }
  .feature.flip .feature-media { order:0; }
}
.feature-media { display:flex; justify-content:center; }
.feature-media .device { max-width: 290px; }
.flagship-badge {
  display:inline-block; background: var(--cocoa); color: var(--cream);
  font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; font-weight:700;
  padding:.4rem .8rem; border-radius:100px; margin-bottom:1rem;
}
.pdo { display:grid; gap:1rem; margin-top:1.4rem; }
.pdo-item { display:grid; grid-template-columns: auto 1fr; gap:1rem; align-items:start; }
.pdo-tag {
  font-size:.64rem; letter-spacing:.14em; text-transform:uppercase; font-weight:800;
  padding:.4rem .55rem; border-radius:7px; white-space:nowrap; height:max-content;
}
.pdo-tag.p { background:#F0CBC0; color:#8a3f2e; }
.pdo-tag.d { background: var(--beige); color: var(--cocoa); }
.pdo-tag.o { background:#CFE0C4; color:#3f5e38; }
.pdo-item p { margin:0; font-size:.96rem; color: var(--ink-soft); }
.pdo-item strong { color: var(--ink); }

/* small feature list cards */
.featcard { border-left:3px solid var(--terracotta); }
.featcard .tag { font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; font-weight:700; color: var(--ink-faint);}

/* ============================================================
   EXPLAINABILITY
   ============================================================ */
.trust {
  display:grid; grid-template-columns: repeat(4,1fr); gap:1px;
  background: rgba(232,220,203,.18); border:1px solid rgba(232,220,203,.18);
  border-radius: var(--radius); overflow:hidden;
}
@media (max-width:760px){ .trust { grid-template-columns: repeat(2,1fr);} }
.trust div { background: var(--cocoa-mid); padding:1.5rem 1.3rem; }
.trust .k { font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color: var(--terracotta); font-weight:700; }
.trust h4 { color: var(--cream); margin:.6rem 0 .4rem; font-size:1.1rem; }
.trust p { font-size:.85rem; color: rgba(248,244,238,.72); margin:0; }

.risk-demo {
  background: var(--cocoa); border-radius: var(--radius); padding:1.8rem;
  color: var(--cream); box-shadow: var(--shadow-card);
}
.gauge { display:flex; align-items:center; gap:1.4rem; }
.gauge .ring {
  width:96px;height:96px;border-radius:50%; flex:none;
  background: conic-gradient(var(--sage) 0 72%, rgba(232,220,203,.18) 72% 100%);
  display:grid;place-items:center; position:relative;
}
.gauge .ring::before{ content:""; position:absolute; inset:10px; background:var(--cocoa); border-radius:50%; }
.gauge .ring span { position:relative; font-family:var(--serif); font-size:1.5rem; color: var(--cream); }
.bar { height:8px; border-radius:100px; background: rgba(232,220,203,.18); overflow:hidden; margin:.4rem 0 .2rem; }
.bar i { display:block; height:100%; background: linear-gradient(90deg, var(--amber), var(--terracotta)); border-radius:100px; }

/* ============================================================
   BRANDING
   ============================================================ */
.swatches { display:grid; grid-template-columns: repeat(4,1fr); gap:1rem; }
@media (max-width:760px){ .swatches { grid-template-columns: repeat(2,1fr);} }
.swatch { border-radius: var(--radius-sm); overflow:hidden; border:1px solid var(--line); background:#fff; }
.swatch .chipc { height:88px; }
.swatch .meta { padding:.8rem .9rem; }
.swatch .meta b { display:block; font-size:.92rem; }
.swatch .meta code { font-size:.78rem; color: var(--ink-faint); font-family: ui-monospace, monospace; }

.logo-breakdown { display:grid; grid-template-columns: repeat(3,1fr); gap:1.2rem; }
@media (max-width:820px){ .logo-breakdown { grid-template-columns:1fr; } }
.lb {
  background: var(--cocoa-deep); border-radius: var(--radius); padding:1.8rem;
  text-align:center; color: var(--cream); border:1px solid rgba(232,220,203,.12);
}
.lb .glyph { width:64px; height:64px; margin:0 auto 1rem; }
.lb h4 { color: var(--cream); font-size:1.15rem; }
.lb p { font-size:.88rem; color: rgba(248,244,238,.72); margin:.5rem 0 0; }
.lb .link { margin-top:.9rem; font-size:.74rem; letter-spacing:.04em; color: var(--terracotta); font-weight:600; }

.principles { display:grid; grid-template-columns: repeat(3,1fr); gap:.8rem; }
@media (max-width:760px){ .principles { grid-template-columns: repeat(2,1fr);} }
@media (max-width:460px){ .principles { grid-template-columns:1fr;} }
.principle { padding:1.1rem 1.2rem; border:1px solid var(--line); border-radius: var(--radius-sm); background:#fff; }
.principle b { font-family:var(--serif); font-size:1.1rem; color: var(--cocoa); }
.principle p { font-size:.85rem; margin:.3rem 0 0; color: var(--ink-soft); }

/* ============================================================
   JOURNEY
   ============================================================ */
.journey { overflow-x:auto; padding-bottom:.5rem; }
.journey-track { display:flex; gap:0; min-width:760px; }
.jstep { flex:1; min-width:120px; text-align:center; position:relative; padding-top:2.4rem; }
.jline { position:absolute; top:1.1rem; left:0; right:0; height:2px; background: var(--line); }
.jstep .dot { width:14px;height:14px;border-radius:50%; background: var(--terracotta); position:absolute; top:.55rem; left:50%; transform:translateX(-50%); box-shadow:0 0 0 4px var(--cream);}
.jstep h5 { font-family:var(--sans); font-size:.84rem; font-weight:700; margin:0 .4rem; color: var(--ink);}
.jstep .emo { font-size:.72rem; color: var(--ink-faint); margin-top:.3rem; padding:0 .3rem;}
.jstep .emo.up { color: var(--sage); font-weight:600; }

/* ============================================================
   REFLECTION / OUTCOME
   ============================================================ */
.skills { display:flex; flex-wrap:wrap; gap:.6rem; margin-top:1rem; }
.skills span {
  background: rgba(232,220,203,.16); border:1px solid rgba(232,220,203,.2);
  padding:.45rem .9rem; border-radius:100px; font-size:.85rem; font-weight:600; color: var(--beige);
}
.roadmap { display:grid; grid-template-columns: repeat(3,1fr); gap:1.2rem; }
@media (max-width:760px){ .roadmap { grid-template-columns:1fr; } }
.phase { border-top:2px solid var(--terracotta); padding-top:1.1rem; }
.phase .k { font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color: var(--terracotta); font-weight:700;}
.phase h4 { margin:.5rem 0; font-size:1.15rem; }
.phase p { font-size:.9rem; color: var(--ink-soft); margin:0; }

.closer {
  background:
    radial-gradient(90% 120% at 85% 0%, rgba(198,134,91,.28), transparent 55%),
    linear-gradient(160deg, var(--cocoa-deep), #1d1610);
  color: var(--cream); text-align:center; padding: clamp(4rem,9vw,7rem) 0;
}
.closer h2 { color: var(--cream); font-size: clamp(2rem,5vw,3.4rem); }
.closer .tagrow {
  display:inline-flex; gap:1.2rem; margin-top:1.6rem; flex-wrap:wrap; justify-content:center;
  font-family:var(--serif); font-style:italic; font-size:1.3rem; color: var(--terracotta);
}

/* footer */
.foot { background:#1d1610; color: rgba(248,244,238,.6); padding:2.4rem 0; font-size:.85rem; }
.foot .wrap { display:flex; justify-content:space-between; align-items:center; gap:1rem; flex-wrap:wrap; }
.disclaimer { font-size:.78rem; color: rgba(248,244,238,.45); max-width:60ch; }

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal { opacity:0; transform: translateY(22px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .reveal { opacity:1; transform:none; transition:none; }
  html { scroll-behavior:auto; }
}

/* hero load stagger — refined, springy reveal */
.hero .anim { opacity:0; transform: translateY(22px); animation: rise .9s both cubic-bezier(.16,.84,.28,1); }
.hero .a1{ animation-delay:.06s;} .hero .a2{animation-delay:.16s;} .hero .a3{animation-delay:.30s;}
.hero .a4{animation-delay:.42s;} .hero .a5{animation-delay:.56s;} .hero .a6{animation-delay:.70s;}
.hero .anim-phone { opacity:0; transform: translateY(28px) scale(.97); animation: heroPhoneIn 1.15s .34s both cubic-bezier(.16,.84,.28,1); }
@keyframes rise { to { opacity:1; transform:none; } }
@keyframes heroPhoneIn { to { opacity:1; transform:none; } }
@media (prefers-reduced-motion: reduce){
  .hero .anim, .hero .anim-phone { animation:none; opacity:1; transform:none; }
}

/* ============================================================
   ENHANCEMENTS · premium storytelling additions
   ============================================================ */

/* nav contact button */
.nav-contact {
  display: inline-flex; align-items: center;
  font-size: 0.85rem; font-weight: 700; letter-spacing: 0.01em;
  color: var(--cream); text-decoration: none;
  background: var(--terracotta); border: 1px solid rgba(232,220,203,.18);
  padding: 0.5rem 1.15rem; border-radius: 100px;
  transition: background .2s, transform .2s;
}
.nav-contact:hover { background: var(--terracotta-d); transform: translateY(-1px); }

/* hero · two-phone photo with the front screen looping */
.hero-stage {
  position: relative; width: 100%; max-width: 560px; margin-inline: auto;
  animation: heroFloat 7s ease-in-out 1.4s infinite;
}
.hero-glow {
  position: absolute; z-index: 0;
  left: 50%; top: 48%; transform: translate(-50%,-50%);
  width: 78%; aspect-ratio: 1; border-radius: 50%;
  background: radial-gradient(circle, rgba(198,134,91,.5) 0%, rgba(169,104,62,.22) 42%, transparent 70%);
  filter: blur(8px);
  animation: heroGlowPulse 6s ease-in-out infinite;
  pointer-events: none;
}
.hero-photo {
  position: relative; z-index: 1;
  width: 100%; height: auto; display: block;
  filter: drop-shadow(0 42px 70px rgba(20, 13, 8, .55));
}
.hero-screen {
  position: absolute; z-index: 2; left: 42.3%; top: 8.2%; width: 25%; height: 86.1%;
  border-radius: 9% / 3.8%; overflow: hidden;
}
.hero-screen .slide {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  opacity: 0; transform: scale(1.06);
  animation: heroCycle 12s infinite cubic-bezier(.45,0,.2,1);
}
.hero-screen .slide:nth-child(1){ animation-delay: 0s; }
.hero-screen .slide:nth-child(2){ animation-delay: 4s; }
.hero-screen .slide:nth-child(3){ animation-delay: 8s; }
@keyframes heroCycle {
  0%   { opacity: 0; transform: scale(1.07); }
  4%   { opacity: 1; }
  28%  { opacity: 1; transform: scale(1.005); }
  33%  { opacity: 0; transform: scale(1); }
  100% { opacity: 0; }
}
@keyframes heroFloat {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-12px); }
}
@keyframes heroGlowPulse {
  0%, 100% { opacity: .75; transform: translate(-50%,-50%) scale(1); }
  50%      { opacity: 1;   transform: translate(-50%,-50%) scale(1.06); }
}
@media (prefers-reduced-motion: reduce){
  .hero-stage, .hero-glow { animation: none; }
  .hero-screen .slide { animation: none; opacity: 0; transform: none; }
  .hero-screen .slide:nth-child(1){ opacity: 1; }
}

/* at-a-glance · more executive */
.glance h2 { font-size: .82rem; opacity: .8; }
.glance-grid { grid-template-columns: repeat(3,1fr); }
.glance-cell { padding: 1.5rem 1.35rem; }
.glance-cell .k { font-size: .72rem; color: var(--terracotta); opacity: 1; margin: .55rem 0 .5rem; }
.glance-cell .v { font-size: .92rem; line-height: 1.5; color: rgba(248,244,238,.86); }
@media (max-width: 880px){ .glance-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 540px){ .glance-grid { grid-template-columns: 1fr; } }

/* origin story (why I chose this problem) */
.origin {
  max-width: 60ch; margin-top: 2.2rem;
  border-left: 3px solid var(--terracotta);
  padding-left: clamp(1.2rem, 3vw, 2rem);
}
.origin p { font-size: 1.12rem; color: var(--ink-soft); margin: 0 0 1.1rem; }
.origin .origin-line { font-family: var(--serif); font-style: italic; font-size: 1.4rem; color: var(--cocoa); }
.origin .origin-emphasis {
  font-family: var(--serif); font-size: clamp(1.6rem, 3.4vw, 2.3rem);
  line-height: 1.1; color: var(--terracotta-d); margin: 1.4rem 0;
}
.origin .origin-foundation { font-weight: 700; color: var(--ink); font-size: 1.18rem; }

/* research objective */
.objective {
  background: var(--cream-2); border: 1px solid var(--line);
  border-left: 3px solid var(--terracotta); border-radius: var(--radius);
  padding: 1.5rem 1.7rem; margin-bottom: 1.6rem; box-shadow: var(--shadow-card);
}
.objective .k { font-size: .66rem; letter-spacing: .2em; text-transform: uppercase; color: var(--terracotta-d); font-weight: 700; }
.objective p { margin: .6rem 0 0; color: var(--ink-soft); font-size: 1.05rem; }

/* themes -> principles mapping */
.mapping { display: grid; gap: 1rem; }
.map-row {
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: stretch; gap: 1rem;
}
.map-finding, .map-decision {
  border-radius: var(--radius); padding: 1.3rem 1.5rem;
  border: 1px solid var(--line); background: #fff; box-shadow: var(--shadow-card);
}
.map-decision { background: var(--cocoa); border-color: var(--cocoa); }
.map-tag { font-size: .62rem; letter-spacing: .18em; text-transform: uppercase; font-weight: 700; color: var(--terracotta-d); }
.map-decision .map-tag { color: var(--terracotta); }
.map-finding h4, .map-decision h4 { margin: .45rem 0 0; font-size: 1.2rem; }
.map-decision h4 { color: var(--cream); }
.map-arrow { display: grid; place-items: center; color: var(--terracotta); font-size: 1.6rem; font-weight: 700; }
@media (max-width: 640px){
  .map-row { grid-template-columns: 1fr; }
  .map-arrow { transform: rotate(90deg); padding: .2rem 0; }
}

/* key findings · insight / evidence / decision */
.finding h3 { font-size: 1.24rem; margin-bottom: 1.1rem; }
.finding .fr { display: grid; grid-template-columns: auto 1fr; gap: .9rem; align-items: start; margin-bottom: .9rem; }
.finding .fr:last-child { margin-bottom: 0; }
.finding .fr p { margin: 0; font-size: .95rem; color: var(--ink-soft); }
.fr-tag {
  font-size: .6rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 800;
  padding: .38rem .5rem; border-radius: 7px; white-space: nowrap; height: max-content;
}
.fr-tag.i { background: var(--beige); color: var(--cocoa); }
.fr-tag.e { background: #F0CBC0; color: #8a3f2e; }
.fr-tag.d { background: #CFE0C4; color: #3f5e38; }

/* the strategic shift */
.shift { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; gap: 1.1rem; align-items: stretch; }
.shift-col {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  padding: 1.7rem 1.6rem; box-shadow: var(--shadow-card);
}
.shift-col .k { font-size: .66rem; letter-spacing: .18em; text-transform: uppercase; color: var(--terracotta-d); font-weight: 700; }
.shift-col p { margin: .7rem 0 0; font-family: var(--serif); font-size: 1.3rem; line-height: 1.2; color: var(--cocoa); }
.shift-col.accent { background: var(--cocoa); border-color: var(--cocoa); }
.shift-col.accent .k { color: var(--terracotta); }
.shift-col.accent p { color: var(--cream); font-size: 1.15rem; }
.shift-arrow { display: grid; place-items: center; color: var(--terracotta); font-size: 1.5rem; font-weight: 700; }
@media (max-width: 820px){
  .shift { grid-template-columns: 1fr; }
  .shift-arrow { transform: rotate(90deg); }
}

/* the opportunity (before problem statement) */
.opportunity {
  text-align: left; max-width: 60ch; margin: 0 auto 2.6rem;
  background: rgba(198,134,91,.12); border: 1px solid rgba(198,134,91,.3);
  border-radius: var(--radius); padding: 1.5rem 1.8rem;
}
.opportunity .k { font-size: .66rem; letter-spacing: .2em; text-transform: uppercase; color: var(--terracotta); font-weight: 700; }
.opportunity p { margin: .6rem 0 0; color: rgba(248,244,238,.9); font-size: 1.08rem; }

/* contact */
.contact-cards { display: grid; grid-template-columns: repeat(2,1fr); gap: 1.2rem; margin-top: .4rem; }
@media (max-width: 600px){ .contact-cards { grid-template-columns: 1fr; } }
.contact-card {
  display: flex; align-items: center; gap: 1.1rem; text-decoration: none;
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  padding: 1.4rem 1.5rem; box-shadow: var(--shadow-card);
  transition: transform .2s, box-shadow .2s, border-color .2s;
}
.contact-card:hover { transform: translateY(-3px); border-color: var(--terracotta); box-shadow: var(--shadow-soft); }
.contact-ico {
  width: 46px; height: 46px; flex: none; border-radius: 12px;
  display: grid; place-items: center; background: var(--beige); color: var(--cocoa);
}
.contact-ico svg { width: 22px; height: 22px; }
.contact-meta { display: flex; flex-direction: column; min-width: 0; }
.contact-label { font-size: .66rem; letter-spacing: .18em; text-transform: uppercase; color: var(--terracotta-d); font-weight: 700; }
.contact-value { font-family: var(--serif); font-size: 1.12rem; color: var(--cocoa); margin-top: .2rem; overflow-wrap: anywhere; }

/* ============================================================
   STORYTELLING REFINEMENTS · turning point, strategy, journey,
   feature elevation, future vision, contact finale
   ============================================================ */

.accent { color: var(--terracotta-d); }

/* the turning point */
.turning { padding-block: clamp(6rem, 13vw, 11rem); }
.turning-head { font-size: clamp(2rem, 5.2vw, 3.4rem); line-height: 1.08; }
.turning-body { margin-top: 2.4rem; }
.turning-body p { font-size: clamp(1.08rem, 2.1vw, 1.3rem); color: var(--ink-soft); margin: 0 auto 1rem; max-width: 48ch; }
.turning-body em { font-style: italic; }
.turning-lead { font-family: var(--serif); font-style: italic; color: var(--cocoa) !important; font-size: clamp(1.3rem,3vw,1.8rem) !important; margin-top: 1.8rem !important; }
.turning-q { display: flex; flex-direction: column; gap: .55rem; margin: 1.5rem auto 1.9rem; }
.turning-q span { font-family: var(--serif); font-size: clamp(1.4rem, 3.4vw, 2.1rem); color: var(--cocoa); line-height: 1.12; }
.turning-foundation { font-weight: 700; color: var(--ink) !important; font-size: 1.2rem !important; margin-top: 1.8rem !important; }
.turning-divider { width: 1px; height: clamp(3rem,7vw,5rem); background: linear-gradient(var(--terracotta), transparent); margin: clamp(2.4rem,6vw,4rem) auto 0; }

/* competitive · strategic observation card */
.strategic-card {
  background: var(--cocoa); color: var(--cream); border-radius: var(--radius);
  padding: 1.8rem 2rem; box-shadow: var(--shadow-soft); margin-bottom: 1.6rem;
  border-left: 4px solid var(--terracotta);
}
.strategic-card .k { font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color: var(--terracotta); font-weight:700; }
.strategic-card p { margin:.6rem 0 0; font-family: var(--serif); font-size: clamp(1.3rem,2.6vw,1.7rem); line-height:1.2; color: var(--cream); }

/* product strategy · principle cards */
.pgrid { gap: 1.1rem; }
.pcard { position: relative; padding-top: 1.8rem; transition: transform .25s, box-shadow .25s, border-color .25s; }
.pcard:hover { transform: translateY(-4px); box-shadow: var(--shadow-soft); border-color: var(--terracotta); }
.pcard .icon { background: linear-gradient(140deg, var(--beige), #f1e5d4); color: var(--cocoa); }
.pcard .pnum { position:absolute; top:1.3rem; right:1.4rem; font-family:var(--serif); font-size:1.15rem; color: var(--terracotta); opacity:.55; }
.pcard h3 { font-size: 1.12rem; line-height:1.15; }
.pcard p { font-size:.9rem; }

/* user journey · emotional progression */
.jstep .dot { transition: transform .2s, box-shadow .2s; }
.jstep h5 { line-height:1.2; }
.jstep .emo.up { color: var(--terracotta); font-weight: 700; }
.jstep.peak .dot { width:20px; height:20px; top:.35rem; box-shadow: 0 0 0 5px rgba(217,164,65,.18), 0 0 18px rgba(217,164,65,.6); }
.jstep.peak h5 { color: var(--terracotta-d); }
.jstep.peak .emo { color: var(--amber) !important; font-weight: 800; letter-spacing:.02em; }

/* design response transition */
.response { padding: clamp(3.2rem, 6vw, 4.8rem) 0; text-align:center; }
.response h2 { font-size: clamp(1.6rem, 3.4vw, 2.3rem); }
.response .lede { margin: 1rem auto 0; }
.response-chips { display:flex; flex-wrap:wrap; justify-content:center; gap:.7rem; margin-top:1.7rem; }
.response-chips span {
  background:#fff; border:1px solid var(--line); border-radius:100px;
  padding:.55rem 1.2rem; font-weight:600; font-size:.92rem; color: var(--cocoa);
  box-shadow: 0 6px 16px -12px rgba(60,42,30,.4);
}

/* onboarding · insight cards + why panel */
.insight-cards { display:grid; grid-template-columns: repeat(3,1fr); gap:.9rem; margin-top:1.7rem; }
@media (max-width:620px){ .insight-cards { grid-template-columns:1fr; } }
.insight-card {
  background:#fff; border:1px solid var(--line); border-radius: var(--radius-sm);
  padding:1.2rem; box-shadow: var(--shadow-card);
  transition: transform .2s, box-shadow .2s, border-color .2s;
}
.insight-card:hover { transform: translateY(-3px); border-color: var(--amber); box-shadow: var(--shadow-soft); }
.ic-ico { width:38px; height:38px; border-radius:10px; display:grid; place-items:center; background: rgba(217,164,65,.16); color:#a9742a; margin-bottom:.7rem; }
.ic-ico svg { width:19px; height:19px; }
.insight-card h4 { font-family: var(--sans); font-weight:700; font-size:.98rem; }
.insight-card p { font-size:.85rem; color: var(--ink-soft); margin:.4rem 0 0; }
.why-panel {
  margin-top:1.7rem;
  background: linear-gradient(140deg, rgba(217,164,65,.14), rgba(198,134,91,.07));
  border:1px solid rgba(217,164,65,.32); border-left:4px solid var(--amber);
  border-radius: var(--radius); padding:1.4rem 1.6rem;
}
.why-panel .k { font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:#a9742a; font-weight:700; }
.why-panel p { margin:.5rem 0 0; color: var(--ink-soft); font-size:.96rem; }

/* sleep safety score · centerpiece */
.sss-title { font-size: clamp(2rem, 4.4vw, 3rem); color: var(--cream); margin-top:.2rem; }
.device-glow { position: relative; }
.device-glow::after {
  content:""; position:absolute; inset:-14% -10%; z-index:-1;
  background: radial-gradient(58% 58% at 50% 42%, rgba(198,134,91,.5), transparent 70%);
  filter: blur(22px);
}
.feature-quote { margin: clamp(2.6rem,5vw,3.8rem) auto 0; max-width: 780px; text-align:center; }
.feature-quote p { font-family: var(--serif); font-style: italic; font-size: clamp(1.4rem,3vw,2rem); line-height:1.3; color: var(--cream); margin:0; }

/* ai explanation · explainable intelligence */
.big-quote { border-left: 4px solid var(--terracotta); padding-left: 1.4rem; }
.big-quote p { font-family: var(--serif); font-style: italic; font-size: clamp(1.35rem, 3vw, 2rem); line-height: 1.24; color: var(--cocoa); margin: 0; }
.ai-questions { display:flex; flex-wrap:wrap; gap:.7rem; margin-top: clamp(2.4rem,5vw,3.4rem); justify-content:center; }
.ai-questions span {
  background:#fff; border:1px solid var(--line); border-radius:100px;
  padding:.6rem 1.2rem; font-size:.92rem; color: var(--cocoa); font-weight:600;
  box-shadow: 0 8px 20px -14px rgba(60,42,30,.5);
}
.ai-close { text-align:center; max-width:640px; margin: 1.8rem auto 0; font-family: var(--serif); font-style: italic; font-size: clamp(1.15rem,2.4vw,1.5rem); color: var(--ink-soft); }

/* outcome · success list + vision card */
.success-list { list-style:none; padding:0; margin:.9rem 0 0; display:grid; gap:.85rem; }
.success-list li { position:relative; padding-left:1.9rem; color: var(--ink-soft); font-size:1rem; }
.success-list li::before {
  content:""; position:absolute; left:0; top:.4em; width:12px; height:12px; border-radius:50%;
  background: radial-gradient(circle at 32% 30%, var(--terracotta), var(--terracotta-d));
  box-shadow: 0 0 0 4px rgba(198,134,91,.14);
}
.vision-card { background: var(--cocoa); border-color: var(--cocoa); }
.vision-card h3 { color: var(--cream); }
.vision-card p { color: var(--beige); }

/* ============================================================
   CONTACT · closing chapter (hero-matched)
   ============================================================ */
.contact-hero {
  position: relative; overflow: hidden; color: var(--cream);
  background:
    radial-gradient(90% 80% at 80% 8%, rgba(198,134,91,.30), transparent 55%),
    radial-gradient(80% 70% at 8% 100%, rgba(169,104,62,.20), transparent 60%),
    linear-gradient(160deg, #1f1712 0%, var(--cocoa-deep) 45%, #3a281d 100%);
  padding: clamp(4.5rem, 10vw, 8rem) 0;
}
.contact-hero::after {
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}
.contact-grid {
  display:grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem,5vw,4rem);
  align-items:center; position:relative; z-index:1;
}
@media (max-width: 900px){ .contact-grid { grid-template-columns:1fr; } }
.contact-hero .eyebrow { color: var(--terracotta); }
.contact-hero h2 { color: var(--cream); font-size: clamp(2rem,4.6vw,3.2rem); line-height:1.05; }
.contact-hero .hero-mark { filter: drop-shadow(0 14px 30px rgba(198,134,91,.4)); margin-bottom:1.4rem; }
.contact-sub { color: rgba(248,244,238,.82); font-size:1.1rem; max-width:46ch; margin-top:1rem; }

.contact-hero .contact-cards { display:grid; grid-template-columns:1fr; gap:1rem; margin-top:1.9rem; }
.contact-hero .contact-card {
  background: rgba(28,21,17,.45); border:1px solid rgba(232,220,203,.16);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  box-shadow: 0 18px 40px -30px rgba(0,0,0,.7);
}
.contact-hero .contact-card:hover { border-color: var(--terracotta); background: rgba(44,30,21,.6); transform: translateY(-3px); }
.contact-hero .contact-ico { background: rgba(198,134,91,.18); color: var(--terracotta); }
.contact-hero .contact-label { color: var(--terracotta); }
.contact-hero .contact-value { color: var(--cream); }
.contact-arrow { margin-left:auto; align-self:center; color: var(--terracotta); font-size:1.2rem; transition: transform .2s; }
.contact-hero .contact-card:hover .contact-arrow { transform: translateX(4px); }

.contact-closer { margin-top: 2.2rem; border-top: 1px solid rgba(232,220,203,.16); padding-top: 1.6rem; }
.contact-statement { font-family: var(--serif); font-style: italic; font-size: clamp(1.3rem,2.6vw,1.7rem); color: var(--terracotta); margin:0; line-height:1.2; }
.contact-note { font-size:.82rem; letter-spacing:.03em; color: rgba(248,244,238,.6); margin:.9rem 0 0; }

.contact-visual { position:relative; display:flex; justify-content:center; align-items:center; min-height: 440px; }
.contact-glow {
  position:absolute; width:72%; height:72%; border-radius:50%;
  background: radial-gradient(circle, rgba(198,134,91,.42), transparent 70%); filter: blur(42px);
}
.contact-device { max-width: 258px; transform: rotate(2deg); position:relative; z-index:1; }
.float-card {
  position:absolute; z-index:2; border-radius:16px; padding:.9rem 1.05rem;
  background: rgba(26,19,14,.74); border:1px solid rgba(232,220,203,.18);
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  box-shadow: 0 26px 50px -28px rgba(0,0,0,.8);
}
.float-card .sc-k { font-size:.6rem; letter-spacing:.16em; text-transform:uppercase; color: var(--terracotta); font-weight:700; }
.score-card { top: 10%; left: -3%; }
.trend-card { bottom: 10%; right: -3%; width: 158px; }
.sc-row { display:flex; align-items:center; gap:.7rem; margin-top:.55rem; }
.sc-ring {
  width:48px; height:48px; border-radius:50%; flex:none; position:relative;
  background: conic-gradient(var(--sage) 0 78%, rgba(232,220,203,.16) 78% 100%);
  display:grid; place-items:center;
}
.sc-ring::before { content:""; position:absolute; inset:5px; background:#211913; border-radius:50%; }
.sc-ring span { position:relative; font-family:var(--serif); font-size:1.02rem; color: var(--cream); }
.sc-meta { display:flex; flex-direction:column; }
.sc-meta strong { color: var(--cream); font-family: var(--serif); font-size:.95rem; line-height:1.1; }
.sc-meta span { font-size:.72rem; color: rgba(248,244,238,.65); margin-top:.15rem; }
.trend-svg { width:100%; height:38px; margin-top:.5rem; display:block; }
@media (max-width: 460px){
  .score-card { left: 0; top: 4%; }
  .trend-card { right: 0; bottom: 4%; }
}
