/* ============================================================
   OGHAM ALPHABET TRANSLATOR — seowebchecker.com
   Design tokens: standing-stone world. Stemline signature motif.
   ============================================================ */

:root{
  /* Dark theme (default) — weathered stone at dusk */
  --bg:#10140F;
  --bg-soft:#161B14;
  --surface:#1B2118;
  --surface-2:#222A1E;
  --border:#2E3728;
  --border-soft:#242C1F;
  --text:#EAE7DC;
  --text-dim:#A9B09E;
  --text-faint:#76806C;
  --accent:#8FBB6F;        /* moss green */
  --accent-strong:#A8D687;
  --accent-ink:#0E1A08;
  --gold:#C9A35E;          /* lichen gold */
  --gold-soft:#E0C088;
  --danger:#E0876B;
  --shadow:0 10px 40px -10px rgba(0,0,0,0.55);
  --radius:14px;
  --radius-sm:8px;
  --font-display:'Outfit',sans-serif;
  --font-body:'Inter',sans-serif;
}

[data-theme="light"]{
  --bg:#F3F0E6;
  --bg-soft:#EBE7DA;
  --surface:#FFFEFA;
  --surface-2:#F1EDE0;
  --border:#DAD4C0;
  --border-soft:#E4E0D2;
  --text:#1E2218;
  --text-dim:#565F4C;
  --text-faint:#838C76;
  --accent:#4C7A35;
  --accent-strong:#3A5F28;
  --accent-ink:#FFFFFF;
  --gold:#9A7526;
  --gold-soft:#7A5C1A;
  --danger:#B8472F;
  --shadow:0 10px 30px -12px rgba(40,35,20,0.18);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{animation-duration:0.001ms !important;animation-iteration-count:1 !important;transition-duration:0.001ms !important;scroll-behavior:auto !important;}
}

body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  width:100%;
  max-width:100vw;
  transition:background .35s ease,color .35s ease;
}

img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}
ul{list-style:none;}
section{position:relative;}

.container{
  width:100%;
  max-width:1180px;
  margin:0 auto;
  padding-inline:20px;
}

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

/* Skip link */
.skip-link{
  position:absolute;left:-999px;top:0;background:var(--accent);color:var(--accent-ink);
  padding:10px 16px;border-radius:0 0 8px 0;font-weight:600;z-index:999;
}
.skip-link:focus{left:0;}

/* ============ TOP UTILITY BAR ============ */
.topbar{
  background:var(--accent-ink);
  background-color:#0B130A;
  color:#BFCDB2;
  font-size:12.5px;
  padding:6px 0;
  border-bottom:1px solid rgba(255,255,255,0.06);
}
[data-theme="light"] .topbar{background-color:#26331C;color:#D8E0CB;}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:12px;}
.topbar-tag{display:flex;align-items:center;gap:6px;opacity:.9;}
.topbar-links{display:flex;gap:16px;}
.topbar-links a{opacity:.85;transition:opacity .2s;}
.topbar-links a:hover{opacity:1;text-decoration:underline;}
@media (max-width:680px){ .topbar-tag span.long{display:none;} }

/* ============ HEADER / NAV ============ */
.site-header{
  position:sticky;top:0;z-index:200;
  background:color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter:blur(10px) saturate(140%);
  -webkit-backdrop-filter:blur(10px) saturate(140%);
  border-bottom:1px solid var(--border-soft);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 0;gap:16px;
}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:700;font-size:19px;letter-spacing:-0.01em;color:var(--text);flex-shrink:0;}
.brand-mark{width:34px;height:34px;flex-shrink:0;}
.brand small{display:block;font-family:var(--font-body);font-weight:500;font-size:10.5px;color:var(--text-faint);letter-spacing:.04em;text-transform:uppercase;}

