/*
Theme Name: The Grid Index
Theme URI: https://www.thegridindex.com
Author: The Grid Index
Author URI: https://www.thegridindex.com
Description: Dark editorial WordPress theme for premium news platforms. Marketing-style front page (hero, demo + support cards, feature grid, CTA, newsletter), full WordPress template hierarchy, complete SEO stack (meta, Open Graph, Twitter Cards, JSON-LD schema, breadcrumbs, Google News sitemap), and Customizer integration.
Version: 2.2.0
Requires at least: 5.5
Tested up to: 6.6
Requires PHP: 7.4
License: GPLv2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: thegridindex
Tags: news, magazine, blog, dark, two-columns, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, block-styles, wide-blocks, full-width-template, footer-widgets
*/

/* ============================================================
   FONT (Fraunces display + Inter Tight body via system fallback)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Inter+Tight:wght@400;500;600;700&display=swap');

/* ============================================================
   RESET
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
html{scroll-padding-top:80px}
[id]{scroll-margin-top:80px}
img,svg{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none;margin:0;padding:0}
button{font:inherit;cursor:pointer}

/* ============================================================
   ACCESSIBILITY
   ============================================================ */
.screen-reader-text{
  border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);
  height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;
  width:1px;word-wrap:normal!important;
}
.screen-reader-text:focus{
  background:#0a1014;clip:auto!important;clip-path:none;
  color:#fff;display:block;font-size:14px;font-weight:600;
  height:auto;left:5px;line-height:normal;padding:15px 23px 14px;
  text-decoration:none;top:5px;width:auto;z-index:100000;
}
.skip-link{position:absolute;left:-9999px;top:0;z-index:1000}
.skip-link:focus{left:8px;top:8px;background:var(--accent);color:#001016;padding:10px 14px;border-radius:6px;font-weight:600}

:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}

/* ============================================================
   TOKENS
   ============================================================ */
:root{
  /* Surfaces */
  --bg:        #0a1014;
  --bg-deep:   #060a0d;
  --surface:   #0e1518;
  --surface-2: #111a1f;
  --card:      rgba(20, 32, 38, 0.55);
  --card-hi:   rgba(28, 44, 52, 0.72);
  --border:    rgba(255,255,255,0.08);
  --border-hi: rgba(255,255,255,0.14);

  /* Text */
  --fg:        #e6eef2;
  --fg-soft:   rgba(230,238,242,0.78);
  --muted:     rgba(230,238,242,0.55);
  --dim:       rgba(230,238,242,0.38);

  /* Accent (cyan/teal) */
  --accent:        #14c8c2;
  --accent-bright: #2de2db;
  --accent-soft:   rgba(20,200,194,0.14);
  --accent-ring:   rgba(20,200,194,0.32);

  /* Effects */
  --grad-card: radial-gradient(120% 140% at 0% 0%, rgba(20,200,194,0.10) 0%, rgba(20,200,194,0) 45%), linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0));
  --shadow-card: 0 1px 0 rgba(255,255,255,0.04) inset, 0 30px 60px -30px rgba(0,0,0,0.6);

  /* Type */
  --serif: 'Fraunces','Times New Roman',Georgia,serif;
  --sans:  'Inter Tight',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

/* ============================================================
   BASE
   ============================================================ */
body{
  background:var(--bg);
  color:var(--fg);
  font-family:var(--sans);
  font-size:15px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

  /* Subtle ambient glow */
  background-image:
    radial-gradient(70% 50% at 80% -10%, rgba(20,200,194,0.06) 0%, transparent 60%),
    radial-gradient(60% 50% at 0% 100%, rgba(20,200,194,0.04) 0%, transparent 60%);
  background-attachment:fixed;
}

.container{max-width:1200px;margin:0 auto;padding:0 28px}

/* Display headings */
h1,h2,h3,.serif{font-family:var(--serif);font-weight:600;letter-spacing:-0.02em;line-height:1.08;color:#f5fafa}

/* Eyebrow / kicker */
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;color:var(--accent);
}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(20,200,194,0.12)}

/* Pills (live newsroom, support hub) */
.pill{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:6px 12px;border-radius:9999px;
  background:var(--accent-soft);border:1px solid var(--accent-ring);
  color:var(--accent-bright);
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
}
.pill svg{width:13px;height:13px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:11px 18px;border-radius:10px;
  font-weight:600;font-size:13px;letter-spacing:.01em;
  border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease, background .15s ease, border-color .15s ease, color .15s ease;
}
.btn-primary{background:var(--accent);color:#001214;box-shadow:0 0 0 0 var(--accent-ring),0 12px 30px -10px rgba(20,200,194,0.45)}
.btn-primary:hover{background:var(--accent-bright);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--fg);border-color:var(--border-hi)}
.btn-ghost:hover{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.22)}
.btn-ghost.is-active{background:rgba(20,200,194,0.10);border-color:var(--accent-ring);color:var(--accent-bright)}
.btn svg{width:14px;height:14px}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(10,16,20,0.72);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid var(--border);
}
.header-row{
  display:flex;align-items:center;justify-content:space-between;
  height:64px;gap:1rem;
}
.brand{display:inline-flex;align-items:center;gap:.6rem;color:var(--fg)}
.brand-mark{
  width:14px;height:14px;border-radius:3px;
  background:linear-gradient(135deg,var(--accent),var(--accent-bright));
  box-shadow:0 0 18px rgba(20,200,194,0.45);
}
.brand-name{font-family:var(--serif);font-size:18px;font-weight:600;letter-spacing:-0.01em}

.primary-nav{display:none}
@media (min-width:900px){
  .primary-nav{display:flex;gap:.5rem;align-items:center}
  .primary-nav ul{display:flex;gap:.25rem}
  .primary-nav a{
    padding:7px 12px;border-radius:8px;
    font-size:13px;font-weight:500;color:var(--fg-soft);
    transition:color .15s, background .15s;
  }
  .primary-nav a:hover,
  .primary-nav .current-menu-item>a,
  .primary-nav .current_page_item>a{color:var(--fg);background:rgba(255,255,255,0.04)}
}

.header-utils{display:flex;align-items:center;gap:.5rem}

.mobile-toggle{display:inline-flex;background:none;border:0;color:var(--fg);padding:8px;margin-right:6px;border-radius:8px}
.mobile-toggle:hover{background:rgba(255,255,255,0.04)}
@media (min-width:900px){.mobile-toggle{display:none}}

