/* ========================================================================
   TMD v2 — Shared Design System
   Tokens · Layout · Components · Utilities
   Built to: TMD_Master_Build_Prompt_v2.md
   ======================================================================== */

/* ===== TOKENS ===== */
:root{
  /* Brand */
  --navy:#0a1628;
  --navy-deep:#06101e;
  --coastal:#1a3a5c;
  --coastal-light:#2c5582;
  --sand:#c8a96e;
  --sand-deep:#a88950;
  --sand-light:#dcc395;
  --white:#f8f7f4;
  --slate:#7a9bb5;
  --ink:#0d1a2e;
  --ink-soft:#33475e;
  --ink-mute:#6b7d96;
  --line:#e6e3dd;
  --line-dark:#d4cfc4;
  --bg-warm:#fbf9f4;
  --success:#16a34a;
  --warn:#d97706;
  --danger:#dc2626;

  /* Type */
  --f-display:'Fraunces',Georgia,serif;
  --f-body:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;

  /* Shadow */
  --shadow-sm:0 1px 2px rgba(10,22,40,.06),0 1px 3px rgba(10,22,40,.04);
  --shadow-md:0 6px 24px rgba(10,22,40,.08),0 2px 8px rgba(10,22,40,.05);
  --shadow-lg:0 24px 60px rgba(10,22,40,.14),0 8px 24px rgba(10,22,40,.06);

  /* Radius */
  --r-sm:6px; --r-md:12px; --r-lg:20px; --r-xl:28px;

  /* Motion */
  --ease:cubic-bezier(.2,.7,.2,1);
  --t-fast:.18s;
  --t-med:.28s;
  --t-slow:.45s;
}

/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-body);
  color:var(--ink);background:var(--white);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
:focus-visible{outline:3px solid var(--sand);outline-offset:3px;border-radius:4px}
.skip{position:absolute;left:-9999px;top:0;background:var(--navy);color:var(--white);padding:.75rem 1rem;z-index:100}
.skip:focus{left:0}

/* View transitions API (new-age tech) */
@view-transition{navigation:auto}

/* ===== TYPE ===== */
h1,h2,h3,h4,h5{font-family:var(--f-display);font-weight:600;color:var(--navy);letter-spacing:-.01em;line-height:1.15}
h1{font-size:clamp(2.25rem,5.4vw,4rem);font-weight:600;letter-spacing:-.025em}
h2{font-size:clamp(1.75rem,3.2vw,2.5rem)}
h3{font-size:clamp(1.25rem,2vw,1.5rem)}
h4{font-size:1.0625rem;font-family:var(--f-body);font-weight:700;letter-spacing:.02em}
p{font-size:1.0625rem;color:var(--ink-soft)}
.lede{font-size:clamp(1.125rem,1.5vw,1.3125rem);color:var(--ink-soft);line-height:1.55;font-weight:400}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .8rem;border-radius:999px;background:rgba(200,169,110,.15);color:var(--sand-deep);font-size:.8125rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}
.eyebrow.dark{background:rgba(200,169,110,.18);color:var(--sand)}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:currentColor;animation:pulse 2.5s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.sec-eyebrow{font-size:.8125rem;color:var(--coastal);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:.75rem;display:block}

/* ===== LAYOUT ===== */
.wrap{max-width:1200px;margin:0 auto;padding:0 1.25rem}
.wrap-narrow{max-width:820px;margin:0 auto;padding:0 1.25rem}
@media(min-width:768px){.wrap,.wrap-narrow{padding:0 2rem}}
section{padding:5rem 0}
.sec-head{max-width:62ch;margin-bottom:3rem}
.sec-head h2{margin-bottom:.75rem}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.95rem 1.5rem;border-radius:999px;font-weight:600;font-size:1rem;letter-spacing:.01em;transition:transform var(--t-med) var(--ease),box-shadow var(--t-med) var(--ease),background var(--t-med) var(--ease),color var(--t-med) var(--ease);min-height:48px;text-align:center;border:none;cursor:pointer}
.btn-primary{background:var(--sand);color:var(--navy);box-shadow:var(--shadow-md)}
.btn-primary:hover{background:var(--sand-deep);color:var(--white);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-ghost{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,.35)}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:var(--white)}
.btn-ghost.dark{color:var(--navy);border-color:var(--line-dark)}
.btn-ghost.dark:hover{background:var(--navy);color:var(--white);border-color:var(--navy)}
.btn-dark{background:var(--navy);color:var(--white)}
.btn-dark:hover{background:var(--coastal)}
.btn-sm{padding:.55rem 1rem;font-size:.875rem;min-height:38px}

