/* futureproofwebsite.com — single stylesheet.
   Design goals map directly to the framework it teaches (P1/P2):
   - System font stack: zero web-font requests, no layout shift, fast LCP.
   - No external assets, no JS dependency for layout: CLS-safe, INP-safe.
   - WCAG 2.2 AA contrast, visible focus, reduced-motion respect. */

:root {
  --ink: #11181c;
  --ink-soft: #41525c;
  --paper: #ffffff;
  --wash: #f4f7f9;
  --line: #d8e0e5;
  --brand: #0b5d63;       /* deep teal — AA on white */
  --brand-dark: #07474c;
  --accent: #b3541e;      /* warm amber accent — AA on white */
  --green: #1a7f37;
  --amber: #9a6700;
  --red: #b42318;
  --maxw: 72rem;
  --radius: 10px;
}

* { box-sizing: border-box; }

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

body {
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  font-size: 1.0625rem;
  line-height: 1.65;
  text-rendering: optimizeLegibility;
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: 1.25rem; }
.section { padding-block: 2.25rem; }

h1, h2, h3 { line-height: 1.2; color: var(--ink); }
h1 { font-size: clamp(2rem, 5vw, 3rem); letter-spacing: -0.02em; }
h2 { font-size: clamp(1.4rem, 3vw, 1.9rem); letter-spacing: -0.01em; }
h3 { font-size: 1.2rem; }

a { color: var(--brand-dark); text-underline-offset: 2px; }
a:hover { color: var(--accent); }

p { margin: 0 0 1rem; }
.muted { color: var(--ink-soft); }
.small { font-size: 0.875rem; }
.lede { font-size: 1.25rem; color: var(--ink-soft); max-width: 46ch; }
.eyebrow { text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.8rem; font-weight: 700; color: var(--brand); margin-bottom: 0.5rem; }

/* Accessibility helpers */
.skip-link {
  position: absolute; left: 0; top: -3rem; background: var(--brand-dark); color: #fff;
  padding: 0.6rem 1rem; z-index: 100; transition: top 0.15s;
}
.skip-link:focus { top: 0; color: #fff; }
.visually-hidden {
  position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}
:focus-visible { outline: 3px solid var(--accent); outline-offset: 2px; border-radius: 3px; }

/* Header */
.site-header { border-bottom: 1px solid var(--line); background: var(--paper); position: sticky; top: 0; z-index: 50; }
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding-block: 0.85rem; }
.brand { display: inline-flex; align-items: center; gap: 0.5rem; font-weight: 700; text-decoration: none; color: var(--ink); font-size: 1.1rem; }
.brand-mark { color: var(--brand); }
.brand-name strong { color: var(--brand); font-weight: 800; }
.site-nav { display: flex; flex-wrap: wrap; gap: 0.25rem 1rem; }
.site-nav a { text-decoration: none; color: var(--ink-soft); font-weight: 600; font-size: 0.95rem; padding: 0.35rem 0.1rem; }
.site-nav a:hover { color: var(--brand-dark); }