.nav-links{display:flex;align-items:center;gap:4px;}
.nav-links > li{position:relative;}
.nav-links > li > a, .nav-links > li > button{
  display:flex;align-items:center;gap:4px;
  padding:9px 13px;border-radius:8px;font-size:14.5px;font-weight:500;color:var(--text-dim);
  background:transparent;border:none;transition:background .18s,color .18s;
  white-space:nowrap;
}
.nav-links > li > a:hover, .nav-links > li > button:hover, .nav-links > li.open > button{
  background:var(--surface-2);color:var(--text);
}
.nav-links .chev{width:9px;height:9px;border-right:1.6px solid currentColor;border-bottom:1.6px solid currentColor;transform:rotate(45deg);margin-top:-3px;transition:transform .2s;}
.nav-links li.open .chev{transform:rotate(225deg);margin-top:3px;}

.dropdown{
  position:absolute;top:calc(100% + 8px);left:0;min-width:260px;
  background:var(--surface);border:1px solid var(--border);border-radius:12px;
  box-shadow:var(--shadow);padding:8px;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .18s,transform .18s,visibility .18s;
  max-height:70vh;overflow-y:auto;
}
.nav-links li.open .dropdown{opacity:1;visibility:visible;transform:translateY(0);}
.dropdown a{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;font-size:14px;color:var(--text-dim);transition:background .15s,color .15s;}
.dropdown a:hover{background:var(--surface-2);color:var(--accent-strong);}
.dropdown a .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;opacity:.6;}

.nav-actions{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.theme-toggle{
  width:44px;height:26px;border-radius:20px;background:var(--surface-2);border:1px solid var(--border);
  position:relative;padding:2px;transition:background .25s;flex-shrink:0;
}
.theme-toggle .knob{
  width:20px;height:20px;border-radius:50%;background:var(--accent);
  display:flex;align-items:center;justify-content:center;color:var(--accent-ink);font-size:11px;
  transform:translateX(0);transition:transform .25s cubic-bezier(.4,0,.2,1);
}
[data-theme="light"] .theme-toggle .knob{transform:translateX(18px);}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-body);font-weight:600;font-size:14.5px;
  padding:10px 20px;border-radius:9px;border:1px solid transparent;
  transition:transform .15s,box-shadow .15s,background .2s,border-color .2s,opacity .2s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px) scale(0.98);}
.btn-primary{background:var(--accent);color:var(--accent-ink);}
.btn-primary:hover{background:var(--accent-strong);box-shadow:0 6px 18px -6px color-mix(in srgb, var(--accent) 60%, transparent);}
.btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none;}
.btn-ghost{background:transparent;border-color:var(--border);color:var(--text);}
.btn-ghost:hover{background:var(--surface-2);}
.btn-gold{background:var(--gold);color:#1B1303;}
.btn-gold:hover{background:var(--gold-soft);}
.btn-sm{padding:7px 13px;font-size:13px;}
.btn[disabled]{cursor:not-allowed;}

.hamburger{display:none;width:40px;height:40px;border-radius:8px;background:var(--surface-2);border:1px solid var(--border);align-items:center;justify-content:center;flex-direction:column;gap:4px;flex-shrink:0;}
.hamburger span{width:18px;height:2px;background:var(--text);border-radius:2px;transition:transform .25s,opacity .25s;}
.hamburger.is-open span:nth-child(1){transform:translateY(6px) rotate(45deg);}
.hamburger.is-open span:nth-child(2){opacity:0;}
.hamburger.is-open span:nth-child(3){transform:translateY(-6px) rotate(-45deg);}

/* Mobile nav drawer */
.mobile-drawer{
  position:fixed;inset:0 0 0 auto;width:min(86vw,360px);background:var(--bg-soft);
  border-left:1px solid var(--border);z-index:300;transform:translateX(100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;padding:18px;
}
.mobile-drawer.is-open{transform:translateX(0);}
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:299;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s;}
.drawer-overlay.is-open{opacity:1;visibility:visible;}
.drawer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;}
.drawer-close{width:36px;height:36px;border-radius:8px;background:var(--surface-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text);font-size:18px;}
.mobile-drawer details{border-bottom:1px solid var(--border-soft);}
.mobile-drawer summary{padding:13px 4px;font-weight:600;font-size:15px;display:flex;justify-content:between;cursor:pointer;list-style:none;color:var(--text);}
.mobile-drawer summary::-webkit-details-marker{display:none;}
.mobile-drawer a{display:block;padding:11px 4px;font-size:14.5px;color:var(--text-dim);}
.mobile-drawer .drawer-sub a{padding-left:16px;font-size:13.5px;}
.mobile-drawer .drawer-actions{margin-top:16px;display:flex;flex-direction:column;gap:10px;}

