/* Touge Atlas — Shared site styles
   Extracted from index.html design system.
   All pages load this + page-specific <style> if needed. */

/* === Tokens === */
:root {
  --red:          #DC2626;
  --red-hot:      #B91C1C;
  --red-glow:     rgba(220,38,38,0.35);
  --bg:           #0a0a0a;
  --bg-1:         #131211;
  --bg-2:         #1a1a1a;
  --bg-3:         #1F1D24;
  --fg-1:         #E6E1E5;
  --fg-2:         #CAC4D0;
  --fg-3:         #938F99;
  --border:       rgba(255,255,255,0.08);
  --border-hi:    rgba(255,255,255,0.13);
  --glass-bg:     rgba(15,14,13,0.80);
  --ease-spring:  cubic-bezier(0.34,1.56,0.64,1);
  --ease-smooth:  cubic-bezier(0.4,0,0.2,1);
}

/* === Reset === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--fg-1);font-family:'Inter',sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,video{display:block;max-width:100%}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}

/* === Nav === */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 clamp(24px,7vw,96px);backdrop-filter:blur(16px) saturate(1.6);-webkit-backdrop-filter:blur(16px) saturate(1.6);background:rgba(10,10,10,0.75);border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:56px;max-width:1400px;margin:0 auto}
.nav-logo{font-family:'Inter',sans-serif;font-weight:800;font-size:15px;letter-spacing:0.06em;display:flex;gap:6px;text-decoration:none}
.nav-logo .w{color:var(--fg-1)}
.nav-logo .r{color:var(--red);text-shadow:0 0 8px rgba(220,38,38,0.4)}
.nav-links{display:flex;align-items:center;gap:24px}
.nav-links a{font-size:13px;font-weight:500;color:var(--fg-3);letter-spacing:0.01em;transition:color 0.15s}
.nav-links a:hover,.nav-links a.active{color:var(--fg-1)}
.nav-links .lang{display:flex;gap:8px}
.nav-links .lang a.active{color:var(--fg-1)}
.nav-cta{display:inline-flex;align-items:center;padding:7px 16px;border-radius:8px;background:var(--red);color:#fff;font-size:13px;font-weight:600;box-shadow:0 0 14px rgba(220,38,38,0.35);transition:all 0.2s var(--ease-spring)}
.nav-cta:hover{background:var(--red-hot);box-shadow:0 0 20px rgba(220,38,38,0.5);transform:translateY(-1px)}

/* === Buttons === */
.btn{display:inline-flex;align-items:center;gap:9px;padding:13px 22px;border-radius:10px;font-size:14px;font-weight:600;transition:all 0.2s var(--ease-spring);white-space:nowrap;cursor:pointer;border:none}
.btn svg{width:18px;height:18px;flex-shrink:0}
.btn-red{background:var(--red);color:#fff;box-shadow:0 0 18px rgba(220,38,38,0.4),0 4px 12px rgba(220,38,38,0.25)}
.btn-red:hover{background:var(--red-hot);box-shadow:0 0 28px rgba(220,38,38,0.55),0 8px 20px rgba(220,38,38,0.35);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,0.06);color:var(--fg-1);border:1px solid var(--border-hi)}
.btn-ghost:hover{background:rgba(255,255,255,0.10);transform:translateY(-2px)}

/* === Page layout === */
.page-container{max-width:1400px;margin:0 auto;padding:calc(56px + clamp(40px,6vw,80px)) clamp(24px,7vw,96px) clamp(40px,6vw,80px)}
.page-title{font-family:'Outfit',sans-serif;font-weight:800;font-size:clamp(32px,5vw,56px);line-height:1.05;letter-spacing:-0.02em;color:var(--fg-1);margin-bottom:12px}
.page-subtitle{font-size:clamp(14px,1.5vw,17px);color:var(--fg-3);line-height:1.7;max-width:580px;margin-bottom:clamp(28px,3vw,44px)}

/* === Content (for legal/text pages) === */
.content-body h2{font-family:'Outfit',sans-serif;font-weight:700;font-size:clamp(20px,2.5vw,28px);color:var(--fg-1);margin:clamp(32px,4vw,48px) 0 16px;letter-spacing:-0.01em}
.content-body h3{font-weight:600;font-size:clamp(16px,1.8vw,20px);color:var(--fg-1);margin:24px 0 12px}
.content-body p{font-size:clamp(14px,1.4vw,16px);color:var(--fg-2);line-height:1.75;margin-bottom:16px}
.content-body ul,.content-body ol{margin:12px 0 20px 20px;display:flex;flex-direction:column;gap:8px}
.content-body li{font-size:clamp(14px,1.4vw,16px);color:var(--fg-2);line-height:1.65}
.content-body a{color:var(--red);transition:color 0.15s}
.content-body a:hover{color:var(--fg-1)}
.content-body strong{color:var(--fg-1)}
.content-body table{width:100%;border-collapse:collapse;margin:16px 0 24px}
.content-body th,.content-body td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border);font-size:14px;color:var(--fg-2)}
.content-body th{color:var(--fg-1);font-weight:600;font-size:13px;letter-spacing:0.02em}

