/* =============================================================================
   Guide article — public help-center article chrome.

   Ported from the "Guide.html" design handoff (Claude Design). Every selector
   is namespaced with the gd- prefix and scoped under .guide-doc so it never
   collides with the global site.css rules. The marketing nav + footer are NOT
   defined here — public pages already get TopBar + FooterComponent from
   MainLayout, so this file owns only the hero + article body + TOC + related.

   Backing the design tokens with the app's existing --icu-* / --hermes--*
   variables where a clean match exists, with literal fallbacks so the article
   renders identically even if a token is missing.
   ========================================================================== */

.guide-doc {
  --gd-brand: var(--icu-brand, #6F42C1);
  --gd-brand-ink: var(--icu-brand-ink, #4E2D8F);
  --gd-brand-50: #F6F2FC;
  --gd-brand-100: #EDE4F8;
  --gd-brand-200: #D9C6EE;
  --gd-brand-300: #B798DF;

  --gd-bg: #FAF9FB;
  --gd-surface: #FFFFFF;
  --gd-line: #ECEAF0;
  --gd-line-2: #E3E0E8;
  --gd-ink: #16141C;
  --gd-ink-2: #3A3645;
  --gd-ink-3: #6B6576;
  --gd-ink-4: #9B96A5;

  --gd-ok: #2F9E6B;
  --gd-warn: #C7893B;
  --gd-bad: #C84A3B;

  --gd-radius: 10px;
  --gd-radius-lg: 14px;
  --gd-shadow-sm: 0 1px 0 rgba(22, 20, 28, 0.03), 0 1px 2px rgba(22, 20, 28, 0.04);
  --gd-shadow-md: 0 2px 4px rgba(22, 20, 28, 0.04), 0 8px 24px rgba(22, 20, 28, 0.06);
  --gd-shadow-lg: 0 12px 40px rgba(78, 45, 143, 0.14);

  --gd-maxw: 1180px;
  --gd-bodyw: 720px;

  font-family: 'Inter Tight', system-ui, sans-serif;
  color: var(--gd-ink);
  background: var(--gd-bg);
}

.guide-doc * { box-sizing: border-box; }
.guide-doc a { color: inherit; text-decoration: none; }
.guide-doc .gd-mono { font-family: 'JetBrains Mono', ui-monospace, monospace; }

/* ============ HERO ============ */
.guide-doc .gd-hero { position: relative; overflow: hidden; padding: 30px 24px 56px; }
.guide-doc .gd-hero::before {
  content: ""; position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(60% 80% at 18% 0%, #EFE7FB 0%, rgba(239, 231, 251, 0) 60%),
    radial-gradient(70% 90% at 88% 6%, #E7ECFB 0%, rgba(231, 236, 251, 0) 55%),
    linear-gradient(180deg, #EEE9FA 0%, var(--gd-bg) 100%);
}
.guide-doc .gd-hero-inner { position: relative; z-index: 1; max-width: var(--gd-maxw); margin: 0 auto; }

.guide-doc .gd-crumbs { display: flex; align-items: center; gap: 8px; font-size: 13.5px; color: var(--gd-ink-3); margin: 0 0 26px; flex-wrap: wrap; }
.guide-doc .gd-crumbs a:hover { color: var(--gd-brand); }
.guide-doc .gd-crumbs .gd-sep { color: var(--gd-ink-4); }
.guide-doc .gd-crumbs .gd-here { color: var(--gd-ink-2); font-weight: 500; }

.guide-doc .gd-hero-head { max-width: 760px; }
.guide-doc .gd-kicker { display: inline-flex; align-items: center; gap: 8px; font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gd-brand); background: rgba(255, 255, 255, 0.7); border: 1px solid var(--gd-brand-200); padding: 6px 12px; border-radius: 999px; }
.guide-doc .gd-hero h1 { font-size: clamp(38px, 5.2vw, 62px); line-height: 1.02; font-weight: 700; letter-spacing: -0.028em; margin: 20px 0 0; color: var(--gd-ink); text-wrap: balance; }
.guide-doc .gd-lede { font-size: 20px; line-height: 1.5; color: var(--gd-ink-2); margin: 20px 0 0; max-width: 640px; text-wrap: pretty; }

.guide-doc .gd-meta-row { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; margin-top: 26px; font-size: 14px; color: var(--gd-ink-3); }
.guide-doc .gd-meta-row .gd-m { display: inline-flex; align-items: center; gap: 8px; }
.guide-doc .gd-meta-row .gd-m svg { color: var(--gd-ink-4); }
.guide-doc .gd-meta-row .gd-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--gd-ink-4); }
.guide-doc .gd-meta-row .gd-author { display: inline-flex; align-items: center; gap: 9px; }
.guide-doc .gd-meta-row .gd-ava { width: 26px; height: 26px; border-radius: 50%; background: linear-gradient(135deg, var(--gd-brand-300), var(--gd-brand)); color: #fff; font-size: 12px; font-weight: 600; display: grid; place-items: center; }

.guide-doc .gd-hero-search { margin-top: 32px; max-width: 540px; display: flex; align-items: center; gap: 10px; background: #fff; border: 1px solid var(--gd-line-2); border-radius: 12px; padding: 13px 16px; box-shadow: var(--gd-shadow-md); }
.guide-doc .gd-hero-search:focus-within { border-color: var(--gd-brand-300); box-shadow: 0 0 0 4px var(--gd-brand-50); }
.guide-doc .gd-hero-search svg { color: var(--gd-ink-4); flex: none; }
.guide-doc .gd-hero-search input { border: 0; background: transparent; outline: none; font: inherit; font-size: 15.5px; color: var(--gd-ink); width: 100%; }
.guide-doc .gd-hero-search .gd-kbd { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--gd-ink-4); border: 1px solid var(--gd-line-2); padding: 2px 7px; border-radius: 5px; flex: none; }

/* ============ LAYOUT ============ */
.guide-doc .gd-layout {
  max-width: var(--gd-maxw); margin: 0 auto; padding: 48px 24px 40px;
  display: grid; gap: 56px;
  grid-template-columns: minmax(0, 1fr) 248px;
}
.guide-doc.gd-doc--toc-left .gd-layout { grid-template-columns: 248px minmax(0, 1fr); }
.guide-doc.gd-doc--toc-left .gd-toc { order: -1; }
.guide-doc.gd-doc--toc-off .gd-layout { grid-template-columns: minmax(0, var(--gd-bodyw)); justify-content: center; }
.guide-doc.gd-doc--toc-off .gd-toc { display: none; }

.guide-doc .gd-article { min-width: 0; max-width: var(--gd-bodyw); }
.guide-doc.gd-doc--toc-off .gd-article { max-width: none; }

/* ============ TOC ============ */
.guide-doc .gd-toc { position: sticky; top: 102px; align-self: start; max-height: calc(100vh - 130px); overflow-y: auto; }
.guide-doc .gd-toc-title { font-family: 'JetBrains Mono', monospace; font-size: 11.5px; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gd-ink-4); margin: 0 0 14px; }
.guide-doc .gd-toc ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
.guide-doc .gd-toc a { display: block; padding: 7px 0 7px 16px; font-size: 14px; color: var(--gd-ink-3); border-left: 2px solid var(--gd-line); line-height: 1.35; }
.guide-doc .gd-toc a:hover { color: var(--gd-ink); border-color: var(--gd-brand-300); }
.guide-doc .gd-toc a.gd-active { color: var(--gd-brand); font-weight: 600; border-color: var(--gd-brand); }

/* ============ ARTICLE BODY ============ */
.guide-doc .gd-article h2 { font-size: 28px; font-weight: 700; letter-spacing: -0.02em; margin: 52px 0 16px; scroll-margin-top: 104px; color: var(--gd-ink); }
.guide-doc .gd-article > h2:first-child,
.guide-doc .gd-article > .gd-section:first-child h2 { margin-top: 0; }
.guide-doc .gd-article h3 { font-size: 19px; font-weight: 650; letter-spacing: -0.01em; margin: 32px 0 10px; color: var(--gd-ink); }
.guide-doc .gd-article p { font-size: 17px; line-height: 1.7; color: var(--gd-ink-2); margin: 0 0 18px; text-wrap: pretty; }
.guide-doc .gd-article p a,
.guide-doc .gd-article li a { color: var(--gd-brand); font-weight: 500; border-bottom: 1px solid var(--gd-brand-200); }
.guide-doc .gd-article p a:hover,
.guide-doc .gd-article li a:hover { border-color: var(--gd-brand); }
.guide-doc .gd-article ul.gd-bul { margin: 0 0 18px; padding-left: 22px; }
.guide-doc .gd-article ul.gd-bul li { font-size: 17px; line-height: 1.7; color: var(--gd-ink-2); margin-bottom: 8px; }
.guide-doc .gd-article strong { color: var(--gd-ink); font-weight: 650; }
.guide-doc .gd-lead { font-size: 19px; line-height: 1.65; color: var(--gd-ink-2); }

/* Ordered/plain lists + inline images inside a raw "html" block (migrated content) */
.guide-doc .gd-article ol { margin: 0 0 18px; padding-left: 22px; }
.guide-doc .gd-article ol li { font-size: 17px; line-height: 1.7; color: var(--gd-ink-2); margin-bottom: 8px; }
.guide-doc .gd-article h6 { font-size: 15px; font-weight: 650; letter-spacing: 0.02em; margin: 22px 0 8px; color: var(--gd-ink); }
.guide-doc .gd-article img { max-width: 100%; height: auto; display: block; margin: 12px 0; border: 1px solid var(--gd-line-2); border-radius: var(--gd-radius); box-shadow: var(--gd-shadow-sm); }

/* Steps */
.guide-doc .gd-steps { list-style: none; counter-reset: gd-step; margin: 8px 0; padding: 0; }
.guide-doc .gd-step { position: relative; padding: 0 0 30px 60px; counter-increment: gd-step; }
.guide-doc .gd-step::before {
  content: counter(gd-step); position: absolute; left: 0; top: -2px;
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--gd-brand); color: #fff; font-weight: 700; font-size: 16px;
  display: grid; place-items: center; box-shadow: 0 2px 8px rgba(111, 66, 193, 0.28);
}
.guide-doc .gd-step::after { content: ""; position: absolute; left: 18px; top: 40px; bottom: 4px; width: 2px; background: linear-gradient(var(--gd-brand-200), var(--gd-brand-100)); }
.guide-doc .gd-step:last-child { padding-bottom: 0; }
.guide-doc .gd-step:last-child::after { display: none; }
.guide-doc .gd-step h3 { margin: 4px 0 8px; font-size: 19px; font-weight: 650; }
.guide-doc .gd-step p { margin-bottom: 0; }
.guide-doc .gd-step .gd-substep { margin-top: 12px; }

/* Callouts */
.guide-doc .gd-callout { display: grid; grid-template-columns: 24px 1fr; gap: 14px; padding: 18px 20px; border-radius: var(--gd-radius); margin: 26px 0; font-size: 15.5px; line-height: 1.6; border: 1px solid; }
.guide-doc .gd-callout svg { margin-top: 1px; }
.guide-doc .gd-callout .gd-ct { font-weight: 650; display: block; margin-bottom: 3px; font-size: 15px; }
.guide-doc .gd-callout p { font-size: 15.5px; margin: 0; line-height: 1.6; }
.guide-doc .gd-callout.gd-tip { background: #EAF6F0; border-color: #BFE3D2; color: #1E5C40; }
.guide-doc .gd-callout.gd-tip svg, .guide-doc .gd-callout.gd-tip .gd-ct { color: var(--gd-ok); }
.guide-doc .gd-callout.gd-note { background: var(--gd-brand-50); border-color: var(--gd-brand-200); color: var(--gd-brand-ink); }
.guide-doc .gd-callout.gd-note svg, .guide-doc .gd-callout.gd-note .gd-ct { color: var(--gd-brand); }
.guide-doc .gd-callout.gd-warn { background: #FDF4E7; border-color: #F0DBB4; color: #7A5410; }
.guide-doc .gd-callout.gd-warn svg, .guide-doc .gd-callout.gd-warn .gd-ct { color: var(--gd-warn); }

/* Figure / screenshot placeholder */
.guide-doc .gd-figure { margin: 28px 0; }
.guide-doc .gd-shot {
  border-radius: var(--gd-radius-lg); border: 1px solid var(--gd-line-2); overflow: hidden;
  background: repeating-linear-gradient(135deg, #fff 0 14px, #F4F1F9 14px 28px);
  aspect-ratio: 16 / 9; display: grid; place-items: center; position: relative;
  box-shadow: var(--gd-shadow-md);
}
.guide-doc .gd-shot img { width: 100%; height: 100%; object-fit: cover; display: block; }
.guide-doc .gd-shot .gd-tag { font-family: 'JetBrains Mono', monospace; font-size: 12.5px; color: var(--gd-ink-3); background: #fff; border: 1px dashed var(--gd-brand-200); padding: 8px 14px; border-radius: 8px; }
.guide-doc .gd-figcaption { font-size: 13.5px; color: var(--gd-ink-4); margin-top: 11px; text-align: center; font-family: 'JetBrains Mono', monospace; }

/* Video placeholder */
.guide-doc .gd-video {
  position: relative; border-radius: var(--gd-radius-lg); overflow: hidden; aspect-ratio: 16 / 9;
  background: linear-gradient(135deg, #2A1E4A 0%, var(--gd-brand-ink) 60%, var(--gd-brand) 100%);
  display: grid; place-items: center; box-shadow: var(--gd-shadow-lg); cursor: pointer;
}
.guide-doc .gd-video .gd-play { width: 72px; height: 72px; border-radius: 50%; background: rgba(255, 255, 255, 0.95); display: grid; place-items: center; box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3); transition: transform .15s; }
.guide-doc .gd-video:hover .gd-play { transform: scale(1.06); }
.guide-doc .gd-video .gd-play svg { color: var(--gd-brand); margin-left: 4px; }
.guide-doc .gd-video .gd-vlabel { position: absolute; left: 20px; bottom: 18px; color: #fff; }
.guide-doc .gd-video .gd-vlabel .gd-t { font-weight: 650; font-size: 16px; }
.guide-doc .gd-video .gd-vlabel .gd-d { font-size: 13px; opacity: 0.8; font-family: 'JetBrains Mono', monospace; margin-top: 2px; }

/* Comparison table */
.guide-doc .gd-table { margin: 28px 0; border: 1px solid var(--gd-line-2); border-radius: var(--gd-radius); overflow: hidden; }
.guide-doc .gd-table table { width: 100%; border-collapse: collapse; font-size: 15px; }
.guide-doc .gd-table thead th { background: var(--gd-brand-50); text-align: left; padding: 13px 18px; font-weight: 650; font-size: 13px; letter-spacing: 0.02em; color: var(--gd-brand-ink); border-bottom: 1px solid var(--gd-brand-100); }
.guide-doc .gd-table tbody td { padding: 14px 18px; border-bottom: 1px solid var(--gd-line); color: var(--gd-ink-2); vertical-align: top; }
.guide-doc .gd-table tbody tr:last-child td { border-bottom: 0; }
.guide-doc .gd-table tbody td:first-child { font-weight: 600; color: var(--gd-ink); }
.guide-doc .gd-table .gd-yes { color: var(--gd-ok); font-weight: 600; }
.guide-doc .gd-table .gd-no { color: var(--gd-ink-4); }

/* FAQ accordion — auto-height via grid-template-rows so it needs no JS */
.guide-doc .gd-faq { margin: 18px 0 8px; border-top: 1px solid var(--gd-line); }
.guide-doc .gd-faq-item { border-bottom: 1px solid var(--gd-line); }
.guide-doc .gd-faq-q { width: 100%; text-align: left; background: transparent; border: 0; font-family: inherit; cursor: pointer; padding: 20px 40px 20px 0; font-size: 17px; font-weight: 600; color: var(--gd-ink); position: relative; display: block; }
.guide-doc .gd-faq-q::after { content: ""; position: absolute; right: 6px; top: 50%; width: 11px; height: 11px; border-right: 2px solid var(--gd-ink-3); border-bottom: 2px solid var(--gd-ink-3); transform: translateY(-65%) rotate(45deg); transition: transform .2s; }
.guide-doc .gd-faq-item.gd-open .gd-faq-q::after { transform: translateY(-35%) rotate(-135deg); }
.guide-doc .gd-faq-item.gd-open .gd-faq-q { color: var(--gd-brand); }
.guide-doc .gd-faq-a { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .28s ease; }
.guide-doc .gd-faq-item.gd-open .gd-faq-a { grid-template-rows: 1fr; }
/* Bottom spacing lives on the answer <p>, NOT on this overflow clip: block-axis
   padding on a grid item isn't zeroed by overflow:hidden, so it floors the
   collapsed 0fr row at the padding height and leaks the first answer line. */
.guide-doc .gd-faq-a-inner { overflow: hidden; padding: 0 40px 0 0; }
.guide-doc .gd-faq-a-inner p { margin: 0; padding-bottom: 22px; font-size: 16px; color: var(--gd-ink-2); line-height: 1.65; }

/* Was this helpful */
.guide-doc .gd-helpful { margin: 56px 0 8px; padding: 26px 28px; border: 1px solid var(--gd-line-2); border-radius: var(--gd-radius-lg); background: var(--gd-surface); display: flex; align-items: center; gap: 20px; flex-wrap: wrap; box-shadow: var(--gd-shadow-sm); }
.guide-doc .gd-helpful .gd-q { font-size: 17px; font-weight: 650; flex: 1; min-width: 200px; }
.guide-doc .gd-helpful .gd-actions { display: flex; gap: 10px; }
.guide-doc .gd-vote { display: inline-flex; align-items: center; gap: 8px; padding: 10px 18px; border-radius: 999px; border: 1px solid var(--gd-line-2); background: #fff; font-family: inherit; font-size: 14.5px; font-weight: 600; color: var(--gd-ink-2); cursor: pointer; transition: all .15s; }
.guide-doc .gd-vote:hover { border-color: var(--gd-brand-300); color: var(--gd-brand); background: var(--gd-brand-50); }
.guide-doc .gd-vote.gd-chosen { background: var(--gd-brand); border-color: var(--gd-brand); color: #fff; }
.guide-doc .gd-helpful.gd-done .gd-actions { display: none; }
.guide-doc .gd-helpful .gd-thanks { display: none; font-size: 16px; font-weight: 600; color: var(--gd-ok); }
.guide-doc .gd-helpful.gd-done .gd-thanks { display: inline-flex; align-items: center; gap: 9px; }
.guide-doc .gd-helpful.gd-done .gd-q { color: var(--gd-ink-3); font-weight: 500; }

.guide-doc .gd-edited { margin-top: 26px; font-size: 13.5px; color: var(--gd-ink-4); font-family: 'JetBrains Mono', monospace; }

/* ============ RELATED ============ */
.guide-doc .gd-related { border-top: 1px solid var(--gd-line); background: linear-gradient(180deg, var(--gd-bg), #fff); }
.guide-doc .gd-related-inner { max-width: var(--gd-maxw); margin: 0 auto; padding: 56px 24px 80px; }
.guide-doc .gd-related-inner h2 { font-size: 24px; font-weight: 700; letter-spacing: -0.02em; margin: 0 0 6px; color: var(--gd-ink); }
.guide-doc .gd-related-inner .gd-rs { font-size: 16px; color: var(--gd-ink-3); margin: 0 0 28px; }
.guide-doc .gd-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.guide-doc .gd-card { background: #fff; border: 1px solid var(--gd-line); border-top: 3px solid var(--gd-brand); border-radius: var(--gd-radius-lg); padding: 24px; box-shadow: var(--gd-shadow-sm); cursor: pointer; transition: transform .15s, box-shadow .15s; display: flex; flex-direction: column; gap: 12px; }
.guide-doc .gd-card:hover { transform: translateY(-3px); box-shadow: var(--gd-shadow-lg); }
.guide-doc .gd-card .gd-gico { width: 42px; height: 42px; border-radius: 11px; display: grid; place-items: center; background: var(--gd-brand-50); color: var(--gd-brand); font-size: 20px; }
.guide-doc .gd-card .gd-gk { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.07em; text-transform: uppercase; color: var(--gd-ink-4); }
.guide-doc .gd-card .gd-gt { font-size: 17px; font-weight: 650; letter-spacing: -0.01em; margin-top: -4px; color: var(--gd-ink); }
.guide-doc .gd-card .gd-gd { font-size: 14.5px; color: var(--gd-ink-3); line-height: 1.55; }
.guide-doc .gd-card .gd-garrow { margin-top: auto; color: var(--gd-brand); display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 600; }

/* Responsive */
@media (max-width: 920px) {
  .guide-doc .gd-layout { grid-template-columns: minmax(0, 1fr) !important; gap: 0; }
  .guide-doc .gd-toc { display: none !important; }
  .guide-doc .gd-cards { grid-template-columns: 1fr; }
}