@media (max-width:980px){
  .nav-links{display:none;}
  .nav-actions .btn-primary.nav-cta{display:none;}
  .hamburger{display:flex;}
}

/* ============ BREADCRUMB ============ */
.breadcrumb-bar{border-bottom:1px solid var(--border-soft);background:var(--bg-soft);}
.breadcrumb{display:flex;align-items:center;gap:7px;padding:11px 0;font-size:13px;color:var(--text-faint);flex-wrap:wrap;}
.breadcrumb a{color:var(--text-dim);transition:color .15s;}
.breadcrumb a:hover{color:var(--accent-strong);}
.breadcrumb .sep{opacity:.5;}
.breadcrumb .current{color:var(--accent-strong);font-weight:500;}

/* ============ HERO ============ */
.hero{padding:64px 0 70px;overflow:hidden;position:relative;}
.hero-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:center;}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;padding:6px 13px;border-radius:30px;
  background:var(--surface-2);border:1px solid var(--border);font-size:12.5px;font-weight:600;
  color:var(--accent-strong);letter-spacing:.03em;text-transform:uppercase;margin-bottom:22px;
}
.hero-eyebrow .pulse{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 var(--accent);animation:pulse 2.2s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in srgb, var(--accent) 55%, transparent);}70%{box-shadow:0 0 0 7px transparent;}100%{box-shadow:0 0 0 0 transparent;}}

.hero h1{
  font-family:var(--font-display);font-weight:700;font-size:clamp(34px,4.6vw,54px);
  line-height:1.07;letter-spacing:-0.02em;margin-bottom:18px;color:var(--text);
}
.hero h1 em{font-style:normal;color:var(--accent-strong);position:relative;}
.hero-sub{font-size:17px;color:var(--text-dim);max-width:520px;margin-bottom:28px;}
.hero-stats{display:flex;gap:28px;margin-bottom:30px;flex-wrap:wrap;}
.hero-stat b{display:block;font-family:var(--font-display);font-size:24px;color:var(--text);font-weight:700;}
.hero-stat span{font-size:12.5px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.03em;}
.hero-cta-row{display:flex;gap:12px;flex-wrap:wrap;}

/* Stemline signature graphic beside hero copy */
.hero-visual{position:relative;display:flex;justify-content:center;align-items:center;min-height:420px;}
.stone-card{
  background:var(--surface);border:1px solid var(--border);border-radius:20px;
  box-shadow:var(--shadow);padding:34px 30px;width:100%;max-width:420px;position:relative;
}
.stemline-demo{display:flex;align-items:center;gap:22px;}
.stemline{position:relative;width:3px;align-self:stretch;background:linear-gradient(180deg,var(--accent) 0%,var(--gold) 100%);border-radius:3px;min-height:300px;flex-shrink:0;}
.stemline .notch{position:absolute;left:0;width:34px;height:0;border-top:3px solid var(--accent-strong);transform-origin:left center;}
.stemline .notch.gold{border-top-color:var(--gold);}
.stemline .notch.right{left:0;}
.stemline .notch.left{left:-34px;}
.word-spell{display:flex;flex-direction:column;gap:14px;}
.word-spell .row{display:flex;align-items:baseline;gap:10px;}
.word-spell .ogham-char{font-size:30px;color:var(--accent-strong);line-height:1;}
.word-spell .latin{font-size:13px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.05em;}
.stone-card-caption{margin-top:20px;padding-top:16px;border-top:1px dashed var(--border);font-size:12.5px;color:var(--text-faint);text-align:center;}