.mobile-nav{display:none;border-top:1px solid var(--border);background:var(--bg-deep)}
.mobile-nav.open{display:block}
.mobile-nav ul{display:flex;flex-direction:column;padding:8px 0}
.mobile-nav a{padding:12px 0;font-size:15px;color:var(--fg-soft);border-bottom:1px solid var(--border)}
.mobile-nav a:hover{color:var(--fg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  padding:80px 0 60px;
  position:relative;
}
.hero-grid{
  display:grid;gap:48px;
  grid-template-columns:1fr;
  align-items:center;
}
@media (min-width:980px){
  .hero-grid{grid-template-columns:1.05fr 1fr;gap:64px}
}
.hero-eyebrow{margin-bottom:22px}
.hero-title{
  font-family:var(--serif);
  font-weight:600;
  font-size:clamp(40px,5.6vw,68px);
  line-height:1.02;letter-spacing:-0.03em;
  margin:0 0 22px;
  color:#f5fafa;
}
.hero-title em{font-style:italic;font-weight:500;color:var(--accent);letter-spacing:-0.02em}
.hero-lead{
  color:var(--fg-soft);font-size:17px;line-height:1.6;
  max-width:560px;margin:0 0 18px;
}
.hero-cats{
  color:var(--muted);font-size:13.5px;
  max-width:560px;margin:0 0 18px;
}
.hero-cats span{white-space:nowrap}
.hero-cats span+span::before{content:" · ";color:var(--dim);margin:0 .2rem}
.hero-sub{color:var(--fg-soft);max-width:560px;margin:0 0 22px;font-size:14.5px}
.hero-pills{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 26px}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.hero-meta{color:var(--muted);font-size:12.5px;margin-top:16px}

/* Browser mock */
.browser{
  position:relative;
  background:linear-gradient(180deg,#0d1518,#0a1114);
  border:1px solid var(--border-hi);border-radius:14px;
  overflow:hidden;
  box-shadow:0 50px 120px -40px rgba(0,0,0,0.7), 0 0 0 1px rgba(20,200,194,0.04) inset;
}
.browser::before{
  content:"";position:absolute;inset:-1px;border-radius:15px;
  background:radial-gradient(80% 100% at 30% 0%, rgba(20,200,194,0.18), transparent 60%);
  pointer-events:none;opacity:.6;z-index:0;
}
.browser-bar{
  position:relative;z-index:1;
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;border-bottom:1px solid var(--border);
  background:rgba(255,255,255,0.02);
}
.browser-dots{display:flex;gap:6px}
.browser-dots i{width:11px;height:11px;border-radius:50%;background:#3a4750;display:inline-block}
.browser-dots i:nth-child(1){background:#ff5f57}
.browser-dots i:nth-child(2){background:#febc2e}
.browser-dots i:nth-child(3){background:#28c840}
.browser-url{
  flex:1;font-size:12px;color:var(--muted);
  background:rgba(255,255,255,0.04);
  padding:6px 12px;border-radius:6px;border:1px solid var(--border);
  display:inline-flex;align-items:center;gap:8px;
}
.browser-url::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px rgba(20,200,194,0.6)}

.browser-body{position:relative;z-index:1;padding:14px;display:flex;flex-direction:column;gap:10px}

.mock-topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 4px;font-size:11.5px;color:var(--fg-soft);
}
.mock-topbar .right{display:flex;gap:14px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;font-size:10px;font-weight:600}
.mock-topbar .right span:hover{color:var(--fg)}
.mock-brand{display:inline-flex;align-items:center;gap:6px;font-family:var(--serif);font-weight:600}
.mock-brand i{width:10px;height:10px;background:var(--accent);border-radius:2px;display:inline-block}

.mock-breaking{
  display:flex;align-items:center;gap:10px;
  background:var(--accent);color:#001214;
  padding:8px 12px;border-radius:6px;font-size:11px;font-weight:600;
}
.mock-breaking b{letter-spacing:.18em;text-transform:uppercase;font-size:10px}
.mock-breaking::before{content:"";width:7px;height:7px;border-radius:50%;background:#001214;animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

.mock-hero{
  display:grid;grid-template-columns:1.6fr 1fr;gap:10px;
}
.mock-lead{
  background:rgba(255,255,255,0.03);border:1px solid var(--border);
  border-radius:8px;padding:14px;min-height:130px;
  display:flex;flex-direction:column;justify-content:flex-end;
}
.mock-lead .tag{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:6px}
.mock-lead h4{font-family:var(--serif);font-size:13px;margin:0 0 6px;line-height:1.25;color:#f5fafa}
.mock-lead .meta{font-size:10px;color:var(--dim)}
.mock-aside{display:flex;flex-direction:column;gap:6px}
.mock-aside .card{
  background:rgba(255,255,255,0.03);border:1px solid var(--border);
  border-radius:6px;padding:8px 10px;
}
.mock-aside .card .tag{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:600}
.mock-aside .card div{font-size:11px;color:var(--fg-soft);margin-top:2px;line-height:1.3}

.mock-trending{
  background:rgba(255,255,255,0.02);border:1px solid var(--border);
  border-radius:8px;padding:10px 12px;
}
.mock-trending header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.mock-trending header b{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:700}
.mock-trending header b::before{content:"⤴ ";color:var(--accent)}
.mock-trending header span{font-size:10px;color:var(--muted)}
.mock-trending ul{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.mock-trending li{display:flex;gap:6px;font-size:10.5px;color:var(--fg-soft);line-height:1.3}
.mock-trending li i{color:var(--accent);font-style:normal;font-weight:700;font-size:10px}

.mock-options{
  background:rgba(255,255,255,0.02);border:1px solid var(--border);
  border-radius:8px;padding:8px 10px;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
}
.mock-options header{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.16em;font-weight:600;display:flex;align-items:center;gap:6px;flex:1}
.mock-options header::before{content:"";width:6px;height:6px;background:var(--accent);border-radius:50%}
.mock-options header span{margin-left:auto;font-size:9px;color:var(--dim)}
.mock-options .opt{font-size:10px;color:var(--muted);padding:4px 8px;background:rgba(255,255,255,0.03);border:1px solid var(--border);border-radius:4px;display:inline-flex;gap:8px}
.mock-options .opt b{color:var(--fg);font-weight:600}

/* ============================================================
   SECTION RULES + GENERIC SECTION
   ============================================================ */
.rule{height:1px;background:var(--border);margin:0}

.section{padding:72px 0}
.section-eyebrow{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:18px}
.section-title{font-family:var(--serif);font-size:clamp(28px,3.4vw,40px);line-height:1.08;letter-spacing:-0.025em;margin:0 0 18px;color:#f5fafa}
.section-lead{color:var(--fg-soft);font-size:15.5px;max-width:520px;line-height:1.65}

/* ============================================================
   DEMO + SUPPORT TWO-UP CARDS
   ============================================================ */
.duo{
  display:grid;gap:24px;grid-template-columns:1fr;
}
@media (min-width:900px){.duo{grid-template-columns:1fr 1fr;gap:28px}}

.feat-card{
  position:relative;
  background:var(--card);
  background-image:var(--grad-card);
  border:1px solid var(--border-hi);
  border-radius:16px;
  padding:32px;
  box-shadow:var(--shadow-card);
  overflow:hidden;
}
.feat-card::after{
  content:"";position:absolute;top:0;right:0;width:60%;height:60%;
  background:radial-gradient(60% 60% at 80% 0%, rgba(20,200,194,0.08), transparent 60%);
  pointer-events:none;
}
.feat-card .eyebrow{margin-bottom:14px}
.feat-card h3{font-family:var(--serif);font-size:clamp(22px,2.3vw,28px);margin:0 0 12px;line-height:1.15;letter-spacing:-0.02em}
.feat-card p{color:var(--fg-soft);font-size:14.5px;line-height:1.65;margin:0 0 18px;max-width:480px}
.feat-card .checks{display:flex;flex-direction:column;gap:10px;margin:18px 0 22px}
.feat-card .checks li{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--fg-soft)}
.feat-card .checks svg{width:16px;height:16px;color:var(--accent);flex:0 0 16px}
.feat-card .actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.feat-card .actions .link{font-size:13px;color:var(--fg-soft);font-weight:500}
.feat-card .actions .link:hover{color:var(--accent)}

/* Demo mini-browser */
.mini-browser{
  background:rgba(255,255,255,0.02);
  border:1px solid var(--border);
  border-radius:10px;
  padding:12px;margin:18px 0;
}
.mini-browser .bar{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);margin-bottom:10px}
.mini-browser .bar::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent)}
.mini-browser .stage{height:8px;background:rgba(255,255,255,0.05);border-radius:3px;width:60%;margin-bottom:14px}
.mini-browser .row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.mini-browser .row i{display:block;height:36px;background:rgba(255,255,255,0.04);border-radius:6px}

/* ============================================================
   FEATURE GRID
   ============================================================ */
.feature-grid-wrap{
  display:grid;gap:48px;grid-template-columns:1fr;
}
@media (min-width:980px){.feature-grid-wrap{grid-template-columns:1fr 1.4fr}}

.feature-card{
  background:var(--card);
  background-image:var(--grad-card);
  border:1px solid var(--border-hi);
  border-radius:14px;padding:22px 24px;
  box-shadow:var(--shadow-card);
}
.feature-grid{display:grid;gap:0;grid-template-columns:1fr}
@media (min-width:640px){.feature-grid{grid-template-columns:1fr 1fr}}

.feat-item{
  display:flex;align-items:center;gap:12px;
  padding:14px 4px;
  font-size:14px;color:var(--fg-soft);
  border-bottom:1px solid var(--border);
}
.feat-item:nth-last-child(-n+2){border-bottom:0}
@media (max-width:639px){
  .feat-item{border-bottom:1px solid var(--border)}
  .feat-item:last-child{border-bottom:0}
}
.feat-item .ico{
  width:30px;height:30px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;
  background:rgba(20,200,194,0.10);color:var(--accent);border:1px solid var(--accent-ring);
  flex:0 0 30px;
}
.feat-item .ico svg{width:15px;height:15px}

/* ============================================================
   CTA BLOCK
   ============================================================ */
.cta{
  position:relative;
  margin:0 auto;max-width:880px;
  background:linear-gradient(180deg, rgba(20,200,194,0.10), rgba(20,200,194,0.02));
  border:1px solid var(--border-hi);
  border-radius:18px;
  padding:54px 28px;
  text-align:center;
  overflow:hidden;
  box-shadow:var(--shadow-card);
}
.cta::before{
  content:"";position:absolute;inset:-40% 0 auto 0;height:100%;
  background:radial-gradient(60% 60% at 50% 0%, rgba(20,200,194,0.18), transparent 60%);
  pointer-events:none;
}
.cta .eyebrow{position:relative;margin-bottom:18px}
.cta h2{position:relative;font-family:var(--serif);font-size:clamp(30px,4vw,46px);line-height:1.05;letter-spacing:-0.025em;margin:0 0 16px}
.cta p{position:relative;color:var(--fg-soft);max-width:520px;margin:0 auto 26px;font-size:16px}
.cta-actions{position:relative;display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.cta-foot{position:relative;color:var(--muted);font-size:12.5px;margin-top:18px}

/* ============================================================
   NEWSLETTER
   ============================================================ */
.newsletter{padding:64px 0 80px;text-align:center}
.newsletter .eyebrow{margin-bottom:14px;justify-content:center}
.newsletter h2{font-family:var(--serif);font-size:clamp(22px,2.6vw,30px);line-height:1.2;max-width:640px;margin:0 auto 22px}
.newsletter-form{
  display:flex;gap:8px;max-width:480px;margin:0 auto;
  background:rgba(255,255,255,0.04);border:1px solid var(--border-hi);
  border-radius:9999px;padding:6px;
}
.newsletter-form input[type=email]{
  flex:1;background:transparent;border:0;color:var(--fg);padding:10px 14px;
  font:inherit;font-size:14px;outline:none;
}
.newsletter-form input::placeholder{color:var(--dim)}
.newsletter-form button{
  background:var(--accent);color:#001214;border:0;border-radius:9999px;
  padding:9px 22px;font-weight:600;font-size:13px;
}
.newsletter-form button:hover{background:var(--accent-bright)}

/* ============================================================
   BREADCRUMBS (used on non-front views)
   ============================================================ */
.breadcrumbs{padding:18px 0 0;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.14em}
.breadcrumbs ol{display:flex;flex-wrap:wrap;gap:.25rem;align-items:center}
.breadcrumbs li{display:inline-flex;align-items:center}
.breadcrumbs a:hover{color:var(--fg)}
.breadcrumb-sep{margin:0 .35rem;color:var(--dim)}

/* ============================================================
   ARTICLE / PAGE CONTENT
   ============================================================ */
.page-content{
  max-width:760px;margin:0 auto;padding:56px 0;
  color:var(--fg-soft);
}
.page-content .entry-header{margin-bottom:28px}
.page-content .kicker{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:600}
.page-content h1,.page-content .entry-title{font-family:var(--serif);font-size:clamp(34px,4.5vw,54px);line-height:1.05;letter-spacing:-0.025em;margin:14px 0 14px;color:#f5fafa}
.page-content .entry-meta{color:var(--muted);font-size:12.5px;text-transform:uppercase;letter-spacing:.14em;margin:0 0 22px}
.page-content .entry-meta a:hover{color:var(--accent)}
.page-content h2{font-family:var(--serif);font-size:28px;margin:36px 0 12px;color:#f5fafa;letter-spacing:-0.02em}
.page-content h3{font-family:var(--serif);font-size:22px;margin:28px 0 10px;color:#f5fafa;letter-spacing:-0.01em}
.page-content p{margin:0 0 16px;font-size:17px;line-height:1.7;color:var(--fg-soft)}
.page-content a{color:var(--accent);text-decoration:underline;text-decoration-color:rgba(20,200,194,0.45);text-underline-offset:3px}
.page-content a:hover{text-decoration-color:var(--accent)}
.page-content blockquote{
  border-left:3px solid var(--accent);
  padding:4px 0 4px 20px;margin:24px 0;
  font-family:var(--serif);font-size:22px;line-height:1.4;color:#f5fafa;font-style:italic;
}
.page-content pre{
  background:#040709;color:#e6eef2;padding:18px;
  border:1px solid var(--border);border-radius:8px;
  overflow:auto;font-size:13.5px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}
.page-content code{background:rgba(255,255,255,0.06);color:var(--accent-bright);padding:2px 6px;border-radius:4px;font-size:.92em}
.page-content pre code{background:transparent;color:inherit;padding:0}
.page-content figure{margin:28px 0}
.page-content figure img{border-radius:8px;border:1px solid var(--border)}
.page-content figcaption{color:var(--muted);font-size:13px;margin-top:8px;text-align:center}
.page-content ul,.page-content ol{margin:0 0 16px 22px;color:var(--fg-soft)}
.page-content ul{list-style:disc}
.page-content ol{list-style:decimal}
.page-content li{margin:6px 0;font-size:16.5px;line-height:1.65}
.page-content hr{border:0;border-top:1px solid var(--border);margin:32px 0}

.featured-image{margin:0 0 28px}
.featured-image img{border-radius:12px;border:1px solid var(--border)}
.featured-image figcaption{color:var(--muted);font-size:13px;margin-top:8px;text-align:center}

.entry-tags{margin:24px 0 0;font-size:13px;color:var(--muted)}
.entry-tags a{color:var(--accent)}
.entry-tags .tags-label{margin-right:6px;text-transform:uppercase;letter-spacing:.12em;font-weight:600;color:var(--fg-soft)}

/* Block alignments */
.alignwide{margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);max-width:100vw}
.alignfull{margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);max-width:100vw}

/* ============================================================
   ARCHIVE / STORY GRID
   ============================================================ */
.archive-header{padding:28px 0;border-bottom:1px solid var(--border);margin-bottom:32px}
.archive-title{font-family:var(--serif);font-size:clamp(28px,3.4vw,40px);margin:0;letter-spacing:-0.02em}
.archive-description{color:var(--fg-soft);max-width:620px;margin-top:8px;font-size:15px}

.story-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:28px;padding-bottom:48px}
.story-card{
  background:var(--card);
  background-image:var(--grad-card);
  border:1px solid var(--border);
  border-radius:12px;padding:18px;
  transition:transform .15s, border-color .15s;
}
.story-card:hover{transform:translateY(-2px);border-color:var(--border-hi)}
.story-card img{border-radius:8px;margin-bottom:12px;border:1px solid var(--border)}
.story-card .meta{font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);font-weight:600}
.story-card h4,.story-card .entry-title{font-family:var(--serif);font-size:20px;margin:8px 0;line-height:1.2;letter-spacing:-0.01em;color:#f5fafa}
.story-card h4 a:hover,.story-card .entry-title a:hover{color:var(--accent)}
.story-card .entry-summary{color:var(--fg-soft);font-size:14.5px;line-height:1.6;margin-top:6px}
.story-card .entry-summary p{margin:0}

/* ============================================================
   PAGINATION
   ============================================================ */
.navigation.pagination,.pagination{margin:40px 0;display:flex;justify-content:center}
.nav-links{display:flex;gap:6px;flex-wrap:wrap}
.page-numbers{
  padding:9px 14px;border:1px solid var(--border-hi);border-radius:8px;
  font-size:13px;font-weight:600;color:var(--fg-soft);
}
.page-numbers.current,.page-numbers:hover{background:var(--accent);color:#001214;border-color:var(--accent)}

.post-nav{max-width:760px;margin:32px auto;padding:24px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.post-nav .nav-links{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.post-nav .nav-subtitle{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:4px;font-weight:600}
.post-nav .nav-title{font-family:var(--serif);font-size:17px;line-height:1.3;color:var(--fg)}
.post-nav .nav-next{text-align:right}
.post-nav a:hover .nav-title{color:var(--accent)}

/* ============================================================
   COMMENTS
   ============================================================ */
.comments-area{max-width:760px;margin:0 auto;padding:24px 0 0}
.comments-title{font-family:var(--serif);font-size:24px;margin:0 0 18px;color:#f5fafa}
.comment-list{margin:0 0 24px}
.comment-list .children{padding-left:24px}
.comment-body{border-bottom:1px solid var(--border);padding:16px 0}
.comment-author{font-weight:600;color:var(--fg)}
.comment-meta{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px}
.comment-form label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--fg-soft);margin-bottom:6px}
.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url],.comment-form textarea{
  width:100%;padding:11px 13px;
  background:rgba(255,255,255,0.04);border:1px solid var(--border-hi);
  color:var(--fg);font:inherit;font-size:14px;
  border-radius:8px;margin-bottom:14px;
}
.comment-form input:focus,.comment-form textarea:focus{outline:none;border-color:var(--accent);background:rgba(255,255,255,0.06)}
.comment-form .submit{
  background:var(--accent);color:#001214;border:0;border-radius:10px;
  padding:10px 22px;font-weight:600;font-size:13px;cursor:pointer;
}
.comment-form .submit:hover{background:var(--accent-bright)}

/* ============================================================
   SEARCH FORM (global)
   ============================================================ */
.search-form{display:flex;gap:8px;max-width:520px}
.search-form input[type=search]{
  flex:1;padding:11px 14px;
  background:rgba(255,255,255,0.04);border:1px solid var(--border-hi);
  color:var(--fg);font:inherit;font-size:14.5px;border-radius:10px;
}
.search-form input:focus{outline:none;border-color:var(--accent)}
.search-form button{
  padding:11px 20px;background:var(--accent);color:#001214;border:0;
  border-radius:10px;font-weight:600;font-size:13px;letter-spacing:.02em;cursor:pointer;
}
.search-form button:hover{background:var(--accent-bright)}

/* ============================================================
   WIDGETS
   ============================================================ */
.widget{margin-bottom:32px}
.widget-title{font-family:var(--serif);font-size:14px;text-transform:uppercase;letter-spacing:.16em;color:var(--accent);padding-bottom:6px;margin:0 0 14px;border-bottom:1px solid var(--border)}
.widget ul li{padding:6px 0;border-bottom:1px solid var(--border);font-size:14px;color:var(--fg-soft)}
.widget a:hover{color:var(--accent)}

.footer-widgets{border-top:1px solid var(--border);background:var(--bg-deep)}
.footer-widgets .container{padding:48px 28px}
.footer-widget-grid{display:grid;gap:32px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.footer-widget-area .widget-title{color:var(--accent);border-bottom-color:var(--border)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  margin-top:0;background:var(--bg-deep);
  border-top:1px solid var(--border);
}
.site-footer .container{padding:56px 28px 32px}
.footer-grid{
  display:grid;grid-template-columns:1fr;gap:36px;
}
@media (min-width:768px){
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}
}
.footer-brand .brand{margin-bottom:14px}
.footer-brand .brand-name{color:#f5fafa}
.footer-brand p{color:var(--fg-soft);font-size:13.5px;margin:0 0 12px;max-width:340px;line-height:1.6}
.footer-brand .meta{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:12px;margin-top:8px}
.footer-brand .meta::before{content:"";width:10px;height:10px;border-radius:2px;background:var(--accent);display:inline-block}

.footer-col h4{font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--accent);margin:0 0 14px;font-weight:600}
.footer-col li{margin-bottom:10px}
.footer-col a{color:var(--fg-soft);font-size:14px}
.footer-col a:hover{color:var(--accent)}

.footer-bottom{
  border-top:1px solid var(--border);
  margin-top:36px;padding-top:22px;
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;
  color:var(--muted);font-size:12.5px;
}
.footer-bottom-links{display:flex;gap:14px;color:var(--muted)}
.footer-bottom-links a:hover{color:var(--accent)}

.social-list{display:flex;flex-wrap:wrap;gap:14px;margin-top:14px}
.social-list a{color:var(--muted);font-size:12.5px;text-transform:uppercase;letter-spacing:.12em}
.social-list a:hover{color:var(--accent)}

/* ============================================================
   CONTACT PAGE (Template Name: Contact)
   ============================================================ */
.contact-page{padding:64px 0 80px}
.contact-narrow{max-width:1100px}

.contact-hero{max-width:720px;margin:0 0 48px}
.contact-hero .section-eyebrow{margin-bottom:14px}
.contact-title{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(40px,5vw,60px);
  line-height:1.05;letter-spacing:-0.03em;
  margin:0 0 18px;color:#f5fafa;
}
.contact-lead{
  color:var(--fg-soft);font-size:16.5px;line-height:1.65;
  max-width:620px;margin:0;
}

.contact-layout{
  display:grid;gap:32px;
  grid-template-columns:1fr;
  align-items:flex-start;
}
@media (min-width:900px){
  .contact-layout{grid-template-columns:1.6fr 1fr;gap:40px}
}

/* ---------- Form ---------- */
.contact-form{
  background:var(--card);background-image:var(--grad-card);
  border:1px solid var(--border-hi);border-radius:16px;
  padding:32px;
  display:flex;flex-direction:column;gap:18px;
}

/* Honeypot — visually and assistive-tech hidden */
.contact-honeypot{
  position:absolute;left:-10000px;top:auto;
  width:1px;height:1px;overflow:hidden;
}

.contact-grid{
  display:grid;gap:18px;
  grid-template-columns:1fr;
}
@media (min-width:600px){
  .contact-grid{grid-template-columns:1fr 1fr}
}

.field{display:flex;flex-direction:column;gap:6px}
.field label{
  font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;
  font-weight:600;color:var(--fg-soft);
}
.field label .req{color:var(--accent);margin-left:2px}

.field input[type=text],
.field input[type=email],
.field select,
.field textarea{
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border-hi);
  border-radius:10px;
  padding:12px 14px;
  font:inherit;font-size:14.5px;line-height:1.5;
  color:var(--fg);
  transition:border-color .15s, background .15s, box-shadow .15s;
  width:100%;
}
.field textarea{resize:vertical;min-height:140px;font-family:inherit}
.field input::placeholder,.field textarea::placeholder{color:var(--dim)}

.field input:focus,
.field select:focus,
.field textarea:focus{
  outline:none;
  border-color:var(--accent);
  background:rgba(255,255,255,0.06);
  box-shadow:0 0 0 3px rgba(20,200,194,0.12);
}

.field select{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1l5 5 5-5' stroke='%2314c8c2' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;
  background-position:right 14px center;
  padding-right:36px;
  cursor:pointer;
}
.field select option{background:#0a1014;color:var(--fg)}

.field input[aria-invalid=true],
.field select[aria-invalid=true],
.field textarea[aria-invalid=true]{
  border-color:#e25a5a;
  background:rgba(226,90,90,0.06);
}

.field-error{
  display:inline-flex;align-items:center;gap:6px;
  color:#ff9a9a;font-size:12.5px;line-height:1.4;
  margin-top:2px;
}
.field-error::before{
  content:"";width:5px;height:5px;border-radius:50%;background:#ff9a9a;display:inline-block;
}
.field-hint{
  color:var(--muted);font-size:12px;line-height:1.4;margin-top:2px;
}

/* Consent */
.field-consent{padding-top:4px}
.field.field-consent label.consent-label{
  display:flex;gap:10px;align-items:flex-start;cursor:pointer;
  font-size:13.5px;line-height:1.6;color:var(--fg-soft);
  text-transform:none;letter-spacing:0;font-weight:normal;
}
.consent-label input[type=checkbox]{
  appearance:none;-webkit-appearance:none;
  width:18px;height:18px;flex:0 0 18px;margin-top:1px;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border-hi);
  border-radius:5px;cursor:pointer;
  position:relative;
  transition:background .15s, border-color .15s;
}
.consent-label input[type=checkbox]:checked{
  background:var(--accent);border-color:var(--accent);
}
.consent-label input[type=checkbox]:checked::after{
  content:"";position:absolute;left:5px;top:2px;
  width:5px;height:9px;
  border:solid #001214;border-width:0 2px 2px 0;
  transform:rotate(45deg);
}
.consent-label input[type=checkbox]:focus-visible{
  outline:2px solid var(--accent);outline-offset:2px;
}
.consent-label a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.consent-label a:hover{color:var(--accent-bright)}

/* Submit row */
.contact-actions{
  display:flex;gap:14px;align-items:center;flex-wrap:wrap;
  margin-top:4px;
}
.contact-actions .btn svg{width:14px;height:14px}
.contact-actions-note{
  color:var(--muted);font-size:12.5px;
}

/* Banner */
.contact-banner{
  display:flex;align-items:flex-start;gap:12px;
  padding:14px 16px;border-radius:10px;
  font-size:14px;line-height:1.5;
  margin-bottom:4px;
}
.contact-banner svg{width:18px;height:18px;flex:0 0 18px;margin-top:1px}
.contact-banner-sent{
  background:rgba(20,200,194,0.10);
  border:1px solid var(--accent-ring);
  color:var(--accent-bright);
}
.contact-banner-sent svg{color:var(--accent)}
.contact-banner-error{
  background:rgba(226,90,90,0.08);
  border:1px solid rgba(226,90,90,0.32);
  color:#ffb4b4;
}
.contact-banner-error svg{color:#ff9a9a}

/* ---------- Side panel ---------- */
.contact-side{display:flex;flex-direction:column;gap:18px}
.contact-side-card{
  background:var(--card);background-image:var(--grad-card);
  border:1px solid var(--border);border-radius:14px;
  padding:24px 26px;
}
.contact-side-card h3{
  font-family:var(--serif);font-size:18px;line-height:1.2;
  margin:0 0 14px;color:#f5fafa;letter-spacing:-0.01em;
}
.contact-side-card p{
  color:var(--fg-soft);font-size:14px;line-height:1.6;margin:0 0 12px;
}
.contact-side-card > ul{display:flex;flex-direction:column;gap:14px;margin:0;padding:0;list-style:none}
.contact-side-card > ul li{
  display:flex;gap:12px;align-items:flex-start;
}
.contact-side-card > ul svg{
  width:18px;height:18px;color:var(--accent);
  flex:0 0 18px;margin-top:2px;
}
.contact-side-card > ul strong{
  display:block;color:var(--fg);font-size:14px;font-weight:600;margin-bottom:2px;
}
.contact-side-card > ul span{
  color:var(--fg-soft);font-size:13.5px;line-height:1.5;
}
.contact-tips{
  margin:0;padding:0;list-style:none;
  display:flex;flex-direction:column;gap:6px;
}
.contact-tips li{
  position:relative;padding-left:18px;
  color:var(--fg-soft);font-size:13.5px;line-height:1.5;
}
.contact-tips li::before{
  content:"";position:absolute;left:0;top:8px;
  width:6px;height:6px;border-radius:50%;background:var(--accent);
}

/* Minimal footer variant for the Contact template */
.tgi-template-contact .site-footer{margin-top:0}


/* ============================================================
   COMPANY / ABOUT PAGE
   ============================================================ */
.company-page{padding:64px 0 80px}
.company-narrow{max-width:880px}

/* Hero */
.company-hero{margin:0 0 72px}
.company-hero .section-eyebrow{margin-bottom:18px}
.company-title{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(40px,5.4vw,68px);
  line-height:1.02;letter-spacing:-0.03em;
  margin:0 0 22px;color:#f5fafa;
}
.company-title em{
  font-style:italic;font-weight:500;
  background:linear-gradient(90deg,var(--accent) 0%,var(--accent-bright) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  letter-spacing:-0.02em;
}
.company-lead{
  color:var(--fg-soft);font-size:17px;line-height:1.65;
  max-width:620px;margin:0;
}

.company-meta-bar{
  display:flex;flex-wrap:wrap;gap:18px 28px;
  margin:28px 0 0;
  padding:14px 18px;
  background:rgba(255,255,255,0.02);
  border:1px solid var(--border);border-radius:10px;
  font-size:13px;color:var(--fg-soft);
}
.company-meta-bar strong{
  color:var(--accent);font-weight:600;
  margin-right:6px;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
}

/* Section spacing */
.company-section{margin:0 0 64px}
.company-section .section-eyebrow{margin-bottom:14px}

.company-h2{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(28px,3.6vw,42px);
  line-height:1.08;letter-spacing:-0.025em;
  margin:0 0 26px;color:#f5fafa;
}

.company-prose{max-width:680px}
.company-prose p{
  color:var(--fg-soft);font-size:16.5px;line-height:1.7;
  margin:0 0 18px;
}
.company-prose p:last-child{margin-bottom:0}
.company-prose p strong{color:var(--fg);font-weight:600}

/* Principles grid (also reused on the About page) */
.company-principles{
  display:grid;gap:22px;
  grid-template-columns:1fr;
  margin-top:8px;
}
@media (min-width:720px){.company-principles{grid-template-columns:1fr 1fr;gap:26px}}

.company-principles article{
  background:var(--card);background-image:var(--grad-card);
  border:1px solid var(--border);border-radius:14px;
  padding:26px 28px;
  transition:border-color .15s, transform .15s;
}
.company-principles article:hover{border-color:var(--border-hi);transform:translateY(-1px)}

.company-num{
  display:inline-block;font-family:var(--serif);
  font-size:14px;font-weight:600;color:var(--accent);
  letter-spacing:.04em;margin-bottom:16px;
}

.company-principles h3{
  font-family:var(--serif);font-size:21px;line-height:1.2;
  margin:0 0 10px;color:#f5fafa;letter-spacing:-0.015em;
}
.company-principles p{
  color:var(--fg-soft);font-size:14.5px;line-height:1.65;margin:0;
}

/* Products section */
.company-products{
  display:grid;gap:24px;grid-template-columns:1fr;
}
@media (min-width:820px){.company-products{grid-template-columns:1fr 1fr;gap:28px}}

.company-product{
  background:var(--card);background-image:var(--grad-card);
  border:1px solid var(--border-hi);border-radius:16px;
  padding:30px 32px;
  display:flex;flex-direction:column;gap:14px;
}
.company-product-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.company-product-tag{
  display:inline-block;padding:4px 10px;
  background:rgba(20,200,194,0.10);border:1px solid var(--accent-ring);
  border-radius:9999px;
  color:var(--accent-bright);
  font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
}
.company-product h3{
  font-family:var(--serif);font-size:24px;line-height:1.2;
  margin:0;color:#f5fafa;letter-spacing:-0.015em;
}
.company-product > p{
  color:var(--fg-soft);font-size:15px;line-height:1.65;margin:0;
}
.company-product-meta{
  display:flex;flex-wrap:wrap;gap:8px;
}
.company-product-meta span{
  display:inline-block;padding:4px 10px;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  border-radius:6px;
  font-size:11.5px;color:var(--fg-soft);
  letter-spacing:.04em;
}
.company-product-link{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--accent);font-size:14px;font-weight:600;
  margin-top:4px;
  transition:color .15s, gap .15s;
}
.company-product-link:hover{color:var(--accent-bright);gap:12px}
.company-product-link svg{width:15px;height:15px}

/* Facts dl */
.company-facts{
  display:grid;gap:0;
  grid-template-columns:1fr;
  background:var(--card);background-image:var(--grad-card);
  border:1px solid var(--border);border-radius:14px;
  padding:8px 28px;
}
.company-facts > div{
  display:grid;grid-template-columns:1fr;gap:4px;
  padding:18px 0;border-top:1px solid var(--border);
}
.company-facts > div:first-child{border-top:0}
@media (min-width:640px){
  .company-facts > div{
    grid-template-columns:200px 1fr;gap:24px;align-items:baseline;
  }
}
.company-facts dt{
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  font-weight:600;color:var(--muted);margin:0;
}
.company-facts dd{
  margin:0;color:var(--fg);font-size:14.5px;line-height:1.5;
}
.company-facts dd a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.company-facts dd a:hover{color:var(--accent-bright)}

/* Final CTA */
.company-final-cta{
  text-align:center;
  padding:56px 24px 24px;
  border-top:1px solid var(--border);
  margin-top:24px;
}
.company-final-cta h2{margin:0 0 12px}
.company-final-cta p{color:var(--fg-soft);font-size:15.5px;max-width:560px;margin:0 auto 24px;line-height:1.6}
.company-final-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;align-items:center}

/* Minimal footer for these single-page templates */
.tgi-template-company .site-footer,
.tgi-template-about .site-footer{margin-top:0}

/* ============================================================
   LEGAL PAGES (Privacy, Terms)
   ============================================================ */
.legal-page{padding:64px 0 80px}
.legal-narrow{max-width:820px}

.legal-hero{margin:0 0 48px}
.legal-hero .section-eyebrow{margin-bottom:18px}
.legal-title{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(40px,5.2vw,64px);
  line-height:1.04;letter-spacing:-0.03em;
  margin:0 0 22px;color:#f5fafa;
}
.legal-lead{
  color:var(--fg-soft);font-size:16.5px;line-height:1.7;
  max-width:680px;margin:0;
}
.legal-updated{
  margin:18px 0 0;color:var(--muted);
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
}

.legal-body{display:flex;flex-direction:column;gap:0}

/* Summary call-out (privacy "short version") */
.legal-summary{
  background:var(--card);background-image:var(--grad-card);
  border:1px solid var(--accent-ring);border-radius:14px;
  padding:24px 28px;
  margin-bottom:48px;
}
.legal-summary h2{
  font-family:var(--serif);font-size:18px;line-height:1.2;
  margin:0 0 14px;color:var(--accent-bright);letter-spacing:-0.01em;
  font-weight:600;
}
.legal-summary ul{
  margin:0;padding:0;list-style:none;
  display:flex;flex-direction:column;gap:10px;
}
.legal-summary li{
  position:relative;padding-left:22px;
  color:var(--fg-soft);font-size:14.5px;line-height:1.6;
}
.legal-summary li::before{
  content:"✓";position:absolute;left:0;top:0;
  color:var(--accent);font-weight:700;
}

/* Standard legal section */
.legal-section{
  padding:32px 0;
  border-top:1px solid var(--border);
}
.legal-section:first-of-type{border-top:0;padding-top:0}

.legal-section h2{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(22px,2.6vw,28px);
  line-height:1.18;letter-spacing:-0.015em;
  margin:0 0 18px;color:#f5fafa;
}
.legal-section h3{
  font-family:var(--serif);font-weight:600;
  font-size:17px;line-height:1.25;
  margin:24px 0 10px;color:#f5fafa;letter-spacing:-0.005em;
}
.legal-section h3:first-of-type{margin-top:0}
.legal-section p{
  color:var(--fg-soft);font-size:15.5px;line-height:1.75;
  margin:0 0 14px;max-width:720px;
}
.legal-section p:last-child{margin-bottom:0}
.legal-section ul{
  margin:0 0 14px;padding:0;list-style:none;
  display:flex;flex-direction:column;gap:8px;
}
.legal-section ul li{
  position:relative;padding-left:18px;
  color:var(--fg-soft);font-size:15px;line-height:1.7;
  max-width:720px;
}
.legal-section ul li::before{
  content:"";position:absolute;left:0;top:11px;
  width:6px;height:6px;border-radius:50%;background:var(--accent);
}
.legal-section ul li strong{color:var(--fg);font-weight:600}
.legal-section a{
  color:var(--accent);text-decoration:underline;text-underline-offset:3px;
  text-decoration-thickness:1px;
}
.legal-section a:hover{color:var(--accent-bright)}

/* Minimal footer for legal templates */
.tgi-template-legal .site-footer{margin-top:0}

/* ============================================================
   DOCS PAGE
   ============================================================ */
.docs-page{padding:64px 0 80px}
.docs-wrap{max-width:1200px}

.docs-hero{margin:0 0 56px;max-width:760px}
.docs-hero .section-eyebrow{margin-bottom:18px}
.docs-title{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(44px,5.4vw,68px);
  line-height:1.04;letter-spacing:-0.03em;
  margin:0 0 22px;color:#f5fafa;
}
.docs-lead{
  color:var(--fg-soft);font-size:17px;line-height:1.65;
  max-width:660px;margin:0;
}
.docs-version-line{
  margin:18px 0 0;color:var(--muted);
  font-size:12px;letter-spacing:.10em;text-transform:uppercase;font-weight:600;
}

/* Layout: TOC + body */
.docs-layout{
  display:grid;gap:48px;
  grid-template-columns:1fr;
  align-items:flex-start;
}
@media (min-width:980px){
  .docs-layout{grid-template-columns:240px 1fr;gap:56px}
}

/* TOC sidebar */
.docs-toc{position:relative}
@media (min-width:980px){
  .docs-toc{
    position:sticky;top:100px;
    align-self:start;
    max-height:calc(100vh - 120px);
    overflow-y:auto;
  }
}
.docs-toc-inner{
  background:rgba(255,255,255,0.02);
  border:1px solid var(--border);border-radius:12px;
  padding:18px 20px 20px;
}
.docs-toc-label{
  margin:0 0 12px;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  font-weight:600;color:var(--accent);
}
.docs-toc ol{
  list-style:none;margin:0;padding:0;
  display:flex;flex-direction:column;gap:2px;
  counter-reset:tgi-toc;
}
.docs-toc li{counter-increment:tgi-toc}
.docs-toc a{
  display:block;padding:7px 0 7px 26px;position:relative;
  font-size:13.5px;line-height:1.4;
  color:var(--fg-soft);
  border-radius:6px;
  transition:color .15s, background .15s;
}
.docs-toc a::before{
  content:counter(tgi-toc, decimal-leading-zero);
  position:absolute;left:0;top:7px;
  font-size:11px;color:var(--muted);font-weight:600;
  letter-spacing:.04em;
}
.docs-toc a:hover{
  color:var(--accent-bright);
}
.docs-toc a:hover::before{color:var(--accent)}

/* Body */
.docs-body{min-width:0}

.docs-section{
  padding:0 0 56px;
  margin-bottom:56px;
  border-bottom:1px solid var(--border);
  scroll-margin-top:80px;
}
.docs-section:last-of-type{border-bottom:0;margin-bottom:32px}

.docs-section-num{
  margin:0 0 14px;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;color:var(--accent);
}

.docs-body h2{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(26px,3vw,34px);
  line-height:1.12;letter-spacing:-0.02em;
  margin:0 0 22px;color:#f5fafa;
}
.docs-body h3{
  font-family:var(--serif);font-weight:600;
  font-size:18px;line-height:1.25;
  margin:32px 0 12px;color:#f5fafa;letter-spacing:-0.005em;
}
.docs-body h3:first-of-type{margin-top:18px}
.docs-body p{
  color:var(--fg-soft);font-size:15.5px;line-height:1.75;
  margin:0 0 14px;max-width:720px;
}
.docs-body ul,
.docs-body ol{
  margin:0 0 18px;padding:0;list-style:none;
  display:flex;flex-direction:column;gap:8px;
}
.docs-body ul li{
  position:relative;padding-left:18px;
  color:var(--fg-soft);font-size:15px;line-height:1.7;
  max-width:740px;
}
.docs-body ul li::before{
  content:"";position:absolute;left:0;top:11px;
  width:6px;height:6px;border-radius:50%;background:var(--accent);
}
.docs-body ol{counter-reset:docs-step}
.docs-body ol li{
  counter-increment:docs-step;
  position:relative;padding-left:34px;
  color:var(--fg-soft);font-size:15px;line-height:1.7;
  max-width:740px;
}
.docs-body ol li::before{
  content:counter(docs-step);
  position:absolute;left:0;top:0;
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;
  background:rgba(20,200,194,0.12);
  border:1px solid var(--accent-ring);
  color:var(--accent-bright);
  font-size:11px;font-weight:700;
}
.docs-body strong{color:var(--fg);font-weight:600}
.docs-body code{
  background:rgba(255,255,255,0.06);
  border:1px solid var(--border);
  padding:2px 7px;border-radius:5px;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:13px;color:var(--accent-bright);
}
.docs-body a{
  color:var(--accent);text-decoration:underline;text-underline-offset:3px;
  text-decoration-thickness:1px;
}
.docs-body a:hover{color:var(--accent-bright)}

/* Quickstart numbered steps (visually distinct) */
.docs-steps{counter-reset:qs-step}
.docs-steps li{counter-increment:qs-step}
.docs-steps li::before{content:counter(qs-step)}

/* Modules ordered list */
.docs-modules{counter-reset:mod-step}
.docs-modules li{counter-increment:mod-step}
.docs-modules li::before{content:counter(mod-step)}

/* Callout box */
.docs-callout{
  display:block;margin:18px 0 0;
  padding:16px 20px;
  background:rgba(20,200,194,0.06);
  border:1px solid var(--accent-ring);border-left:3px solid var(--accent);
  border-radius:8px;
  color:var(--fg-soft);font-size:14.5px;line-height:1.6;
  max-width:740px;
}
.docs-callout strong{
  color:var(--accent-bright);
  display:block;margin-bottom:4px;
}

/* Table */
.docs-table{
  width:100%;border-collapse:collapse;
  margin:8px 0 18px;
  background:rgba(255,255,255,0.02);
  border:1px solid var(--border);border-radius:8px;
  overflow:hidden;
  font-size:14px;
}
.docs-table th,.docs-table td{
  text-align:left;padding:11px 14px;
  border-top:1px solid var(--border);
  color:var(--fg-soft);
}
.docs-table thead th{
  border-top:0;
  background:rgba(255,255,255,0.03);
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  font-weight:600;color:var(--accent);
}
.docs-table td:first-child{white-space:nowrap;vertical-align:top}
.docs-table code{background:transparent;border:0;padding:0;color:var(--accent-bright)}

/* Final CTA */
.docs-final-cta{
  text-align:center;
  padding:40px 24px 24px;
}
.docs-final-cta h2{margin:0 0 12px;font-size:clamp(24px,2.8vw,30px)}
.docs-final-cta p{color:var(--fg-soft);font-size:15.5px;max-width:520px;margin:0 auto 22px}
.docs-final-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}

/* Smooth anchor scrolling */
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}

/* Minimal footer for docs */
.tgi-template-docs .site-footer{margin-top:0}




/* ============================================================
   PLUGIN PAGE (Template Name: Plugin)
   ============================================================ */
.plugin-page{padding:72px 0 80px}
.plugin-narrow{max-width:1100px}

.plugin-hero{max-width:760px;margin:0 0 60px}
.plugin-hero .section-eyebrow{margin-bottom:18px}
.plugin-title{
  font-family:var(--serif);
  font-weight:600;
  font-size:clamp(40px,5.4vw,68px);
  line-height:1.02;letter-spacing:-0.03em;
  margin:0 0 24px;color:#f5fafa;
}
.plugin-title em{
  font-style:italic;font-weight:500;
  background:linear-gradient(90deg,var(--accent) 0%,var(--accent-bright) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  letter-spacing:-0.02em;
}
.plugin-lead{
  color:var(--fg-soft);font-size:17px;line-height:1.65;
  max-width:560px;margin:0 0 30px;
}
.plugin-cta{display:flex;flex-wrap:wrap;gap:12px}
.plugin-cta .btn svg{width:16px;height:16px}

/* Feature grid */
.plugin-features{
  display:grid;gap:18px;
  grid-template-columns:1fr;
  margin:0 0 64px;
}
@media (min-width:760px){
  .plugin-features{grid-template-columns:1fr 1fr;gap:22px}
}
.plugin-feature{
  background:var(--card);
  background-image:var(--grad-card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:28px;
  transition:border-color .15s, transform .15s;
}
.plugin-feature:hover{border-color:var(--border-hi);transform:translateY(-1px)}
.plugin-feature .ico-bare{
  display:inline-flex;width:24px;height:24px;
  color:var(--accent);margin-bottom:24px;
}
.plugin-feature .ico-bare svg{width:24px;height:24px}
.plugin-feature h3{
  font-family:var(--serif);font-size:21px;line-height:1.2;
  margin:0 0 10px;color:#f5fafa;letter-spacing:-0.015em;
}
.plugin-feature p{
  color:var(--fg-soft);font-size:14.5px;line-height:1.6;margin:0;
}

/* Divider */
.plugin-rule{
  border:0;height:1px;background:var(--border);
  margin:0 0 48px;
}

/* Installation */
.plugin-install{max-width:760px}
.plugin-section-title{
  font-family:var(--serif);
  font-size:clamp(28px,3.2vw,38px);
  letter-spacing:-0.02em;line-height:1.1;
  margin:0 0 26px;color:#f5fafa;
}
.plugin-steps{
  counter-reset:plugin-step;
  margin:0 0 32px;padding:0;list-style:none;
  display:flex;flex-direction:column;gap:14px;
}
.plugin-steps li{
  counter-increment:plugin-step;
  display:flex;gap:14px;align-items:flex-start;
  color:var(--fg-soft);font-size:16px;line-height:1.55;
  padding-left:0;
}
.plugin-steps li::before{
  content:counter(plugin-step) ".";
  font-family:var(--sans);font-weight:600;color:var(--muted);
  flex:0 0 auto;min-width:18px;
}
.plugin-steps li strong{color:var(--fg);font-weight:600}
.plugin-steps li code{
  display:inline-block;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:.88em;
  background:rgba(255,255,255,0.06);
  color:var(--accent-bright);
  padding:1px 7px;border-radius:5px;
  border:1px solid var(--border);
  vertical-align:baseline;
}

.plugin-docs-link{margin:0;padding:8px 0 0}
.plugin-docs-link a{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--accent);font-size:14.5px;font-weight:500;
  transition:color .15s;
}
.plugin-docs-link a:hover{color:var(--accent-bright)}
.plugin-docs-link svg{width:18px;height:18px}

.plugin-page-content{margin-top:48px;padding:0}

/* Hero meta bar */
.plugin-meta-bar{
  display:flex;flex-wrap:wrap;gap:18px 28px;
  margin:24px 0 28px;
  padding:14px 18px;
  background:rgba(255,255,255,0.02);
  border:1px solid var(--border);border-radius:10px;
  font-size:13px;color:var(--fg-soft);
}
.plugin-meta-bar strong{
  color:var(--accent);font-weight:600;
  margin-right:6px;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
}

.plugin-author{
  margin:18px 0 0;color:var(--muted);font-size:13.5px;line-height:1.55;
}
.plugin-author strong{color:var(--fg-soft);font-weight:600}

/* Generic section spacing for the plugin page */
.plugin-section{margin:0 0 72px}
.plugin-section .section-eyebrow{margin-bottom:10px}
.plugin-section-lead{
  color:var(--fg-soft);font-size:15px;line-height:1.65;
  max-width:680px;margin:0 0 30px;
}

/* ============================================================
   FULL FEATURE SPEC GRID (3-col)
   ============================================================ */
.plugin-spec-grid{
  display:grid;gap:18px;
  grid-template-columns:1fr;
  margin-top:8px;
}
@media (min-width:720px){.plugin-spec-grid{grid-template-columns:1fr 1fr}}
@media (min-width:1020px){.plugin-spec-grid{grid-template-columns:1fr 1fr 1fr;gap:22px}}

.plugin-spec-card{
  background:var(--card);background-image:var(--grad-card);
  border:1px solid var(--border);border-radius:12px;
  padding:22px 22px 24px;
  transition:border-color .15s, transform .15s;
}
.plugin-spec-card:hover{border-color:var(--border-hi);transform:translateY(-1px)}
.plugin-spec-ico{
  display:inline-flex;color:var(--accent);margin-bottom:14px;
}
.plugin-spec-ico svg{width:22px;height:22px}
.plugin-spec-card h4{
  font-family:var(--serif);font-size:17px;line-height:1.25;
  margin:0 0 8px;color:#f5fafa;letter-spacing:-0.01em;font-weight:600;
}
.plugin-spec-card p{
  color:var(--fg-soft);font-size:13.5px;line-height:1.55;margin:0;
}

/* ============================================================
   THEME PAIRING TWO-CARD
   ============================================================ */
.plugin-pair{
  display:grid;gap:22px;grid-template-columns:1fr;margin-top:14px;
}
@media (min-width:820px){.plugin-pair{grid-template-columns:1fr 1fr;gap:26px}}
.plugin-pair-card{
  background:var(--card);background-image:var(--grad-card);
  border:1px solid var(--border-hi);border-radius:14px;
  padding:28px 30px;
}
.plugin-pair-card h3{
  font-family:var(--serif);font-size:20px;line-height:1.2;
  margin:0 0 16px;color:#f5fafa;letter-spacing:-0.015em;
}
.plugin-pair-card .checks li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:14.5px;color:var(--fg-soft);line-height:1.55;
  margin:0 0 12px;
}
.plugin-pair-card .checks li:last-child{margin-bottom:0}
.plugin-pair-card .checks svg{
  width:18px;height:18px;color:var(--accent);
  flex:0 0 18px;margin-top:1px;
}

/* ============================================================
   PUBLISHER CATALOG GRID
   ============================================================ */
.catalog-grid{
  display:grid;gap:24px;grid-template-columns:1fr;
}
@media (min-width:760px){.catalog-grid{grid-template-columns:1fr 1fr 1fr;gap:32px}}
.catalog-col h4{
  margin:0 0 12px;font-size:12px;font-weight:600;
}
.catalog-tag{
  display:inline-block;padding:4px 10px;
  background:rgba(20,200,194,0.10);
  border:1px solid var(--accent-ring);
  border-radius:9999px;
  color:var(--accent-bright);
  font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
}
.catalog-col ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:6px}
.catalog-col li{
  color:var(--fg-soft);font-size:13.5px;line-height:1.5;
  padding:6px 0;border-bottom:1px solid var(--border);
}
.catalog-col li:last-child{border-bottom:0}
.catalog-foot{
  margin-top:24px;padding:14px 18px;
  background:rgba(255,255,255,0.02);
  border:1px solid var(--border);border-radius:10px;
  color:var(--muted);font-size:13px;line-height:1.55;
}

/* ============================================================
   PRIVACY LIST
   ============================================================ */
.privacy-list{
  margin:0;padding:0;list-style:none;
  display:flex;flex-direction:column;gap:14px;
}
.privacy-list li{
  background:var(--card);background-image:var(--grad-card);
  border:1px solid var(--border);border-radius:12px;
  padding:18px 22px;
  display:flex;flex-direction:column;gap:6px;
}
.privacy-list strong{
  color:#f5fafa;font-size:15px;font-weight:600;line-height:1.3;
}
.privacy-list strong::before{
  content:"✓ ";color:var(--accent);font-weight:700;
}
.privacy-list span{color:var(--fg-soft);font-size:14px;line-height:1.6}

/* ============================================================
   FAQ
   ============================================================ */
.plugin-faq-list{
  display:flex;flex-direction:column;gap:8px;margin-top:14px;
}
.plugin-faq-item{
  background:var(--card);background-image:var(--grad-card);
  border:1px solid var(--border);border-radius:10px;
  overflow:hidden;
  transition:border-color .15s;
}
.plugin-faq-item[open]{border-color:var(--border-hi)}
.plugin-faq-item summary{
  list-style:none;cursor:pointer;
  padding:16px 20px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  font-family:var(--serif);font-size:16px;font-weight:500;
  color:#f5fafa;letter-spacing:-0.005em;
}
.plugin-faq-item summary::-webkit-details-marker{display:none}
.plugin-faq-item summary svg{
  width:18px;height:18px;color:var(--accent);
  transition:transform .2s ease;flex:0 0 18px;
}
.plugin-faq-item[open] summary svg{transform:rotate(180deg)}
.plugin-faq-body{
  padding:0 20px 18px;
  color:var(--fg-soft);font-size:14.5px;line-height:1.65;
}

/* ============================================================
   FINAL CTA
   ============================================================ */
.plugin-final-cta{
  text-align:center;
  padding:48px 24px;
  border-top:1px solid var(--border);
}
.plugin-final-cta h2{margin:0 0 10px}
.plugin-final-cta p{color:var(--fg-soft);font-size:15px;max-width:520px;margin:0 auto 22px}
.plugin-final-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}

/* Minimal footer variant for the Plugin template */
.tgi-template-plugin .site-footer .footer-grid,
.tgi-template-plugin .footer-bottom-links{display:none}
.tgi-template-plugin .site-footer{margin-top:0;background:transparent;border-top:1px solid var(--border)}
.tgi-template-plugin .site-footer .container{padding:22px 28px}
.tgi-template-plugin .footer-bottom{
  border-top:0;margin-top:0;padding-top:0;
  justify-content:flex-start;
  color:var(--muted);
}

/* ============================================================
   DEMO PAGE (Template Name: Demo) — rich editorial mockup
   ============================================================ */
.demo-page{padding:64px 0 80px}

/* Centered hero */
.demo-hero{
  text-align:center;max-width:760px;margin:0 auto 56px;
}
.demo-hero .pill{margin-bottom:20px}
.demo-h1{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(34px,4.4vw,52px);
  line-height:1.05;letter-spacing:-0.025em;
  margin:0 0 18px;color:#f5fafa;
}
.demo-lead{
  color:var(--fg-soft);font-size:16px;line-height:1.6;
  max-width:620px;margin:0 auto 24px;
}
.demo-cta{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.demo-cta .btn svg{width:14px;height:14px}

/* Live pulse badge in browser bar */
.browser-bar{position:relative}
.browser-live{
  display:inline-flex;align-items:center;gap:6px;margin-left:auto;
  font-size:9.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent-bright);
  padding:3px 9px;border-radius:9999px;
}
.live-pulse,.live-pulse-sm{
  width:6px;height:6px;border-radius:50%;background:var(--accent-bright);
  box-shadow:0 0 0 0 var(--accent-ring);animation:live-ring 1.6s infinite;
}
.live-pulse-sm{width:5px;height:5px}
@keyframes live-ring{
  0%  {box-shadow:0 0 0 0 rgba(20,200,194,0.6)}
  70% {box-shadow:0 0 0 8px rgba(20,200,194,0)}
  100%{box-shadow:0 0 0 0 rgba(20,200,194,0)}
}

/* Stage */
.demo-stage{margin:0 auto 88px;max-width:1100px}
.demo-stage .browser{margin:0}
.demo-mock{padding:0;background:#0a1014}

.demo-caption{
  text-align:center;color:var(--muted);font-size:13px;
  margin:18px auto 8px;max-width:560px;line-height:1.5;
}
.demo-caption-link{text-align:center;margin:0}
.demo-caption-link a{
  font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--accent);
}
.demo-caption-link a:hover{color:var(--accent-bright)}

/* ----- Browser body internals ----- */

.demo-topbar{
  display:flex;align-items:center;gap:16px;
  padding:14px 18px;border-bottom:1px solid var(--border);
}
.demo-brand{display:inline-flex;align-items:center;gap:8px;font-family:var(--serif);font-weight:600;font-size:14px;color:#f5fafa}
.demo-brand i{width:11px;height:11px;background:var(--accent);border-radius:2px;display:inline-block}
.demo-cats{display:flex;gap:18px;margin-left:auto;font-size:12px;font-weight:500;color:var(--muted)}
.demo-cats span:hover{color:var(--fg)}
.demo-live{
  display:inline-flex;align-items:center;gap:6px;
  font-size:9.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent-bright);
}

.demo-breaking{
  display:flex;align-items:center;gap:12px;
  padding:11px 18px;background:rgba(220,38,38,0.10);
  border-bottom:1px solid rgba(220,38,38,0.22);
  font-size:12.5px;color:var(--fg-soft);
}
.demo-breaking b{
  background:#dc2626;color:#fff;
  padding:3px 8px;border-radius:4px;
  font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
}

/* Main grid: lead + most-active rail */
.demo-grid-main{
  display:grid;gap:14px;padding:18px;
  grid-template-columns:1fr;
}
@media (min-width:780px){
  .demo-grid-main{grid-template-columns:2fr 1fr;gap:18px}
}

.demo-hero-card{
  background:rgba(255,255,255,0.02);border:1px solid var(--border);border-radius:10px;overflow:hidden;
}
.demo-hero-img{
  aspect-ratio:16/8;width:100%;display:block;
}
.demo-grad-1{background:linear-gradient(135deg, #1b2a52 0%, #3b1e6b 40%, #6e2bb5 100%)}
.demo-grad-2{background:linear-gradient(135deg, #0e6b6b 0%, #14c8c2 100%)}
.demo-grad-3{background:linear-gradient(135deg, #1e2966 0%, #4756e7 100%)}
.demo-grad-4{background:linear-gradient(135deg, #3a1a5e 0%, #8e3ac3 100%)}
.demo-grad-5{background:linear-gradient(135deg, #5a1a1a 0%, #c14a3a 100%)}

.demo-hero-body{padding:16px 18px 18px}
.demo-kicker{
  display:inline-block;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
  font-weight:600;color:var(--accent);margin-bottom:8px;
}
.demo-hero-body h2{
  font-family:var(--serif);font-size:18px;line-height:1.22;margin:0 0 8px;
  color:#f5fafa;letter-spacing:-0.015em;
}
.demo-hero-body p{color:var(--fg-soft);font-size:13px;line-height:1.55;margin:0}

.demo-rail{
  background:rgba(255,255,255,0.02);border:1px solid var(--border);border-radius:10px;
  padding:14px 14px 12px;
  display:flex;flex-direction:column;
}
.demo-rail header{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.demo-rail header svg{width:14px;height:14px;color:var(--accent)}
.demo-rail header b{
  font-size:10.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);
}
.demo-rail ol{display:flex;flex-direction:column;gap:10px}
.demo-rail li{display:flex;align-items:flex-start;gap:10px;font-size:12.5px;line-height:1.4;color:var(--fg-soft)}
.demo-rail .n{
  flex:0 0 18px;font-weight:700;font-size:11.5px;color:var(--accent);
  padding-top:1px;
}

/* Accelerating thumbs */
.demo-thumbs{
  display:grid;gap:12px;padding:0 18px 16px;
  grid-template-columns:repeat(2,1fr);
}
@media (min-width:780px){.demo-thumbs{grid-template-columns:repeat(4,1fr);gap:14px}}

.demo-thumb{
  background:rgba(255,255,255,0.02);border:1px solid var(--border);border-radius:8px;overflow:hidden;
  display:flex;flex-direction:column;
}
.demo-thumb-img{aspect-ratio:16/8;width:100%;display:block}
.demo-thumb-tag{
  padding:9px 12px 0;font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;color:var(--accent);
}
.demo-thumb h4{
  font-family:var(--serif);font-size:13px;line-height:1.25;
  margin:4px 12px 12px;color:#f5fafa;letter-spacing:-0.01em;
}

/* Live latest */
.demo-latest{
  margin:0 18px;padding:14px 0 0;border-top:1px solid var(--border);
}
.demo-latest header{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding-bottom:8px}
.demo-latest header svg{width:13px;height:13px;color:var(--accent)}
.demo-latest header b{
  font-size:10.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);
}
.demo-latest ul{display:flex;flex-direction:column}
.demo-latest li{
  display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;
  padding:10px 0;border-top:1px solid var(--border);font-size:12.5px;
}
.demo-latest li:first-child{border-top:0}
.demo-latest .src{
  display:inline-block;
  background:rgba(255,255,255,0.04);border:1px solid var(--border);
  padding:3px 9px;border-radius:4px;
  font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--fg-soft);
  min-width:88px;text-align:center;
}
.demo-latest .hed{color:var(--fg-soft);line-height:1.4}
.demo-latest .age{font-size:11.5px;color:var(--muted)}

/* Inline newsletter capture inside the mockup */
.demo-newsletter{
  margin:16px 18px 18px;
  background:rgba(255,255,255,0.02);border:1px solid var(--border);
  border-radius:10px;padding:14px 16px;
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;
}
.demo-newsletter-copy{display:flex;flex-direction:column;gap:2px}
.demo-newsletter-copy strong{font-family:var(--serif);font-size:14px;color:#f5fafa;font-weight:600}
.demo-newsletter-copy span{font-size:11.5px;color:var(--muted)}
.demo-newsletter-form{display:flex;gap:8px;align-items:center}
.demo-newsletter-form input{
  background:rgba(255,255,255,0.04);border:1px solid var(--border);
  padding:7px 10px;border-radius:6px;
  color:var(--fg);font:inherit;font-size:12px;min-width:200px;
}
.demo-newsletter-form input::placeholder{color:var(--dim)}
.demo-newsletter-form button{
  background:var(--accent);color:#001214;border:0;
  padding:8px 14px;border-radius:6px;
  font-weight:600;font-size:11.5px;cursor:pointer;
}
.demo-newsletter-form button:hover{background:var(--accent-bright)}

/* ============================================================
   12 MODULES GRID
   ============================================================ */
.demo-modules{margin:0 0 88px}
.demo-section-head{text-align:center;max-width:680px;margin:0 auto 36px}
.demo-section-head .section-eyebrow{margin-bottom:12px}
.demo-h2{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(28px,3.4vw,40px);
  line-height:1.08;letter-spacing:-0.02em;
  margin:0 0 12px;color:#f5fafa;
}
.demo-section-lead{color:var(--fg-soft);font-size:15px;line-height:1.6;margin:0 auto;max-width:600px}

.demo-mod-grid{
  display:grid;gap:18px;
  grid-template-columns:1fr;
}
@media (min-width:720px){.demo-mod-grid{grid-template-columns:1fr 1fr}}
@media (min-width:1020px){.demo-mod-grid{grid-template-columns:1fr 1fr 1fr;gap:22px}}

.demo-mod-card{
  background:var(--card);background-image:var(--grad-card);
  border:1px solid var(--border);border-radius:12px;
  padding:22px 22px 24px;
  transition:border-color .15s, transform .15s;
}
.demo-mod-card:hover{border-color:var(--border-hi);transform:translateY(-1px)}
.demo-mod-ico{
  display:inline-flex;color:var(--accent);margin-bottom:18px;
}
.demo-mod-ico svg{width:22px;height:22px}
.demo-mod-card h3{
  font-family:var(--serif);font-size:18px;line-height:1.2;
  margin:0 0 8px;color:#f5fafa;letter-spacing:-0.01em;
}
.demo-mod-card p{color:var(--fg-soft);font-size:13.5px;line-height:1.6;margin:0}

/* ============================================================
   TECH SPECS
   ============================================================ */
.demo-specs{margin:0 0 88px}
.demo-specs-grid{
  display:grid;gap:22px;
  grid-template-columns:1fr;
}
@media (min-width:900px){.demo-specs-grid{grid-template-columns:1fr 1fr;gap:26px}}

.demo-specs-card{
  background:var(--card);background-image:var(--grad-card);
  border:1px solid var(--border-hi);border-radius:14px;
  padding:30px;
}
.demo-specs-card .section-eyebrow{margin-bottom:8px}
.demo-specs-card h3{
  font-family:var(--serif);font-size:24px;line-height:1.15;
  margin:0 0 18px;color:#f5fafa;letter-spacing:-0.015em;
}
.demo-specs-lead{color:var(--fg-soft);font-size:14px;line-height:1.6;margin:0 0 20px}

.demo-specs-list{margin:0;padding:0;display:flex;flex-direction:column}
.demo-specs-list > div{
  display:flex;justify-content:space-between;gap:12px;align-items:baseline;
  padding:10px 0;border-top:1px solid var(--border);
}
.demo-specs-list > div:first-child{border-top:0}
.demo-specs-list dt{
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  font-weight:600;color:var(--muted);margin:0;
}
.demo-specs-list dd{
  margin:0;color:var(--fg);font-size:13.5px;text-align:right;
}

/* Build-right badges */
.demo-badges{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.demo-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 12px;
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border);border-radius:8px;
  font-size:13px;color:var(--fg-soft);
}
.demo-badge svg{width:15px;height:15px;color:var(--accent);flex:0 0 15px}

/* ============================================================
   FINAL CTA
   ============================================================ */
.demo-final-cta{
  text-align:center;
  padding:48px 24px;
  border-top:1px solid var(--border);
}
.demo-final-cta h2{margin:0 0 10px}
.demo-final-cta p{color:var(--fg-soft);font-size:15px;max-width:520px;margin:0 auto 22px}
.demo-final-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}

/* Minimal footer variant for Demo template (same as plugin) */
.tgi-template-demo .site-footer .footer-grid,
.tgi-template-demo .footer-bottom-links{display:none}
.tgi-template-demo .site-footer{margin-top:0;background:transparent;border-top:1px solid var(--border)}
.tgi-template-demo .site-footer .container{padding:22px 28px}
.tgi-template-demo .footer-bottom{
  border-top:0;margin-top:0;padding-top:0;
  justify-content:flex-start;color:var(--muted);
}

/* ============================================================
   MEDIA TWEAKS
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  html{scroll-behavior:auto}
}