/* ===== NAV ===== */
.nav{position:sticky;top:0;z-index:50;background:rgba(248,247,244,.85);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav-row{display:flex;align-items:center;justify-content:space-between;padding:.875rem 0;gap:1rem}
.brand{display:flex;align-items:center;gap:.625rem;font-family:var(--f-display);font-weight:600;color:var(--navy);font-size:1.1875rem}
.brand-mark{width:34px;height:34px;border-radius:50%;background:var(--navy);color:var(--sand);display:grid;place-items:center;font-family:var(--f-display);font-size:1rem;font-weight:600}
.nav-links{display:none;gap:1.75rem;font-size:.9375rem;color:var(--coastal);font-weight:500}
.nav-links a{transition:color var(--t-fast) var(--ease)}
.nav-links a:hover{color:var(--navy)}
.nav-cta{display:flex;gap:.5rem}
.nav-cta .btn{padding:.6rem 1rem;font-size:.875rem;min-height:40px}
@media(min-width:1024px){.nav-links{display:flex}}

/* ===== HERO ===== */
.hero{position:relative;background:linear-gradient(180deg,var(--navy) 0%,#13294a 60%,var(--coastal) 100%);color:var(--white);overflow:hidden;padding:5rem 0 5.5rem}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 40% at 80% 0%,rgba(200,169,110,.15),transparent 60%),radial-gradient(50% 50% at 0% 100%,rgba(122,155,181,.18),transparent 60%);pointer-events:none}
.hero h1{color:var(--white)}
.hero h1 .accent{color:var(--sand);font-style:italic;font-weight:500}
.hero .lede{color:rgba(248,247,244,.82);max-width:54ch;margin-top:1.25rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:1.75rem;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.12)}
.trust-item{display:flex;flex-direction:column;gap:.15rem}
.trust-num{font-family:var(--f-display);font-size:1.5rem;color:var(--sand);font-weight:600}
.trust-lbl{font-size:.8125rem;color:rgba(248,247,244,.7);text-transform:uppercase;letter-spacing:.06em}

/* ===== CARDS ===== */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.75rem;transition:transform var(--t-med) var(--ease),box-shadow var(--t-med) var(--ease),border-color var(--t-med) var(--ease)}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--sand)}
.card-tag{font-size:.6875rem;font-weight:700;color:var(--sand-deep);text-transform:uppercase;letter-spacing:.08em;display:inline-block;margin-bottom:.5rem}
.card h3{font-size:1.25rem;margin-bottom:.5rem}
.card p{font-size:.9375rem;color:var(--ink-soft)}
.card .more{font-weight:600;color:var(--coastal);font-size:.9375rem;display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem}
.card .more::after{content:"→";transition:transform var(--t-fast) var(--ease)}
.card:hover .more::after{transform:translateX(4px)}

/* Grid utilities */
.grid{display:grid;gap:1.25rem}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
.grid-4{grid-template-columns:1fr 1fr}
@media(min-width:768px){.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}}