@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-visual{order:-1;min-height:auto;}
  .stone-card{max-width:100%;}
}

/* ============ TRANSLATOR TOOL ============ */
.tool-section{padding:18px 0 70px;}
.tool-panel{
  background:var(--surface);border:1px solid var(--border);border-radius:20px;
  box-shadow:var(--shadow);overflow:hidden;
}
.tool-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--surface-2);padding:6px;gap:4px;flex-wrap:wrap;}
.tool-tab{flex:1;min-width:140px;padding:11px 16px;border-radius:10px;background:transparent;border:none;font-weight:600;font-size:14px;color:var(--text-dim);transition:background .18s,color .18s;}
.tool-tab.active{background:var(--surface);color:var(--accent-strong);box-shadow:0 1px 4px rgba(0,0,0,0.08);}

.tool-body{padding:28px;}
@media (max-width:680px){.tool-body{padding:18px;}}

.tool-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
@media (max-width:860px){.tool-grid{grid-template-columns:1fr;}}

.field-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:9px;}
.field-label span{font-size:13.5px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.02em;}
.char-count{font-size:12px;color:var(--text-faint);}
.char-count.warn{color:var(--gold);}
.char-count.err{color:var(--danger);}

textarea.input-area{
  width:100%;min-height:200px;resize:vertical;
  background:var(--bg-soft);border:1.5px solid var(--border);border-radius:12px;
  padding:16px;font-family:var(--font-body);font-size:15.5px;color:var(--text);
  transition:border-color .18s,box-shadow .18s;line-height:1.65;
}
textarea.input-area:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 18%, transparent);outline:none;}
textarea.input-area.has-error{border-color:var(--danger);}

.output-area{
  width:100%;min-height:200px;background:var(--bg-soft);border:1.5px solid var(--border);
  border-radius:12px;padding:16px;overflow-y:auto;
}
.output-ogham{font-size:26px;line-height:2.1;letter-spacing:1px;color:var(--accent-strong);word-break:break-word;white-space:pre-wrap;}
.output-placeholder{color:var(--text-faint);font-size:14.5px;font-style:normal;}

.error-msg{display:flex;align-items:flex-start;gap:8px;background:color-mix(in srgb, var(--danger) 12%, var(--bg-soft));border:1px solid color-mix(in srgb, var(--danger) 35%, var(--border));color:var(--danger);border-radius:10px;padding:10px 13px;font-size:13.5px;margin-top:10px;}
.error-msg.hidden{display:none;}
.error-msg svg{flex-shrink:0;margin-top:1px;}

.tool-actions{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:22px;flex-wrap:wrap;}
.tool-options{display:flex;gap:18px;flex-wrap:wrap;align-items:center;}
.option-toggle{display:flex;align-items:center;gap:7px;font-size:13.5px;color:var(--text-dim);cursor:pointer;}
.option-toggle input{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;}

.btn-row{display:flex;gap:10px;flex-wrap:wrap;}

.output-tools{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px;}

.live-status{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--text-faint);margin-top:10px;}
.live-status .dot-live{width:6px;height:6px;border-radius:50%;background:var(--accent);}

/* Result panel that gets scrolled to */
.result-panel{margin-top:26px;padding-top:24px;border-top:1px dashed var(--border);}
.result-panel.hidden{display:none;}
.result-title{font-family:var(--font-display);font-size:18px;font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:8px;color:var(--text);}

/* Sample words chips */
.sample-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px;}
.chip{padding:6px 13px;border-radius:20px;background:var(--surface-2);border:1px solid var(--border);font-size:13px;color:var(--text-dim);transition:background .15s,color .15s,border-color .15s;}
.chip:hover{background:var(--accent);color:var(--accent-ink);border-color:var(--accent);}