/* Hero */
.hero { background: linear-gradient(180deg, var(--wash), var(--paper)); border-bottom: 1px solid var(--line); padding-block: 3.5rem 2.5rem; }
.hero h1 { max-width: 18ch; margin-bottom: 1rem; }
.hero h1 em { color: var(--brand); font-style: normal; }
.hero-niche { background: linear-gradient(180deg, #eef4f2, var(--paper)); }

/* Hero two-column: copy left, "what AI sees" card right */
.hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 2.75rem; align-items: center; }
@media (max-width: 60rem) { .hero-grid { grid-template-columns: 1fr; gap: 1.75rem; } }
.hero-copy h1 { max-width: 16ch; }

.ai-card { margin: 0; border-radius: 12px; overflow: hidden; background: #0f1c1f; border: 1px solid #20393e; box-shadow: 0 14px 34px rgba(11, 93, 99, 0.18); font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace; }
.ai-card-bar { display: flex; align-items: center; gap: 0.4rem; padding: 0.6rem 0.9rem; background: #14282c; border-bottom: 1px solid #20393e; }
.ai-dot { width: 0.62rem; height: 0.62rem; border-radius: 50%; background: #305057; }
.ai-card-title { margin-left: 0.5rem; color: #9ec1bd; font-size: 0.72rem; letter-spacing: 0.05em; text-transform: uppercase; }
.ai-card-body { margin: 0; padding: 0.95rem 1.15rem; color: #dceae8; font-size: 0.85rem; line-height: 1.55; overflow-x: auto; }
.ai-card-body code { background: none; color: inherit; padding: 0; font-size: inherit; }
.t-key { color: #6fd3ca; }
.t-str { color: #e8b888; }
.ai-card-div { padding: 0.45rem 1.15rem; font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.07em; color: #9ec1bd; background: #14282c; border-top: 1px solid #20393e; border-bottom: 1px solid #20393e; }
.ai-card-llms { color: #b9d4d0; font-size: 0.82rem; }
.ai-card-cap { padding: 0.65rem 1.15rem; font-size: 0.76rem; color: #9ec1bd; background: #14282c; }
.ai-card-cap a { color: #e8efee; text-decoration: underline; }

.page-head { background: var(--wash); border-bottom: 1px solid var(--line); padding-block: 2.25rem; }
.page-head h1 { margin: 0.25rem 0 0.75rem; }

/* Buttons */
.cta-row { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-top: 1.25rem; }
.btn { display: inline-block; padding: 0.7rem 1.25rem; border-radius: var(--radius); font-weight: 700; text-decoration: none; border: 2px solid transparent; }
.btn-primary { background: var(--brand-dark); color: #fff; }
.btn-primary:hover { background: var(--brand); color: #fff; }
.btn-ghost { border-color: var(--line); color: var(--brand-dark); background: #fff; }
.btn-ghost:hover { border-color: var(--brand); color: var(--brand-dark); }

/* Answer-layer unit — the visual signature of P3 */
.answer-unit {
  background: #eef4f2; border-left: 5px solid var(--brand);
  padding: 1.1rem 1.25rem; border-radius: 0 var(--radius) var(--radius) 0; margin: 0 0 1.75rem;
}
.answer-unit p { margin-bottom: 0; }
.answer-label { text-transform: uppercase; letter-spacing: 0.06em; font-size: 0.72rem; font-weight: 800; color: var(--brand); margin-bottom: 0.4rem !important; }

/* Stages list */
.stages { padding-left: 1.25rem; }
.stages li { margin-bottom: 0.5rem; }

/* Conversion homepage sections */
.section-lede { font-size: 1.1rem; color: var(--ink-soft); max-width: 52ch; }
.section-head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.section-alt-wrap { background: var(--wash); border-radius: var(--radius); padding: 1.75rem; }

/* The Shift band */
.shift { background: var(--brand-dark); color: #fff; padding-block: 3rem; }
.shift-head { color: #fff; margin: 0 0 1.9rem; max-width: 28ch; }
.shift-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem 2.25rem; align-items: start; counter-reset: shift; }
@media (max-width: 52rem) { .shift-grid { grid-template-columns: 1fr; gap: 1.5rem; } }
.shift-item { padding-top: 0.9rem; border-top: 2px solid var(--accent); }
.shift-item::before { counter-increment: shift; content: "0" counter(shift); display: block; color: var(--accent); font-weight: 800; font-size: 0.78rem; letter-spacing: 0.12em; margin-bottom: 0.55rem; }
.shift-item h3 { color: #fff; font-size: 1.05rem; margin: 0 0 0.5rem; line-height: 1.3; }
.shift-item p { color: #cfe1e0; margin: 0; max-width: 34ch; line-height: 1.6; }

/* Author credibility block */
.author-block { display: flex; gap: 1.5rem; align-items: flex-start; background: var(--wash); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.5rem; }
.author-avatar { flex: 0 0 auto; width: 4.5rem; height: 4.5rem; border-radius: 50%; background: var(--brand-dark); color: #fff; font-weight: 800; font-size: 1.4rem; letter-spacing: 0.02em; display: flex; align-items: center; justify-content: center; }
.author-body h2 { margin-top: 0; }
.cred-chips { list-style: none; display: flex; flex-wrap: wrap; gap: 0.5rem; padding: 0; margin: 1rem 0; }
.cred-chips li { background: #fff; border: 1px solid var(--line); border-radius: 999px; padding: 0.25rem 0.75rem; font-size: 0.82rem; font-weight: 700; color: var(--brand-dark); }
@media (max-width: 36rem) { .author-block { flex-direction: column; gap: 1rem; } }

/* Blog-style home: two-column feed + sidebar */
.blog-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 18rem;
  gap: 2.5rem;
  padding-block: 2.5rem;
}
@media (max-width: 56rem) {
  .blog-layout { grid-template-columns: 1fr; gap: 1.5rem; }
}

.post-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem 0.75rem; margin-bottom: 0.4rem; }
.post-meta .tag { text-decoration: none; }
a.tag:hover { text-decoration: underline; }

/* Featured post */
.post-featured { padding-bottom: 1.75rem; border-bottom: 2px solid var(--line); margin-bottom: 1.75rem; }
.post-featured-title { font-size: clamp(1.6rem, 3.5vw, 2.2rem); line-height: 1.15; margin: 0.25rem 0 0.6rem; }
.post-featured-title a { color: var(--ink); text-decoration: none; }
.post-featured-title a:hover { color: var(--brand-dark); }
.post-excerpt { font-size: 1.05rem; margin-bottom: 0.6rem; }
.post-byline { margin: 0; }
.post-byline a { font-weight: 700; }

/* Feed list */
.feed-heading { font-size: 1.05rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ink-soft); border-bottom: 1px solid var(--line); padding-bottom: 0.4rem; margin: 0 0 1.25rem; }
.post-list { list-style: none; padding: 0; margin: 0; }
.post-item { padding-bottom: 1.4rem; margin-bottom: 1.4rem; border-bottom: 1px solid var(--line); }
.post-item:last-child { border-bottom: none; }
.post-item h3 { font-size: 1.3rem; margin: 0.15rem 0 0.5rem; }
.post-item h3 a { color: var(--ink); text-decoration: none; }
.post-item h3 a:hover { color: var(--brand-dark); text-decoration: underline; }
.post-item .post-excerpt { font-size: 1rem; margin-bottom: 0; }

.readmore { font-weight: 700; text-decoration: none; }
.readmore:hover { text-decoration: underline; }

/* Sidebar */
.blog-aside { display: flex; flex-direction: column; gap: 1.1rem; }
@media (min-width: 56.01rem) { .blog-aside { position: sticky; top: 4.5rem; align-self: start; } }
.aside-card { border: 1px solid var(--line); border-radius: var(--radius); padding: 1rem 1.1rem; background: #fff; }
.aside-card h2 { font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.07em; color: var(--brand); margin: 0 0 0.5rem; }
.aside-card-feature { background: #eef4f2; border-color: #cfe1dd; border-left: 4px solid var(--brand); }
.aside-card p:last-child { margin-bottom: 0; }
.aside-list { list-style: none; padding: 0; margin: 0 0 0.6rem; }
.aside-list li { display: flex; justify-content: space-between; gap: 0.5rem; padding: 0.3rem 0; border-bottom: 1px solid var(--wash); }
.aside-list li:last-child { border-bottom: none; }
.aside-list a { text-decoration: none; font-weight: 600; }
.aside-list a:hover { text-decoration: underline; }
.aside-list-radar li { display: block; padding: 0.45rem 0; }
.aside-list-radar a { display: block; line-height: 1.35; }
.radar-date { display: block; margin-top: 0.15rem; }

/* Pillar + card grids */
.pillar-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr)); gap: 1rem; margin-top: 1rem; }
.pillar-card { border: 1px solid var(--line); border-radius: var(--radius); padding: 1.1rem; background: #fff; }
.pillar-card h3 { margin: 0.2rem 0 0.5rem; }
.pillar-points { font-weight: 800; color: var(--accent); margin: 0; }

.card-list { list-style: none; padding: 0; margin: 1rem 0 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(17rem, 1fr)); gap: 1rem; }
.card { border: 1px solid var(--line); border-radius: var(--radius); padding: 1.1rem 1.25rem; background: #fff; }
.card h2, .card h3 { margin: 0.35rem 0 0.5rem; }
.card a { text-decoration: none; }
.card a:hover { text-decoration: underline; }
.tag { display: inline-block; font-size: 0.72rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.05em; color: var(--brand); margin: 0; }
.niche-card code { background: var(--wash); padding: 0.1rem 0.35rem; border-radius: 4px; font-size: 0.85em; }

/* Framework tables + criteria */
.score-summary { width: 100%; border-collapse: collapse; margin: 1.25rem 0; max-width: 28rem; }
.score-summary th, .score-summary td { text-align: left; padding: 0.5rem 0.75rem; border-bottom: 1px solid var(--line); }
.score-summary td { text-align: right; font-variant-numeric: tabular-nums; }
.score-summary tfoot th, .score-summary tfoot td { font-weight: 800; border-bottom: none; }
.score-summary a { text-decoration: none; }

.version-tag { font-size: 0.9rem; font-weight: 700; color: var(--accent); vertical-align: middle; background: #fbeee4; padding: 0.1rem 0.5rem; border-radius: 999px; }

.principle-note { background: #f3f0ea; border: 1px solid #e4ddd0; border-left: 5px solid var(--accent); border-radius: 0 var(--radius) var(--radius) 0; padding: 1rem 1.25rem; margin: 1.5rem 0; }
.principle-note p:last-child { margin-bottom: 0; }
.principle-label { text-transform: uppercase; letter-spacing: 0.06em; font-size: 0.72rem; font-weight: 800; color: var(--accent); margin-bottom: 0.4rem !important; }

.check-legend { font-size: 0.9rem; color: var(--ink-soft); margin-top: 1rem; }
.audit-cta { display: flex; align-items: center; justify-content: space-between; gap: 1.25rem; flex-wrap: wrap; background: #eef4f2; border: 1px solid #cfe1dd; border-left: 5px solid var(--brand); border-radius: var(--radius); padding: 1.1rem 1.4rem; margin: 1.5rem 0; }
.audit-cta h2 { margin: 0 0 0.3rem; font-size: 1.2rem; }
.audit-cta p { margin: 0; max-width: 48ch; }
.audit-cta .btn { white-space: nowrap; }
.check-badge { display: inline-block; font-size: 0.68rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.04em; padding: 0.1rem 0.5rem; border-radius: 999px; white-space: nowrap; }
.check-self { background: #e3f1e7; color: var(--green); }
.check-assisted { background: #fbeee4; color: var(--accent); }

/* Interactive scorer (Phase 2) — the live "surface" over the static checklist */
.scorer { position: sticky; top: 4.1rem; z-index: 30; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1rem 1.25rem; margin-top: 1.25rem; box-shadow: 0 6px 18px rgba(11, 93, 99, 0.10); }
.scorer-top { display: flex; align-items: center; gap: 0.75rem 1rem; flex-wrap: wrap; }
.scorer-num { font-size: 2.3rem; font-weight: 800; line-height: 1; margin: 0; font-variant-numeric: tabular-nums; }
.scorer-den { font-size: 1rem; font-weight: 600; color: var(--ink-soft); }
.scorer-band { font-weight: 800; font-size: 0.85rem; padding: 0.2rem 0.7rem; border-radius: 999px; background: var(--wash); color: var(--ink-soft); }
.scorer-band.score-green { background: #e3f1e7; color: var(--green); }
.scorer-band.score-amber { background: #fbf1e3; color: var(--amber); }
.scorer-band.score-red { background: #fbe7e5; color: var(--red); }
.scorer-reset { margin-left: auto; border: 1px solid var(--line); background: #fff; color: var(--brand-dark); font-weight: 700; padding: 0.4rem 0.85rem; border-radius: var(--radius); cursor: pointer; font-size: 0.85rem; }
.scorer-reset:hover { border-color: var(--brand); }
.scorer-meta { margin: 0.5rem 0 0.75rem; }
.scorer-bars { display: grid; gap: 0.45rem; }
.scorer-bar-row { display: grid; grid-template-columns: minmax(8rem, 14rem) 1fr 3rem; gap: 0.6rem; align-items: center; font-size: 0.85rem; }
.scorer-bar-name { text-decoration: none; color: var(--ink); font-weight: 600; }
.scorer-bar-name:hover { color: var(--brand-dark); text-decoration: underline; }
.scorer-track { background: var(--wash); border-radius: 999px; height: 0.55rem; overflow: hidden; }
.scorer-fill { display: block; height: 100%; width: 0; background: var(--brand); border-radius: 999px; transition: width 0.25s ease; }
.scorer-bar-val { text-align: right; font-variant-numeric: tabular-nums; color: var(--ink-soft); font-weight: 600; }
@media (max-width: 36rem) { .scorer-bar-row { grid-template-columns: 1fr 3rem; } .scorer-track { grid-column: 1 / -1; order: 3; } }

/* Bands become selectable when the scorer is active */
.bands[role="radiogroup"] .band { border: 1px solid transparent; border-radius: 7px; padding: 0.25rem 0.4rem; transition: background 0.12s, border-color 0.12s; }
.band-label { display: flex; gap: 0.55rem; align-items: flex-start; cursor: pointer; }
.band-radio { margin: 0.3rem 0 0; flex: 0 0 auto; accent-color: var(--brand); }
.bands[role="radiogroup"] .band:hover { background: var(--wash); }
.band-green.band-selected { background: #e3f1e7; border-color: var(--green); }
.band-amber.band-selected { background: #fbf1e3; border-color: var(--amber); }
.band-red.band-selected { background: #fbe7e5; border-color: var(--red); }
.criterion-scored { border-left: 4px solid var(--brand); }

.pillar-section { border-top: 1px solid var(--line); }
.pillar-head h2 { display: flex; flex-wrap: wrap; align-items: baseline; gap: 0.6rem; }
.pillar-points-inline { font-size: 0.9rem; color: var(--accent); font-weight: 700; }
.criterion { border: 1px solid var(--line); border-radius: var(--radius); padding: 1rem 1.25rem; margin-bottom: 1rem; background: #fff; }
.criterion h3 { display: flex; flex-wrap: wrap; align-items: baseline; gap: 0.5rem; }
.criterion-id { background: var(--brand-dark); color: #fff; font-size: 0.72rem; font-weight: 800; padding: 0.1rem 0.45rem; border-radius: 4px; }
.criterion-points { margin-left: auto; font-size: 0.85rem; color: var(--ink-soft); font-weight: 700; }
.bands { list-style: none; padding: 0; margin: 0.75rem 0 0; display: grid; gap: 0.4rem; }
.band { font-size: 0.92rem; padding-left: 0.25rem; }
.band span { display: inline-block; min-width: 4.2rem; font-weight: 800; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.04em; }
.band-green span { color: var(--green); }
.band-amber span { color: var(--amber); }
.band-red span { color: var(--red); }

/* Guide body typography */
.guide-body { max-width: 44rem; }
.guide-body h2 { margin-top: 2rem; }
.guide-body h3 { margin-top: 1.5rem; }
.guide-body ul, .guide-body ol { padding-left: 1.4rem; }
.guide-body li { margin-bottom: 0.4rem; }
.guide-body code { background: var(--wash); padding: 0.1rem 0.35rem; border-radius: 4px; font-size: 0.9em; }
.guide-body pre { background: #0f1c1f; color: #e6f0ef; padding: 1rem; border-radius: var(--radius); overflow-x: auto; }
.guide-body pre code { background: none; padding: 0; color: inherit; }
.guide-body blockquote { border-left: 4px solid var(--line); margin: 1.25rem 0; padding-left: 1rem; color: var(--ink-soft); }
/* Featured expert quote */
.expert-quote { margin: 2rem 0; padding: 1.25rem 1.5rem; background: var(--wash); border-left: 5px solid var(--accent); border-radius: 0 var(--radius) var(--radius) 0; }
.expert-quote blockquote { margin: 0 0 0.6rem; font-size: 1.15rem; line-height: 1.5; color: var(--ink); }
.expert-quote blockquote::before { content: "\201C"; color: var(--accent); font-weight: 800; }
.expert-quote blockquote::after { content: "\201D"; color: var(--accent); font-weight: 800; }
.expert-quote figcaption { font-size: 0.9rem; font-weight: 700; color: var(--brand-dark); }
.expert-quote .quote-role { display: block; font-weight: 400; color: var(--ink-soft); }

.byline { color: var(--ink-soft); font-size: 0.92rem; }
.breadcrumb { font-size: 0.9rem; color: var(--ink-soft); margin-bottom: 0.5rem; }
.breadcrumb a { color: var(--brand-dark); text-decoration: none; }

/* Signup */
.signup { background: var(--brand-dark); color: #fff; border-radius: var(--radius); padding: 1.75rem; }
.signup h2 { color: #fff; margin-top: 0; }
.signup .muted, .signup .small { color: #cfe1e0; }
.signup a { color: #fff; text-decoration: underline; }
.signup a:hover { color: #fff; }
.cookie-table td:first-child { white-space: nowrap; }
.cookie-table td { text-align: left; }
.signup-form { display: flex; flex-wrap: wrap; gap: 0.6rem; margin: 1rem 0 0.6rem; }
.signup-form input[type=email] { flex: 1 1 16rem; padding: 0.7rem 0.85rem; border-radius: var(--radius); border: 2px solid transparent; font-size: 1rem; }
.signup-form button { padding: 0.7rem 1.4rem; border: none; border-radius: var(--radius); background: var(--accent); color: #fff; font-weight: 800; cursor: pointer; font-size: 1rem; }
.signup-form button:hover { background: #93430f; }

/* Pricing / audit CTA card (brand-toned version of the dark pricing card) */
.pricing-card { background: #0f1c1f; border: 1px solid #20393e; border-radius: 14px; padding: 2.1rem 2.25rem; text-align: center; box-shadow: 0 14px 34px rgba(11, 93, 99, 0.18); }
.pricing-price { display: flex; flex-wrap: wrap; align-items: baseline; justify-content: center; gap: 0.35rem 0.6rem; margin: 0 0 1.1rem; }
.pricing-amount { font-size: 2.7rem; font-weight: 800; color: #6fd3ca; line-height: 1; }
.pricing-note { color: #9ec1bd; font-size: 0.95rem; }
.pricing-arrow { color: #5d8086; margin: 0 0.15rem; font-size: 1.2rem; }
.pricing-old { font-size: 1.5rem; font-weight: 700; color: #5d8086; text-decoration: line-through; }
.pricing-body { color: #cfe1e0; max-width: 62ch; margin: 0 auto 1rem; line-height: 1.65; }
.pricing-free { color: #e8efee; }
.pricing-free a { color: #6fd3ca; text-decoration: underline; }
.pricing-cta { justify-content: center; margin-top: 1.25rem; }

/* Audit tool */
.audit-form { background: var(--wash); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.25rem; margin-bottom: 1.5rem; }
.audit-label { display: block; font-weight: 700; margin-bottom: 0.5rem; }
.audit-row { display: flex; flex-wrap: wrap; gap: 0.6rem; }
.audit-row input { flex: 1 1 18rem; padding: 0.7rem 0.85rem; border-radius: var(--radius); border: 2px solid var(--line); font-size: 1rem; }
.audit-row input:focus-visible { border-color: var(--brand); }
.audit-row button { padding: 0.7rem 1.4rem; border: none; border-radius: var(--radius); background: var(--brand-dark); color: #fff; font-weight: 800; cursor: pointer; font-size: 1rem; }
.audit-row button:hover { background: var(--brand); }

.audit-score { display: flex; align-items: center; gap: 1.25rem; flex-wrap: wrap; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.25rem 1.5rem; }
.audit-score-num { font-size: 3rem; font-weight: 800; line-height: 1; margin: 0; padding: 0.3rem 0.8rem; border-radius: var(--radius); }
.audit-score-den { font-size: 1.2rem; }
.audit-score-line { margin: 0 0 0.3rem; }

.audit-criterion { border: 1px solid var(--line); border-left-width: 5px; border-radius: var(--radius); padding: 0.85rem 1.1rem; margin-bottom: 0.7rem; background: #fff; }
.audit-green { border-left-color: var(--green); }
.audit-amber { border-left-color: var(--amber); }
.audit-red { border-left-color: var(--red); }
.audit-manual { border-left-color: var(--ink-soft); background: var(--wash); }
.audit-criterion-head { display: flex; align-items: center; gap: 0.6rem; flex-wrap: wrap; }
.audit-cname { font-weight: 700; }
.audit-verdict { margin-left: auto; font-size: 0.75rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.03em; padding: 0.15rem 0.55rem; border-radius: 999px; white-space: nowrap; }
.audit-verdict-green { background: #e3f1e7; color: var(--green); }
.audit-verdict-amber { background: #fbf1e3; color: var(--amber); }
.audit-verdict-red { background: #fbe7e5; color: var(--red); }
.audit-verdict-manual { background: #e7edf0; color: var(--ink-soft); }
.audit-detail { margin: 0.5rem 0 0; color: var(--ink-soft); font-size: 0.95rem; }
.advisory h2 { margin-top: 0; }

/* Premium report CTA (post-audit upsell) */
.premium-cta { background: #eef4f2; border: 1px solid #cfe1dd; border-left: 5px solid var(--brand); border-radius: var(--radius); padding: 1.5rem 1.75rem; }
.premium-cta h2 { margin-top: 0; }
.premium-benefits { list-style: none; padding: 0; margin: 1.1rem 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.5rem 1.75rem; }
@media (max-width: 40rem) { .premium-benefits { grid-template-columns: 1fr; } }
.premium-benefits li { padding-left: 1.6rem; position: relative; line-height: 1.5; }
.premium-benefits li::before { content: "\2713"; position: absolute; left: 0; top: 0; color: var(--green); font-weight: 800; }
.premium-foot { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 0.75rem 1.25rem; border-top: 1px solid #cfe1dd; padding-top: 1.1rem; margin-top: 0.5rem; }
.premium-price { margin: 0; }
.premium-amount { font-size: 1.9rem; font-weight: 800; color: var(--brand-dark); }
.premium-old { text-decoration: line-through; color: var(--ink-soft); margin-left: 0.3rem; }
.premium-foot .cta-row { margin: 0; }
.premium-advisory { margin: 0.85rem 0 0; }
.embed-code { width: 100%; font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size: 0.8rem; padding: 0.6rem 0.75rem; border: 1px solid var(--line); border-radius: var(--radius); background: #fff; color: var(--ink); resize: vertical; }

/* Draft banner (phased publishing) */
.draft-banner { background: #fbeee4; border-bottom: 2px solid var(--accent); color: #7a3a14; padding: 0.6rem 0; font-size: 0.92rem; }
.draft-banner strong { color: var(--accent); }

/* Notices + flash */
.notice { background: var(--wash); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.1rem 1.25rem; }
.flash-region { background: #eef4f2; border-bottom: 1px solid var(--line); }
.flash { margin: 0; padding: 0.7rem 0; font-weight: 600; }
.flash-error { color: var(--red); }
.flash-success { color: var(--green); }

/* Footer */
.site-footer { border-top: 1px solid var(--line); background: var(--wash); margin-top: 2rem; padding-block: 2rem; }
.footer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr)); gap: 1.5rem; align-items: start; }
.footer-brand { font-weight: 800; margin: 0; }
.air-badge { display: inline-flex; align-items: stretch; margin-top: 0.85rem; border-radius: 6px; overflow: hidden; font-size: 0.88rem; font-weight: 800; letter-spacing: 0.02em; text-decoration: none; line-height: 1; box-shadow: 0 1px 3px rgba(11,93,99,0.15); }
.air-badge-k { background: #2d3b40; color: #fff; padding: 0.5rem 0.66rem; }
.air-badge-v { background: var(--green); color: #fff; padding: 0.5rem 0.66rem; }
.air-badge:hover .air-badge-v { background: #166a2e; }
.air-badge:hover .air-badge-k { background: #1f2a2e; }
.air-badge-lg { font-size: 0.95rem; border-radius: 7px; }
.air-badge-lg .air-badge-k, .air-badge-lg .air-badge-v { padding: 0.55rem 0.8rem; }
.about-badge-row { display: flex; align-items: center; gap: 0.85rem; flex-wrap: wrap; margin: 0.5rem 0 1rem; }
.about-badge-row .muted { font-size: 0.95rem; }
.footer-brand strong { color: var(--brand); }
.site-footer nav { display: flex; flex-direction: column; gap: 0.35rem; }
.site-footer nav a { text-decoration: none; color: var(--brand-dark); }
.site-footer nav a:hover { text-decoration: underline; }

/* ── GEO/AEO scan ─────────────────────────────────────────────────────── */
.hp { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; }
.audit-form input[type="email"] { width: 100%; padding: 0.7rem 0.85rem; border-radius: var(--radius); border: 2px solid var(--line); font-size: 1rem; margin-bottom: 0.75rem; }
.audit-form input[type="email"]:focus-visible { border-color: var(--brand); }
.audit-form .audit-label + .audit-label { margin-top: 0.25rem; }

/* band colours (scorer keys: good | warn | poor) */
.band-good { --band: var(--green); }
.band-warn { --band: var(--amber); }
.band-poor { --band: var(--red); }

/* landing: what-we-grade grid */
.geo-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr)); gap: 1rem; margin: 1rem 0 1.5rem; }
.geo-cell { border: 1px solid var(--line); border-radius: var(--radius); padding: 1.1rem; background: #fff; }
.geo-cell h3 { margin: 0.5rem 0 0.35rem; font-size: 1.05rem; }
.geo-cell p { margin: 0; color: var(--ink-soft); font-size: 0.95rem; }

.geo-tag { display: inline-block; font-size: 0.72rem; font-weight: 800; letter-spacing: 0.04em; text-transform: uppercase; padding: 0.15rem 0.5rem; border-radius: 999px; color: #fff; }
.geo-tag-geo { background: var(--brand-dark); }
.geo-tag-aeo { background: var(--accent); }
.geo-tag-seo { background: #475569; }
.geo-tag-schema { background: #0b5d63; }
.geo-tag-auth { background: #6b4c9a; }

/* scanning page */
.geo-progress { text-align: center; padding: 2.5rem 1rem; }
.geo-spinner { width: 2.5rem; height: 2.5rem; margin: 0 auto 1rem; border: 4px solid var(--line); border-top-color: var(--brand); border-radius: 50%; animation: geo-spin 0.9s linear infinite; }
@keyframes geo-spin { to { transform: rotate(360deg); } }
.geo-progress-status { font-weight: 700; color: var(--brand-dark); }

/* results: scorecards */
.geo-scorecards { display: grid; grid-template-columns: repeat(auto-fit, minmax(8rem, 1fr)); gap: 0.9rem; margin: 0.5rem 0 2rem; }
.geo-score { border: 1px solid var(--line); border-top: 4px solid var(--band, var(--line)); border-radius: var(--radius); padding: 1rem; text-align: center; background: #fff; display: flex; flex-direction: column; gap: 0.15rem; }
.geo-score-lead { background: var(--wash); }
.geo-score-num { font-size: 2.4rem; font-weight: 800; line-height: 1; color: var(--band, var(--ink)); }
.geo-score-lead .geo-score-num { font-size: 3rem; }
.geo-score-cap { font-weight: 700; }
.geo-score-band { font-size: 0.85rem; color: var(--ink-soft); }

/* results: two columns (priorities / quick wins) */
.geo-cols { display: grid; grid-template-columns: 1.4fr 1fr; gap: 2rem; margin-bottom: 1.5rem; }
@media (max-width: 40rem) { .geo-cols { grid-template-columns: 1fr; } }
.geo-issues { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.75rem; }
.geo-issues li { border-left: 4px solid var(--line); padding: 0.6rem 0 0.6rem 0.9rem; }
.geo-issues li.sev-critical { border-left-color: var(--red); }
.geo-issues li.sev-warning { border-left-color: var(--amber); }
.geo-issues li.sev-info { border-left-color: var(--brand); }
.geo-issue-dim { display: inline-block; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.03em; color: var(--ink-soft); margin-left: 0.4rem; }
.geo-issues p, .geo-findings p { margin: 0.3rem 0 0; font-size: 0.95rem; color: var(--ink-soft); }
.geo-fix { color: var(--brand-dark) !important; font-weight: 600; }
.geo-wins { padding-left: 1.1rem; }
.geo-wins li { margin-bottom: 0.5rem; }

/* results: per-dimension accordions */
.geo-dims { display: grid; gap: 0.5rem; margin-bottom: 2rem; }
.geo-dim { border: 1px solid var(--line); border-radius: var(--radius); background: #fff; }
.geo-dim summary { display: grid; grid-template-columns: 1fr 8rem auto; align-items: center; gap: 1rem; padding: 0.85rem 1rem; cursor: pointer; }
@media (max-width: 40rem) { .geo-dim summary { grid-template-columns: 1fr auto; } .geo-dim summary .bar { display: none; } }
.geo-dim-head { display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }
.geo-dim-name { font-weight: 700; }
.geo-dim-score { font-weight: 800; font-size: 1.1rem; color: var(--band, var(--ink)); min-width: 2ch; text-align: right; }
.bar { display: block; height: 0.55rem; background: var(--line); border-radius: 999px; overflow: hidden; }
.bar-fill { display: block; height: 100%; width: 0; background: var(--band, var(--brand)); transition: width 0.6s ease; }
.geo-dim-body { padding: 0 1rem 1rem; border-top: 1px solid var(--line); }
.geo-findings { list-style: none; padding: 0; margin: 0.75rem 0 0; display: grid; gap: 0.6rem; }
.geo-findings li { border-left: 3px solid var(--line); padding-left: 0.8rem; }
.geo-findings li.sev-critical { border-left-color: var(--red); }
.geo-findings li.sev-warning { border-left-color: var(--amber); }
.geo-findings li.sev-info { border-left-color: var(--green); }

.geo-next { background: var(--wash); border-radius: var(--radius); padding: 1.5rem; }
.geo-next h2 { margin-top: 0; }
.audit-form textarea { width: 100%; padding: 0.7rem 0.85rem; border-radius: var(--radius); border: 2px solid var(--line); font-size: 1rem; font-family: inherit; resize: vertical; margin-bottom: 0.75rem; }
.audit-form textarea:focus-visible { border-color: var(--brand); }
.geo-score-solo { max-width: 16rem; }

/* ── Homepage: three fronts of AI search (AIO / GEO / AEO) ─────────────── */
.fronts { background: var(--wash); border-block: 1px solid var(--line); }
.fronts-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; margin-top: 1.25rem; }
@media (max-width: 48rem) { .fronts-grid { grid-template-columns: 1fr; } }
.front-card { background: #fff; border: 1px solid var(--line); border-top: 4px solid var(--brand); border-radius: var(--radius); padding: 1.25rem; display: flex; flex-direction: column; }
.front-card.front-aio { border-top-color: var(--accent); }
.front-card.front-geo { border-top-color: var(--brand-dark); }
.front-card.front-aeo { border-top-color: #6b4c9a; }
.front-acr { font-size: 1.6rem; font-weight: 800; color: var(--ink); line-height: 1.1; margin: 0 0 0.6rem; }
.front-full { display: block; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.06em; font-weight: 700; color: var(--ink-soft); margin-top: 0.25rem; }
.front-card > p { color: var(--ink-soft); margin: 0 0 0.9rem; }
.front-card .readmore { margin-top: auto; font-weight: 700; color: var(--brand-dark); text-decoration: none; }
.front-card .readmore:hover { text-decoration: underline; }

/* ── Larger AIO scan form ─────────────────────────────────────────────── */
.audit-form-lg { padding: 1.6rem; }
.audit-form-lg .audit-label { font-size: 1.05rem; margin-bottom: 0.4rem; }
.audit-form-lg input[type="text"],
.audit-form-lg input[type="email"],
.audit-form-lg textarea {
  width: 100%; font-size: 1.1rem; padding: 0.85rem 1rem; margin-bottom: 1rem;
}
.audit-form-lg button { font-size: 1.1rem; padding: 0.85rem 1.8rem; }

/* ── GEO scan: two-column hero (copy left, form right) ────────────────── */
.geo-hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 2.5rem; align-items: center; }
@media (max-width: 60rem) { .geo-hero-grid { grid-template-columns: 1fr; gap: 1.5rem; } }
.geo-hero-copy .lede { margin-bottom: 0; max-width: 42ch; }
.geo-hero-form .audit-form { background: #fff; margin-bottom: 0; box-shadow: 0 10px 30px rgba(11, 93, 99, 0.10); }

/* ── Nav dropdown (Scans) — CSS/markup only, no JS (CSP-safe) ──────────── */
.nav-dd { position: relative; }
.nav-dd > summary { list-style: none; cursor: pointer; color: var(--ink-soft); font-weight: 600; font-size: 0.95rem; padding: 0.35rem 0.1rem; user-select: none; }
.nav-dd > summary::-webkit-details-marker { display: none; }
.nav-dd > summary::after { content: "▾"; font-size: 0.7em; margin-left: 0.3rem; vertical-align: middle; }
.nav-dd > summary:hover { color: var(--brand-dark); }
.nav-dd[open] > summary { color: var(--brand-dark); }
.nav-dd[open] > summary::after { content: "▴"; }
.nav-dd-menu { position: absolute; top: calc(100% + 0.45rem); left: 0; min-width: 12rem; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); box-shadow: 0 12px 28px rgba(11, 93, 99, 0.14); padding: 0.4rem; display: flex; flex-direction: column; z-index: 60; }
.nav-dd-menu a { padding: 0.55rem 0.7rem; border-radius: 6px; text-decoration: none; color: var(--ink); font-weight: 600; font-size: 0.95rem; }
.nav-dd-menu a:hover { background: var(--wash); color: var(--brand-dark); }
/* On small screens the nav wraps — expand the menu inline (indented) so it can't overflow. */
@media (max-width: 48rem) {
  .nav-dd-menu { position: static; box-shadow: none; border: none; border-left: 2px solid var(--line); border-radius: 0; padding: 0.2rem 0 0.2rem 0.75rem; margin-top: 0.2rem; min-width: 0; }
}

/* ── Mobile hamburger nav (JS-enhanced via .js-nav; no-JS keeps the wrapping nav) ── */
.nav-toggle { display: none; }
.nav-toggle-bars, .nav-toggle-bars::before, .nav-toggle-bars::after {
  display: block; width: 22px; height: 2px; background: var(--ink); border-radius: 2px;
  transition: transform .2s ease, background-color .2s ease;
}
.nav-toggle-bars { position: relative; }
.nav-toggle-bars::before, .nav-toggle-bars::after { content: ""; position: absolute; left: 0; }
.nav-toggle-bars::before { top: -6px; }
.nav-toggle-bars::after { top: 6px; }

@media (max-width: 52rem) {
  .js-nav .nav-toggle {
    display: inline-flex; align-items: center; justify-content: center;
    width: 44px; height: 44px; padding: 0; margin: -0.3rem -0.25rem;
    background: none; border: 1px solid var(--line); border-radius: 8px; cursor: pointer;
  }
  .js-nav .nav-toggle:hover { border-color: var(--brand); }
  .js-nav .site-nav {
    position: absolute; top: 100%; left: 0; right: 0;
    display: none; flex-direction: column; flex-wrap: nowrap; align-items: stretch; gap: 0;
    background: var(--paper); border-bottom: 1px solid var(--line);
    box-shadow: 0 14px 28px rgba(11, 93, 99, 0.12); padding: 0.35rem 0;
  }
  .js-nav .site-nav.is-open { display: flex; }
  .js-nav .site-nav > a, .js-nav .nav-dd > summary { padding: 0.75rem 1.25rem; font-size: 1rem; }
  .js-nav .site-nav > a, .js-nav .site-nav > .nav-dd { border-top: 1px solid var(--line); }
  .js-nav .site-nav > a:first-child, .js-nav .site-nav > .nav-dd:first-child { border-top: none; }
  .js-nav .nav-dd-menu {
    position: static; box-shadow: none; border: none; border-left: 2px solid var(--line);
    border-radius: 0; margin: 0 0 0.3rem 1.6rem; padding: 0.1rem 0; min-width: 0;
  }
  /* hamburger morphs into an X when open */
  .js-nav .nav-toggle[aria-expanded="true"] .nav-toggle-bars { background: transparent; }
  .js-nav .nav-toggle[aria-expanded="true"] .nav-toggle-bars::before { transform: translateY(6px) rotate(45deg); }
  .js-nav .nav-toggle[aria-expanded="true"] .nav-toggle-bars::after { transform: translateY(-6px) rotate(-45deg); }
}

/* Premium success page — spacing without inline styles (CSP-safe) */
.premium-cta + .premium-cta { margin-top: 1.5rem; }
.badge-preview { margin: 0.5rem 0 1rem; }

/* ── AI Readiness Index: featured pillar + CTA fill the last row ──────── */
@media (min-width: 64rem) { .pillar-card-feature, .pillar-cta { grid-column: span 2; } }
.pillar-card-feature { background: var(--wash); border-color: var(--brand); border-left: 4px solid var(--brand); }
.pillar-feature-top { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; }
.pillar-eyebrow { text-transform: uppercase; letter-spacing: 0.07em; font-size: 0.72rem; font-weight: 800; color: var(--brand); }
.pillar-cta { background: var(--brand-dark); border-color: var(--brand-dark); display: flex; flex-direction: column; justify-content: center; align-items: flex-start; gap: 0.3rem; }
.pillar-cta h3 { color: #fff; margin: 0; }
.pillar-cta p { color: #cfe1e0; margin: 0; }
.pillar-cta .btn-primary { background: #fff; color: var(--brand-dark); margin-top: 0.6rem; }
.pillar-cta .btn-primary:hover { background: var(--wash); color: var(--brand-dark); }

/* ── Agentic commerce readiness panel ─────────────────────────────────── */
.geo-commerce { border-top: 1px solid var(--line); margin-top: 2rem; padding-top: 1.5rem; }
.geo-commerce-signals { margin-top: 1rem; }
.geo-commerce-signals li strong { font-size: 1rem; }

/* ── Agentic Commerce teaser (on GEO/AIO results) ─────────────────────── */
.geo-commerce-teaser { margin-top: 2rem; padding: 1.25rem 1.5rem; background: var(--wash); border: 1px solid var(--line); border-left: 4px solid var(--accent); border-radius: var(--radius); }
.geo-commerce-teaser p { margin: 0 0 0.8rem; }

/* ── Homepage: Agentic Commerce callout (below the three fronts) ──────── */
.fronts-commerce { margin-top: 1.25rem; background: var(--brand-dark); color: #fff; border-radius: var(--radius); padding: 1.5rem 1.75rem; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; }
.fronts-commerce-copy { flex: 1 1 26rem; }
.fronts-commerce .eyebrow { color: #7fd0c8; margin-bottom: 0.3rem; }
.fronts-commerce h3 { color: #fff; margin: 0 0 0.5rem; }
.fronts-commerce p { color: #cfe1e0; margin: 0; max-width: 62ch; }
.fronts-commerce .btn-primary { background: #fff; color: var(--brand-dark); white-space: nowrap; flex: 0 0 auto; }
.fronts-commerce .btn-primary:hover { background: var(--wash); color: var(--brand-dark); }

/* ── About: profile block (ported from profile.html; scoped + teal-harmonised) ── */
.profile { --p-mono: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  --p-accent: var(--brand-dark); --p-mid: var(--brand); --p-light: #e3efee; --p-strong: #c9cdd6; --p-faint: #8a99a0;
  margin: 2rem 0 2.5rem; }
.profile .profile-header { display: flex; align-items: flex-start; gap: 1.5rem; margin-bottom: 2.25rem; padding-bottom: 1.75rem; border-bottom: 1px solid var(--line); }
.profile-avatar { width: 132px; height: 132px; min-width: 132px; border-radius: 16px; object-fit: cover; border: 3px solid #fff; box-shadow: 0 4px 14px rgba(11,93,99,0.18); }
.profile-name { font-size: 1.6rem; font-weight: 700; letter-spacing: -0.01em; margin: 0 0 0.15rem; }
.profile-role { font-size: 0.95rem; color: var(--ink-soft); margin: 0 0 0.7rem; line-height: 1.5; }
.profile-pills { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.profile-pill { font-family: var(--p-mono); font-size: 0.7rem; color: var(--p-accent); background: var(--p-light); border: 1px solid #c3d9d6; border-radius: 999px; padding: 0.18rem 0.6rem; white-space: nowrap; }
.profile-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.75rem; margin-bottom: 2.25rem; }
.profile-stat { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 1.1rem 1.25rem; display: flex; flex-direction: column; }
.profile-stat-val { font-family: var(--p-mono); font-size: 1.75rem; font-weight: 700; color: var(--p-accent); line-height: 1; margin-bottom: 0.35rem; }
.profile-stat-lbl { font-size: 0.78rem; color: var(--ink-soft); line-height: 1.4; }
.profile-section { margin-bottom: 2.25rem; }
.profile-eyebrow { font-family: var(--p-mono); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--p-faint); margin: 0 0 1rem; display: flex; align-items: center; gap: 0.6rem; }
.profile-eyebrow::after { content: ''; flex: 1; height: 1px; background: var(--line); }
.profile-section > p { color: var(--ink); line-height: 1.8; margin-bottom: 1rem; }
.profile-section > p:last-child { margin-bottom: 0; }
/* timeline */
.profile-timeline { position: relative; padding-left: 1.25rem; }
.profile-timeline::before { content: ''; position: absolute; left: 5px; top: 8px; bottom: 8px; width: 1px; background: var(--p-strong); }
.profile-tl { position: relative; padding: 0 0 1.4rem 1.25rem; }
.profile-tl:last-child { padding-bottom: 0; }
.profile-tl::before { content: ''; position: absolute; left: -15px; top: 6px; width: 9px; height: 9px; border-radius: 50%; background: var(--p-strong); border: 2px solid var(--wash); }
.profile-tl-current::before { background: var(--p-accent); }
.profile-tl-period { display: block; font-family: var(--p-mono); font-size: 0.72rem; color: var(--p-faint); margin-bottom: 0.15rem; }
.profile-tl-title { display: block; font-size: 0.95rem; font-weight: 700; margin-bottom: 0.15rem; }
.profile-tl-desc { display: block; font-size: 0.88rem; color: var(--ink-soft); line-height: 1.5; }
/* certs */
.profile-cert-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(13rem, 1fr)); gap: 0.6rem; }
.profile-cert { background: #fff; border: 1px solid var(--line); border-left: 3px solid var(--p-mid); border-radius: var(--radius); padding: 0.75rem 0.9rem; display: flex; flex-direction: column; }
.profile-cert-issuer { font-family: var(--p-mono); font-size: 0.62rem; font-weight: 600; color: var(--p-mid); letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 0.3rem; }
.profile-cert-name { font-size: 0.82rem; color: var(--ink); line-height: 1.4; }
/* portfolio */
.profile-portfolio { display: grid; grid-template-columns: repeat(auto-fill, minmax(14rem, 1fr)); gap: 0.6rem; }
.profile-pcard { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 1rem 1.1rem; text-decoration: none; display: block; transition: border-color 0.15s, box-shadow 0.15s; }
.profile-pcard:hover { border-color: var(--p-mid); box-shadow: 0 0 0 3px var(--p-light); }
.profile-pdomain { font-family: var(--p-mono); font-size: 0.8rem; font-weight: 600; color: var(--p-accent); margin-bottom: 0.4rem; display: block; }
.profile-pdesc { font-size: 0.82rem; color: var(--ink-soft); line-height: 1.5; display: block; }
.profile-dev { font-family: var(--p-mono); font-size: 0.62rem; font-weight: 600; letter-spacing: 0.05em; background: #fbf1e3; color: var(--accent); border: 1px solid #efd9bf; border-radius: 999px; padding: 0.1rem 0.45rem; margin-left: 0.4rem; vertical-align: middle; text-transform: none; }
@media (max-width: 34rem) {
  .profile .profile-header { flex-direction: column; gap: 1rem; }
  .profile-stats { grid-template-columns: 1fr 1fr; }
  .profile-stats .profile-stat:last-child { grid-column: span 2; }
}

/* About: certifications as a categorised list (replaces the card grid) */
.profile-certs { display: grid; gap: 1.25rem; }
.profile-cert-group { }
.profile-cert-cat { font-size: 0.95rem; font-weight: 700; color: var(--brand-dark); margin: 0 0 0.5rem; }
.profile-cert-items { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.35rem; }
.profile-cert-items li { font-size: 0.92rem; line-height: 1.5; color: var(--ink); padding-left: 1.1rem; position: relative; }
.profile-cert-items li::before { content: "›"; position: absolute; left: 0; top: -0.02em; color: var(--brand); font-weight: 700; }
.profile-cert-by { color: var(--ink-soft); }

/* ── Standards page ───────────────────────────────────────────────────── */
.std-table { width: 100%; border-collapse: collapse; margin: 0.5rem 0 1.75rem; font-size: 0.92rem; }
.std-table th { text-align: left; background: var(--brand-dark); color: #fff; padding: 0.55rem 0.7rem; font-weight: 700; }
.std-table td { border-bottom: 1px solid var(--line); padding: 0.55rem 0.7rem; vertical-align: top; }
.std-table tr:nth-child(even) td { background: var(--wash); }
.std-id { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-weight: 700; color: var(--brand); margin-right: 0.2rem; }
.std-status { display: inline-block; font-size: 0.72rem; font-weight: 800; letter-spacing: 0.03em; padding: 0.12rem 0.5rem; border-radius: 999px; white-space: nowrap; }
.std-established { background: #e3f1e7; color: var(--green); }
.std-emerging { background: #fbf1e3; color: var(--amber); }
.std-practice { background: #eef2f4; color: var(--ink-soft); }
.std-bodies-head { font-size: 1rem; margin: 1.25rem 0 0.5rem; }
.std-bodies { columns: 2; column-gap: 2rem; padding-left: 1.1rem; margin: 0 0 1rem; }
@media (max-width: 40rem) { .std-bodies { columns: 1; } }
.std-bodies li { margin-bottom: 0.3rem; break-inside: avoid; }
@media (max-width: 48rem) { .std-table { font-size: 0.85rem; } .std-table th, .std-table td { padding: 0.45rem 0.5rem; } }

/* ── Testimonial form (ported, scoped under .tform, teal-harmonised) ──── */
.tform { --t-accent: var(--brand-dark); --t-accent-light: #e3efee; --t-border-strong: #c9cdd6; --t-muted: #8a99a0; max-width: 680px; }
.tform .policy-card { background: var(--t-accent-light); border: 1px solid #bcd6d3; border-radius: 12px; padding: 1.25rem 1.5rem; margin-bottom: 1.75rem; }
.tform .policy-card h2 { font-size: 0.82rem; font-weight: 700; letter-spacing: 0.03em; color: var(--t-accent); margin-bottom: 0.6rem; text-transform: uppercase; }
.tform .policy-card ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 5px; }
.tform .policy-card li { font-size: 0.85rem; color: var(--brand-dark); padding-left: 1.2rem; position: relative; }
.tform .policy-card li::before { content: '—'; position: absolute; left: 0; color: var(--brand); }
.tform .policy-link { display: inline-block; margin-top: 0.75rem; font-size: 0.8rem; font-weight: 600; }
.tform .form-card { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 2rem; }
.tform .form-section { margin-bottom: 1.75rem; }
.tform .form-section:last-child { margin-bottom: 0; }
.tform .section-label { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.07em; text-transform: uppercase; color: var(--t-muted); margin: 0 0 1rem; padding-bottom: 0.5rem; border-bottom: 1px solid var(--line); }
.tform .req-note { color: var(--t-muted); font-weight: 400; text-transform: none; letter-spacing: 0; font-size: 0.7rem; }
.tform .field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px; }
.tform .field { margin-bottom: 12px; }
.tform .field label { display: block; font-size: 0.85rem; font-weight: 600; color: var(--ink-soft); margin-bottom: 5px; }
.tform .field label .req { color: var(--red); margin-left: 2px; }
.tform .field label .hint { font-weight: 400; color: var(--t-muted); font-size: 0.78rem; margin-left: 4px; }
.tform .field input, .tform .field select, .tform .field textarea { width: 100%; padding: 9px 12px; font-size: 0.95rem; font-family: inherit; color: var(--ink); background: #fff; border: 1px solid var(--t-border-strong); border-radius: var(--radius); outline: none; }
.tform .field select { appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a99a0' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 32px; cursor: pointer; }
.tform .field input:focus, .tform .field select:focus, .tform .field textarea:focus { border-color: var(--brand); box-shadow: 0 0 0 3px rgba(11,93,99,0.1); }
.tform .field textarea { min-height: 120px; resize: vertical; line-height: 1.6; }
.tform .char-count { text-align: right; font-size: 0.72rem; color: var(--t-muted); margin: 4px 0 0; }
.tform .char-count.warn { color: var(--red); }
.tform .declarations { display: flex; flex-direction: column; gap: 12px; }
.tform .declaration { display: flex; gap: 12px; align-items: flex-start; padding: 12px 14px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--wash); cursor: pointer; }
.tform .declaration:hover { border-color: var(--t-border-strong); }
.tform .declaration input[type=checkbox] { width: 16px; height: 16px; flex-shrink: 0; margin-top: 2px; accent-color: var(--brand); cursor: pointer; }
.tform .declaration.checked { border-color: #bcd6d3; background: var(--t-accent-light); }
.tform .decl-text { font-size: 0.85rem; color: var(--ink-soft); line-height: 1.55; user-select: none; }
.tform .decl-num { font-weight: 700; color: var(--t-accent); font-size: 0.75rem; display: block; margin-bottom: 2px; letter-spacing: 0.04em; text-transform: uppercase; }
.tform .submit-section { padding-top: 1.5rem; border-top: 1px solid var(--line); }
.tform .submit-row { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.tform .btn-submit { padding: 10px 24px; font-size: 0.95rem; font-weight: 700; font-family: inherit; color: #fff; background: var(--brand-dark); border: none; border-radius: var(--radius); cursor: pointer; white-space: nowrap; }
.tform .btn-submit:hover { background: var(--brand); }
.tform .btn-submit:disabled { background: var(--t-border-strong); cursor: not-allowed; }
.tform .submit-note { font-size: 0.78rem; color: var(--t-muted); line-height: 1.5; flex: 1; min-width: 200px; }
.tform .alert { display: none; padding: 12px 16px; border-radius: var(--radius); font-size: 0.85rem; line-height: 1.5; margin-top: 1rem; }
.tform .alert.success { background: #e3f1e7; color: var(--green); border: 1px solid #a8d8be; }
.tform .alert.error { background: #fbe7e5; color: var(--red); border: 1px solid #e8b8ae; }
.tform .field-error { font-size: 0.78rem; color: var(--red); margin: 4px 0 0; display: none; }
.tform .decl-error { margin-top: 8px; }
.tform .field input.invalid, .tform .field select.invalid, .tform .field textarea.invalid { border-color: var(--red); }
.tform .gdpr-note { font-size: 0.78rem; color: var(--t-muted); margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--line); line-height: 1.55; }
@media (max-width: 34rem) { .tform .field-row { grid-template-columns: 1fr; } .tform .form-card { padding: 1.25rem; } .tform .submit-row { flex-direction: column; align-items: flex-start; } }

/* ── Homepage testimonials strip ──────────────────────────────────────── */
.testimonials { background: var(--wash); border-block: 1px solid var(--line); }
.testi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(17rem, 1fr)); gap: 1.1rem; margin-top: 1.25rem; }
.testi-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.25rem 1.4rem; display: flex; flex-direction: column; }
.testi-body { margin: 0 0 0.9rem; color: var(--ink); line-height: 1.6; }
.testi-body::before { content: '“'; color: var(--brand); font-weight: 800; }
.testi-attr { margin-top: auto; font-weight: 700; color: var(--brand-dark); font-size: 0.92rem; }
.testi-meta { display: block; font-weight: 400; color: var(--ink-soft); font-size: 0.82rem; margin-top: 0.1rem; }
.testi-disclosure { display: block; color: var(--ink-soft); font-size: 0.74rem; font-style: italic; margin-top: 0.3rem; }

/* ── Testimonials admin ───────────────────────────────────────────────── */
.ad-row { border: 1px solid var(--line); border-radius: var(--radius); padding: 1rem 1.25rem; margin-bottom: 1rem; background: #fff; }
.ad-head { margin: 0 0 0.5rem; }
.ad-body { margin: 0 0 0.5rem; padding-left: 0.9rem; border-left: 3px solid var(--line); color: var(--ink); }
.ad-badge { display: inline-block; font-size: 0.68rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.04em; padding: 0.12rem 0.5rem; border-radius: 999px; margin-right: 0.4rem; }
.ad-badge-pending { background: #fbf1e3; color: var(--amber); }
.ad-badge-approved { background: #e3f1e7; color: var(--green); }
.ad-badge-rejected { background: #fbe7e5; color: var(--red); }
.ad-badge-withdrawn { background: #eef2f4; color: var(--ink-soft); }
.ad-actions { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; margin-top: 0.5rem; }
.ad-actions input { flex: 1 1 16rem; padding: 0.45rem 0.6rem; border: 1px solid var(--line); border-radius: var(--radius); font-size: 0.85rem; }
.ad-actions .btn { padding: 0.45rem 0.9rem; font-size: 0.85rem; cursor: pointer; }

/* Darker fine print on the testimonial form (readability / contrast) */
.tform .submit-note, .tform .gdpr-note { color: #55606a; }

/* Server-rendered (no-JS) form states — reveal via class, not inline style (CSP-safe) */
.tform .alert.show, .tform .field-error.show { display: block; }

/* ── Free tools ───────────────────────────────────────────────────────── */
.tool-cell { text-decoration: none; color: inherit; transition: border-color 0.15s, box-shadow 0.15s; }
.tool-cell:hover { border-color: var(--brand); box-shadow: 0 0 0 3px #e3efee; }
.tool-cell h3 { color: var(--brand-dark); }
.tool-result { margin-top: 1.5rem; }
.tool-result-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 0.4rem; }
.tool-result-label { font-weight: 700; color: var(--brand-dark); font-size: 0.95rem; }
.tool-output { width: 100%; font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace; font-size: 0.85rem; line-height: 1.5; padding: 0.85rem 1rem; border: 1px solid var(--line); border-radius: var(--radius); background: var(--wash); color: var(--ink); resize: vertical; }
.tool-note { margin-top: 0.6rem; }
.tool-snippet { margin-bottom: 0.9rem; }
.tool-snippet .tool-output { resize: none; white-space: pre; overflow-x: auto; }
.btn-copy { padding: 0.35rem 0.8rem; font-size: 0.82rem; cursor: pointer; }
.tool-signals { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 1.25rem; }
.tool-check { display: flex; align-items: center; gap: 0.6rem; font-size: 0.92rem; color: var(--ink); cursor: pointer; }
.tool-check input { width: 16px; height: 16px; accent-color: var(--brand); }
.tool-bots { font-size: 0.9rem; }
.tool-bots td, .tool-bots th { text-align: center; }
.tool-bots td:first-child, .tool-bots th:first-child { text-align: left; }
.tool-bots input[type=radio] { accent-color: var(--brand); width: 16px; height: 16px; }
.tool-checks { margin-top: 1rem; }

/* Schema dump (niche/demo pages — show the JSON-LD a page ships) */
.schema-dump { background: #0f1c1f; color: #dceae8; font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace; font-size: 0.82rem; line-height: 1.5; padding: 1rem 1.2rem; border-radius: 12px; overflow: auto; max-height: 26rem; margin: 0.5rem 0 1rem; }
.schema-dump code { background: none; color: inherit; padding: 0; font-size: inherit; }

/* ── Demo product page (PDP reference implementation) ─────────────────── */
.pdp-breadcrumb { font-size: 0.85rem; color: var(--ink-soft); padding-top: 1.5rem; }
.pdp-breadcrumb a { color: var(--brand-dark); text-decoration: none; }
.pdp-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; align-items: start; margin-bottom: 1.5rem; }
@media (max-width: 48rem) { .pdp-grid { grid-template-columns: 1fr; gap: 1.5rem; } }
.pdp-image { margin: 0; }
.pdp-image img { width: 100%; height: auto; border-radius: var(--radius); border: 1px solid var(--line); display: block; }
.pdp-info h1 { margin: 0.2rem 0 0.5rem; }
.pdp-rating { color: var(--accent); font-weight: 700; margin: 0 0 0.4rem; }
.pdp-price { font-size: 1.8rem; font-weight: 800; color: var(--brand-dark); margin: 0 0 0.6rem; }
.pdp-avail { font-size: 0.8rem; font-weight: 700; color: var(--green); background: #e3f1e7; padding: 0.15rem 0.6rem; border-radius: 999px; vertical-align: middle; margin-left: 0.4rem; }
.pdp-buy { margin-top: 1rem; display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap; }
.pdp-specs th { text-align: left; width: 40%; color: var(--ink-soft); font-weight: 600; }
.pdp-faqs { display: grid; gap: 0.5rem; }
.pdp-faq { border: 1px solid var(--line); border-radius: var(--radius); background: #fff; padding: 0.85rem 1rem; }
.pdp-faq summary { font-weight: 700; cursor: pointer; }
.pdp-faq p { margin: 0.6rem 0 0; color: var(--ink-soft); }
.pdp-reviews { display: grid; grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr)); gap: 1rem; }
.pdp-review { border: 1px solid var(--line); border-radius: var(--radius); background: #fff; padding: 1rem 1.1rem; }
.pdp-review-stars { color: var(--accent); margin: 0 0 0.4rem; letter-spacing: 0.1em; }