/* ===== FAQ DETAILS ===== */
details.q{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:1.25rem 1.5rem;transition:box-shadow var(--t-fast) var(--ease)}
details.q[open]{box-shadow:var(--shadow-sm);border-color:var(--sand)}
details.q summary{font-weight:600;color:var(--navy);cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:1rem}
details.q summary::-webkit-details-marker{display:none}
details.q summary::after{content:"+";font-size:1.5rem;color:var(--sand-deep);transition:transform var(--t-fast) var(--ease);line-height:1}
details.q[open] summary::after{transform:rotate(45deg)}
details.q p{margin-top:.75rem;font-size:.9375rem;color:var(--ink-soft)}

/* ===== FOOTER ===== */
footer{background:var(--navy);color:rgba(248,247,244,.7);padding:4rem 0 2rem;margin-top:0}
.foot-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;margin-bottom:2.5rem}
@media(min-width:768px){.foot-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}}
footer h4{color:var(--white);font-family:var(--f-body);font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem}
footer ul{list-style:none;display:flex;flex-direction:column;gap:.6rem;font-size:.9375rem}
footer a{transition:color var(--t-fast) var(--ease)}
footer a:hover{color:var(--sand)}
.foot-brand p{color:rgba(248,247,244,.65);font-size:.9375rem;max-width:38ch}
.compliance{padding-top:1.75rem;border-top:1px solid rgba(255,255,255,.1);font-size:.75rem;color:rgba(248,247,244,.55);line-height:1.7}
.compliance strong{color:rgba(248,247,244,.85)}
.compliance p+p{margin-top:.5rem}

/* ===== STICKY CTA + LAUNCHER + COOKIES ===== */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:40;background:rgba(10,22,40,.96);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:.6rem .75rem calc(.6rem + env(safe-area-inset-bottom));display:flex;gap:.5rem;border-top:1px solid rgba(255,255,255,.1)}
.sticky-cta .btn{flex:1;padding:.75rem .5rem;font-size:.875rem;min-height:44px}
@media(min-width:1024px){.sticky-cta{display:none}}

.marina-launcher{position:fixed;right:1rem;bottom:1rem;z-index:45;background:var(--sand);color:var(--navy);padding:.85rem 1.25rem;border-radius:999px;font-weight:600;box-shadow:var(--shadow-lg);display:none;align-items:center;gap:.5rem;font-size:.9375rem;border:none;cursor:pointer}
.marina-launcher::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--success);box-shadow:0 0 0 3px rgba(22,163,74,.25)}
.marina-launcher:hover{transform:translateY(-2px);background:var(--sand-deep);color:var(--white)}
@media(min-width:1024px){.marina-launcher{display:inline-flex}}

.cookies{position:fixed;left:1rem;right:1rem;bottom:5rem;z-index:60;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:1.25rem;font-size:.875rem;color:var(--ink-soft);display:none}
@media(min-width:768px){.cookies{left:auto;right:1.5rem;bottom:1.5rem;max-width:380px}}
.cookies p{font-size:.875rem;margin-bottom:.75rem}
.cookies .row{display:flex;gap:.5rem;flex-wrap:wrap}
.cookies .btn{padding:.55rem 1rem;font-size:.8125rem;min-height:36px}

/* ===== UTILITIES ===== */
.center{text-align:center}
.mt-0{margin-top:0}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}
.flex{display:flex}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}
.wrap-cta{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}
.muted{color:var(--ink-mute);font-size:.875rem}
.disclaimer{font-size:.75rem;color:var(--ink-mute);line-height:1.5}

/* ===== BREADCRUMBS ===== */
.bcrumb{font-size:.8125rem;color:var(--ink-mute);padding:1rem 0;display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}
.bcrumb a{color:var(--coastal);transition:color var(--t-fast) var(--ease)}
.bcrumb a:hover{color:var(--navy)}
.bcrumb span[aria-current]{color:var(--ink)}
.bcrumb .sep{color:var(--ink-mute)}

/* ===== REDUCED MOTION ===== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
}

/* ===== PRINT (clean printables for PDFs) ===== */
@media print{
  .nav,.sticky-cta,.marina-launcher,.cookies,footer{display:none !important}
  body{background:#fff;color:#000}
  a{color:#000;text-decoration:underline}
}