/* Alphabet reference table */
.alphabet-ref{margin-top:18px;}
.aletheid-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(76px,1fr));gap:8px;margin-top:12px;}
.alet-cell{background:var(--bg-soft);border:1px solid var(--border);border-radius:10px;padding:10px 6px;text-align:center;transition:border-color .15s,transform .15s;}
.alet-cell:hover{border-color:var(--accent);transform:translateY(-2px);}
.alet-cell .glyph{font-size:24px;color:var(--accent-strong);display:block;}
.alet-cell .letter{font-size:11.5px;color:var(--text-faint);text-transform:uppercase;margin-top:4px;display:block;}
.aletheid-toggle{margin-top:18px;}

/* ============ FEATURES ============ */
.section-head{text-align:center;max-width:680px;margin:0 auto 46px;}
.section-eyebrow{font-size:13px;font-weight:700;color:var(--accent-strong);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;}
.section-head h2{font-family:var(--font-display);font-size:clamp(26px,3.4vw,38px);font-weight:700;letter-spacing:-0.015em;margin-bottom:12px;}
.section-head p{color:var(--text-dim);font-size:16px;}

.features-section{padding:80px 0;}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
@media (max-width:900px){.features-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:600px){.features-grid{grid-template-columns:1fr;}}
.feature-card{
  background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:26px;
  transition:transform .2s,border-color .2s,box-shadow .2s;
}
.feature-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:var(--shadow);}
.feature-icon{width:44px;height:44px;border-radius:11px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--accent-strong);}
.feature-card h3{font-family:var(--font-display);font-size:17.5px;font-weight:600;margin-bottom:8px;}
.feature-card p{font-size:14.5px;color:var(--text-dim);}

/* ============ HOW IT WORKS ============ */
.how-section{padding:80px 0;background:var(--bg-soft);}
.how-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative;}
@media (max-width:900px){.how-steps{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.how-steps{grid-template-columns:1fr;}}
.how-step{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px;position:relative;}
.how-num{font-family:var(--font-display);font-size:13px;font-weight:700;color:var(--accent-ink);background:var(--accent);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:14px;}
.how-step h3{font-family:var(--font-display);font-size:16.5px;font-weight:600;margin-bottom:7px;}
.how-step p{font-size:14px;color:var(--text-dim);}

/* ============ ARTICLE / ABOUT TEXT ============ */
.article-section{padding:70px 0;}
.article-section .container{max-width:780px;}
.article-section h2{font-family:var(--font-display);font-size:clamp(24px,3vw,32px);font-weight:700;margin-bottom:18px;letter-spacing:-0.01em;}
.article-section p{color:var(--text-dim);font-size:16px;margin-bottom:16px;}
.article-section strong{color:var(--text);}

/* ============ FAQ ============ */
.faq-section{padding:80px 0;}
.faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:12px;}
.faq-item{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:14px;padding:19px 22px;background:transparent;border:none;text-align:left;font-family:var(--font-body);font-size:15.5px;font-weight:600;color:var(--text);}
.faq-q .plus{width:20px;height:20px;flex-shrink:0;position:relative;}
.faq-q .plus::before,.faq-q .plus::after{content:'';position:absolute;background:var(--accent-strong);border-radius:2px;transition:transform .25s;}
.faq-q .plus::before{width:14px;height:2px;top:9px;left:3px;}
.faq-q .plus::after{width:2px;height:14px;top:3px;left:9px;}
.faq-item.open .plus::after{transform:rotate(90deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.faq-a-inner{padding:0 22px 20px;font-size:14.5px;color:var(--text-dim);}

/* ============ CTA ============ */
.cta-section{padding:70px 0;}
.cta-box{
  background:linear-gradient(135deg,var(--surface) 0%,var(--surface-2) 100%);
  border:1px solid var(--border);border-radius:22px;padding:50px 40px;text-align:center;
  position:relative;overflow:hidden;
}
.cta-box::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 20% 20%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 50%);
  pointer-events:none;
}
.cta-box h2{font-family:var(--font-display);font-size:clamp(24px,3.2vw,32px);font-weight:700;margin-bottom:12px;position:relative;}
.cta-box p{color:var(--text-dim);font-size:16px;max-width:560px;margin:0 auto 26px;position:relative;}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative;}