/* === Forms === */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}
.form-row{display:flex;flex-direction:column;gap:6px}
.form-row.full{grid-column:1 / -1}
.form-row label{font-size:13px;font-weight:600;color:var(--fg-1);letter-spacing:0.01em}
.form-row input,.form-row select,.form-row textarea{background:var(--bg-1);border:1px solid var(--border-hi);border-radius:8px;padding:12px 14px;font-size:14px;color:var(--fg-1);font-family:inherit;transition:border-color 0.15s}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--red)}
.form-row input::placeholder,.form-row textarea::placeholder{color:var(--fg-3)}
.form-row textarea{min-height:100px;resize:vertical}
.form-row select{appearance:none;cursor:pointer}
.form-row .hint{font-size:12px;color:var(--fg-3)}
.form-row .field-error{font-size:12px;color:#EF4444}
.label-optional{font-weight:400;color:var(--fg-3)}
.checkbox-row{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--fg-2);line-height:1.55;cursor:pointer;margin-bottom:12px}
.checkbox-row input{margin-top:3px;accent-color:var(--red);flex-shrink:0}
.checkbox-row a{color:var(--red)}
.checkbox-row a:hover{color:var(--fg-1)}
.form-actions{display:flex;align-items:center;gap:16px;margin-top:20px}
.form-status{font-size:13px;font-weight:500}
.form-status.success{color:#22C55E}
.form-status.error{color:#EF4444}
.hp-field{position:absolute;left:-9999px;height:0;width:0;overflow:hidden;opacity:0}
.support-note{font-size:13px;color:var(--fg-3);margin-top:16px}
.support-note a{color:var(--red)}

/* === Tab shell === */
.tab-list{display:flex;gap:4px;margin-bottom:24px}
.tab-button{padding:10px 20px;border-radius:8px;font-size:13px;font-weight:600;color:var(--fg-3);background:transparent;border:1px solid transparent;transition:all 0.15s}
.tab-button:hover{color:var(--fg-1)}
.tab-button.active{color:var(--fg-1);background:var(--bg-1);border-color:var(--border-hi)}
.tab-panel{background:var(--bg-1);border:1px solid var(--border-hi);border-radius:16px;padding:clamp(24px,3vw,40px)}
.tab-panel[hidden]{display:none}
.tab-panel .badge{display:inline-block;font-size:11px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--red);margin-bottom:12px}
.tab-panel h2{font-family:'Outfit',sans-serif;font-weight:700;font-size:clamp(20px,2.5vw,26px);color:var(--fg-1);margin-bottom:8px}
.tab-panel > p{font-size:14px;color:var(--fg-3);margin-bottom:24px;line-height:1.6}

/* === Footer CTA === */
.footer-cta{background:var(--bg-1);border-top:1px solid var(--border);padding:clamp(64px,8vw,100px) clamp(24px,7vw,96px);text-align:center;position:relative;overflow:hidden}
.footer-cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 100%,rgba(220,38,38,0.12),transparent 65%);pointer-events:none}
.footer-cta-lockup{font-family:'Inter',sans-serif;font-weight:800;font-size:clamp(40px,7vw,90px);letter-spacing:-0.025em;line-height:0.95;margin-bottom:clamp(20px,2.5vw,32px);position:relative}
.footer-cta-lockup .w{color:var(--fg-1);text-shadow:0 0 6px rgba(255,255,255,0.2)}
.footer-cta-lockup .r{color:var(--red);text-shadow:0 0 10px rgba(220,38,38,0.4),0 0 30px rgba(220,38,38,0.2)}
.footer-cta-sub{font-size:clamp(14px,1.5vw,17px);color:var(--fg-3);margin-bottom:clamp(28px,3vw,44px);position:relative}
.footer-cta-btns{display:flex;justify-content:center;flex-wrap:wrap;gap:12px;position:relative}

/* === Footer === */
footer{background:var(--bg);border-top:1px solid var(--border);padding:clamp(28px,3vw,40px) clamp(24px,7vw,96px);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:20px}
.footer-copy{font-size:12px;color:var(--fg-3)}
.footer-copy span{color:var(--red)}
.footer-links{display:flex;flex-wrap:wrap;gap:20px;align-items:center}
.footer-links a{font-size:12px;color:var(--fg-3);transition:color 0.15s}
.footer-links a:hover{color:var(--fg-1)}
.footer-social{display:flex;gap:14px;margin-left:8px}
.footer-social a{color:var(--fg-3);transition:color 0.15s}
.footer-social a:hover{color:var(--fg-1)}
.footer-social svg{width:18px;height:18px;fill:currentColor}

/* === Skip link === */
.skip-link{position:absolute;top:-100px;left:16px;background:var(--red);color:#fff;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:600;z-index:1000;transition:top 0.2s}
.skip-link:focus{top:8px}

/* === Turnstile === */
.cf-turnstile{margin:16px 0}

/* === Responsive === */
@media(max-width:768px){
  .nav-links .nav-cta{display:none}
  .form-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .nav-links a:not(.lang a):not(.nav-cta){display:none}
}