/* ============ FOOTER ============ */
.site-footer{background:var(--bg-soft);border-top:1px solid var(--border-soft);padding:60px 0 0;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:28px;padding-bottom:40px;}
@media (max-width:980px){.footer-top{grid-template-columns:1fr 1fr 1fr;}}
@media (max-width:680px){.footer-top{grid-template-columns:1fr 1fr;}}
@media (max-width:460px){.footer-top{grid-template-columns:1fr;}}
.footer-brand p{font-size:13.5px;color:var(--text-faint);margin-top:12px;max-width:280px;}
.footer-col h4{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);margin-bottom:14px;}
.footer-col ul{display:flex;flex-direction:column;gap:9px;}
.footer-col a{font-size:13.5px;color:var(--text-faint);transition:color .15s;}
.footer-col a:hover{color:var(--accent-strong);}
.footer-social{display:flex;gap:10px;margin-top:16px;}
.footer-social a{width:34px;height:34px;border-radius:9px;background:var(--surface-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-dim);transition:color .15s,border-color .15s;}
.footer-social a:hover{color:var(--accent-strong);border-color:var(--accent);}

.footer-disclaimer{border-top:1px solid var(--border-soft);padding:22px 0;font-size:12px;color:var(--text-faint);line-height:1.7;}
.footer-bottom{border-top:1px solid var(--border-soft);padding:18px 0;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;font-size:13px;color:var(--text-faint);}
.footer-bottom-links{display:flex;gap:18px;flex-wrap:wrap;}
.footer-bottom-links a{transition:color .15s;}
.footer-bottom-links a:hover{color:var(--accent-strong);}

/* ============ COOKIE BANNER ============ */
.cookie-banner{
  position:fixed;left:16px;right:16px;bottom:16px;max-width:560px;margin:0 auto;
  background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);
  padding:18px 20px;z-index:400;display:flex;gap:14px;align-items:flex-start;
  transform:translateY(120%);opacity:0;transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .4s;
}
.cookie-banner.is-visible{transform:translateY(0);opacity:1;}
.cookie-banner p{font-size:13px;color:var(--text-dim);flex:1;}
.cookie-banner a{color:var(--accent-strong);text-decoration:underline;}
.cookie-actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0;}

/* ============ SCROLL TOP ============ */
.scroll-top{
  position:fixed;bottom:20px;right:20px;width:44px;height:44px;border-radius:50%;
  background:var(--accent);color:var(--accent-ink);border:none;display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .25s,visibility .25s,transform .25s;z-index:150;
}
.scroll-top.is-visible{opacity:1;visibility:visible;transform:translateY(0);}

/* ============ TOAST ============ */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--surface);border:1px solid var(--border);color:var(--text);
  padding:11px 20px;border-radius:10px;box-shadow:var(--shadow);font-size:13.5px;font-weight:500;
  z-index:500;opacity:0;visibility:hidden;transition:opacity .25s,transform .25s,visibility .25s;
  display:flex;align-items:center;gap:8px;
}
.toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}

/* ============ SPINNER ============ */
.spin{
  display:inline-block;width:13px;height:13px;border-radius:50%;
  border:2px solid color-mix(in srgb, var(--accent-ink) 35%, transparent);
  border-top-color:var(--accent-ink);
  animation:spin .7s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* ============ VISUALLY HIDDEN ============ */
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);}

/* ============ UTILITY ============ */
.fade-up{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease;}
.fade-up.in-view{opacity:1;transform:translateY(0);}
