/* ============================================================
   TLALOC SYSTEMS — vivid brand styling (matches deck cover)
   Deep #0B3C6B · Blue #1E8FC4 · Aqua #34D3D8 · Mist #7FE3DE · Sun #F5A623
   Fonts: Sora (display) + Hanken Grotesk (body)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');

:root{
  --deep:#0B3C6B; --deep2:#08305A; --deep3:#06294B; --blue:#1E8FC4; --aqua:#34D3D8;
  --mist:#7FE3DE; --sun:#F5A623; --sun2:#FFC15E;
  --muted:#9cc0de; --line:rgba(255,255,255,.14); --line2:rgba(52,211,216,.34);
  --grad-aqua:linear-gradient(120deg,#34D3D8 0%,#1E8FC4 100%);
  --grad-aqua-soft:linear-gradient(150deg,rgba(52,211,216,.20),rgba(30,143,196,.07));
  --grad-gold:linear-gradient(120deg,#FFC15E,#F5A623);
  --display:'Sora',sans-serif; --body:'Hanken Grotesk',sans-serif;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);line-height:1.65;-webkit-font-smoothing:antialiased;color:#d4e8f8;
  background:
    radial-gradient(1200px 760px at 82% -8%,rgba(52,211,216,.30),transparent 55%),
    radial-gradient(1000px 720px at -8% 8%,rgba(30,143,196,.26),transparent 55%),
    radial-gradient(1100px 800px at 50% 118%,rgba(52,211,216,.18),transparent 55%),
    linear-gradient(160deg,#0E4B86 0%,var(--deep) 38%,var(--deep2) 72%,var(--deep3) 100%);
}
a{color:inherit;text-decoration:none}
img,svg{display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(8,40,75,.72);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:12px}
.brand .mark{width:40px;height:40px;flex:0 0 auto;filter:drop-shadow(0 4px 14px rgba(52,211,216,.4))}
.brand .wordmark{font-family:var(--display);font-weight:700;letter-spacing:.06em;color:#fff;font-size:18px}
.brand .wordmark span{display:block;font-family:var(--body);font-weight:500;letter-spacing:.26em;font-size:9px;color:var(--aqua);margin-top:2px}
.links{display:flex;gap:30px;align-items:center}
.links a{color:#d4e8f8;font-weight:500;font-size:15px;position:relative;padding:6px 0;transition:color .2s}
.links a:hover{color:#fff}
.links a.active{color:#fff}
.links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--grad-gold);border-radius:2px}
.nav-cta{background:var(--grad-aqua);color:#06304a !important;padding:10px 19px;border-radius:9px;font-weight:700;font-size:14px;box-shadow:0 6px 18px -6px rgba(52,211,216,.7);transition:transform .15s,box-shadow .2s}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 10px 24px -6px rgba(52,211,216,.9)}
.menu-btn{display:none;background:none;border:0;color:#fff;font-size:26px;cursor:pointer}

/* ---------- shared accents ---------- */
.eyebrow{font-family:var(--body);font-weight:700;letter-spacing:.34em;font-size:13px;color:var(--aqua);text-transform:uppercase;margin-bottom:24px;display:inline-block}
.label-gold{font-family:var(--body);font-weight:700;letter-spacing:.28em;font-size:12.5px;text-transform:uppercase;color:var(--sun);margin-bottom:18px;display:inline-block}
.divider,.gold-bar{width:96px;height:5px;background:var(--grad-gold);border-radius:4px;box-shadow:0 4px 14px -4px rgba(245,166,35,.6)}
.divider{margin:32px 0 26px}.gold-bar{margin:22px 0 0}.gold-bar.center{margin:24px auto 0}
/* gradient accent words in headlines */
.a{background:linear-gradient(120deg,#5BE6E6,#34D3D8 55%,#36B6E8);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- hero ---------- */
.hero{position:relative;color:#fff;overflow:hidden;min-height:calc(100vh - 72px);display:flex;align-items:center}
.hero::after{content:"";position:absolute;right:-160px;top:8%;width:620px;height:620px;border-radius:50%;
  background:radial-gradient(circle at 38% 38%,rgba(52,211,216,.55),rgba(30,143,196,.22) 45%,transparent 70%);
  filter:blur(8px);pointer-events:none}
.hero .glow{position:absolute;inset:0;background:radial-gradient(820px 520px at 70% 26%,rgba(52,211,216,.22),transparent 62%);pointer-events:none}
.hero .waves,.phead .waves{position:absolute;left:0;right:0;bottom:0;width:100%;height:200px;pointer-events:none}
.hero .wrap{position:relative;z-index:2;padding-top:60px;padding-bottom:120px}
.hero h1{font-family:var(--display);font-weight:800;font-size:clamp(35px,5.3vw,64px);line-height:1.07;letter-spacing:-.018em;max-width:16ch;color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hero .sub{font-size:clamp(17px,1.7vw,21px);color:var(--mist);max-width:50ch;line-height:1.6}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:38px}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:15px;padding:15px 28px;border-radius:11px;transition:transform .15s,box-shadow .25s,background .2s}
.btn-primary{background:var(--grad-aqua);color:#06304a;box-shadow:0 10px 26px -8px rgba(52,211,216,.75)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 34px -8px rgba(52,211,216,.95)}
.btn-ghost{border:1.5px solid rgba(127,227,222,.55);color:var(--mist)}
.btn-ghost:hover{border-color:var(--aqua);color:#fff;background:rgba(52,211,216,.12);transform:translateY(-2px)}

/* reveal */
.reveal{opacity:0;transform:translateY(18px);animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards}
.d1{animation-delay:.05s}.d2{animation-delay:.18s}.d3{animation-delay:.32s}.d4{animation-delay:.46s}.d5{animation-delay:.6s}
@keyframes rise{to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.reveal{animation:none;opacity:1;transform:none}}

/* ---------- stats strip (vivid gradient band) ---------- */
.stats{background:var(--grad-aqua);position:relative;overflow:hidden}
.stats::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 12% 0%,rgba(255,255,255,.22),transparent 60%)}
.stats .grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat{padding:42px 22px;text-align:center;border-right:1px solid rgba(255,255,255,.28)}
.stat:last-child{border-right:0}
.stat .n{font-family:var(--display);font-weight:800;font-size:clamp(27px,3vw,40px);color:#fff;letter-spacing:-.02em;text-shadow:0 3px 16px rgba(6,40,74,.35)}
.stat .l{font-size:13.5px;font-weight:600;color:#06375f;margin-top:8px;letter-spacing:.02em}

/* ---------- sections ---------- */
.section{padding:96px 0;position:relative}
.section.band{background:linear-gradient(180deg,rgba(52,211,216,.07),rgba(30,143,196,.05));border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.kicker{font-family:var(--body);font-weight:700;letter-spacing:.3em;font-size:12.5px;text-transform:uppercase;color:var(--aqua);margin-bottom:18px;display:inline-block}
.section h2{font-family:var(--display);font-weight:800;font-size:clamp(28px,3.5vw,42px);color:#fff;letter-spacing:-.025em;line-height:1.12;max-width:20ch}
.section h2.center{margin:0 auto;text-align:center}
.section .lead{font-size:18px;color:#c2dcf0;max-width:60ch;margin-top:18px}

/* ---------- model cards ---------- */
.cards{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:50px}
.card{background:var(--grad-aqua-soft);border:1px solid var(--line2);border-radius:20px;padding:36px;position:relative;overflow:hidden;transition:transform .22s,box-shadow .28s,border-color .2s}
.card::after{content:"";position:absolute;top:-40%;right:-30%;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(52,211,216,.18),transparent 65%);pointer-events:none}
.card:hover{transform:translateY(-6px);box-shadow:0 30px 64px -28px rgba(0,0,0,.65),0 0 0 1px var(--line2);border-color:var(--aqua)}
.card .tag{display:inline-block;font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:#06304a;background:var(--grad-aqua);padding:6px 13px;border-radius:8px;margin-bottom:18px;box-shadow:0 6px 16px -6px rgba(52,211,216,.6)}
.card h3{font-family:var(--display);font-weight:700;font-size:23px;color:#fff;margin-bottom:6px;line-height:1.2}
.card .punch{font-style:italic;color:var(--mist);font-weight:600;margin-bottom:14px}
.card p{color:#c2dcf0;font-size:15.5px}
.card .accent-bar{position:absolute;top:0;left:0;width:6px;height:100%;background:var(--grad-aqua)}
.card ul{list-style:none;margin-top:18px;display:flex;flex-direction:column;gap:10px}
.card li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;color:#cfe4f6}
.card li::before{content:"";flex:0 0 auto;width:9px;height:9px;border-radius:50%;background:var(--grad-aqua);margin-top:7px;box-shadow:0 0 10px rgba(52,211,216,.8)}

/* ---------- pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px}
.pillar{background:var(--grad-aqua-soft);border:1px solid var(--line2);border-radius:18px;padding:34px;transition:transform .2s,border-color .2s}
.pillar:hover{transform:translateY(-5px);border-color:var(--aqua)}
.pillar .dot{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:800;color:#fff;font-size:21px;margin-bottom:20px;box-shadow:0 10px 22px -8px rgba(0,0,0,.5)}
.pillar:nth-child(1) .dot{background:linear-gradient(140deg,#2AA6DA,#1E6FB0)}
.pillar:nth-child(2) .dot{background:var(--grad-aqua);color:#06304a}
.pillar:nth-child(3) .dot{background:var(--grad-gold);color:#3a2500}
.pillar h3{font-family:var(--display);font-weight:700;font-size:20px;color:#fff;margin-bottom:10px}
.pillar p{font-size:15px;color:#c2dcf0}

/* ---------- mission statement band ---------- */
.statement{background:linear-gradient(150deg,rgba(52,211,216,.16),rgba(30,143,196,.10));border:1px solid var(--line2);border-radius:24px;padding:clamp(36px,5vw,66px);position:relative;overflow:hidden;box-shadow:0 36px 80px -44px rgba(0,0,0,.7)}
.statement::after{content:"";position:absolute;top:-25%;right:-10%;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(52,211,216,.22),transparent 65%);pointer-events:none}
.statement p{position:relative;font-size:clamp(18px,2.1vw,24px);line-height:1.62;color:#e2f2ff;max-width:62ch;margin-bottom:22px}
.statement p:last-child{margin-bottom:0}
.statement strong{color:#fff;font-weight:700}
.statement .a{font-weight:700}

/* ---------- CTA band ---------- */
.cta-band{background:var(--grad-aqua);border-radius:24px;padding:clamp(40px,5vw,64px);text-align:center;position:relative;overflow:hidden;box-shadow:0 30px 70px -34px rgba(30,143,196,.8)}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(500px 280px at 80% 120%,rgba(255,255,255,.25),transparent 60%)}
.cta-band h2{position:relative;font-family:var(--display);font-weight:800;font-size:clamp(26px,3.4vw,40px);color:#06304a;letter-spacing:-.02em;max-width:22ch;margin:0 auto;line-height:1.14}
.cta-band p{position:relative;color:#0a4a72;font-weight:500;max-width:52ch;margin:16px auto 28px;font-size:17px}
.cta-band .btn-dark{position:relative;display:inline-flex;align-items:center;gap:9px;background:#06304a;color:#fff;font-weight:700;padding:15px 30px;border-radius:11px;font-size:15px;transition:transform .15s,box-shadow .2s}
.cta-band .btn-dark:hover{transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(6,48,74,.7)}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.email-card{background:linear-gradient(150deg,rgba(52,211,216,.18),rgba(30,143,196,.10));border:1px solid var(--line2);border-radius:22px;padding:44px;position:relative;overflow:hidden;box-shadow:0 36px 80px -44px rgba(0,0,0,.7)}
.email-card::after{content:"";position:absolute;top:-20%;right:-15%;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(52,211,216,.28),transparent 65%);pointer-events:none}
.email-card .lbl{position:relative;font-weight:700;letter-spacing:.22em;font-size:12.5px;text-transform:uppercase;color:var(--sun);margin-bottom:14px}
.email-card a.email{position:relative;display:inline-block;font-family:var(--display);font-weight:700;font-size:clamp(20px,2.6vw,28px);color:#fff;letter-spacing:-.01em;border-bottom:3px solid var(--sun);padding-bottom:5px;transition:color .2s}
.email-card a.email:hover{color:var(--aqua)}
.email-card .note{position:relative;color:var(--mist);margin-top:22px;font-size:15.5px;max-width:38ch}
.form{background:var(--grad-aqua-soft);border:1px solid var(--line2);border-radius:22px;padding:40px}
.form label{display:block;font-weight:700;font-size:14px;color:#e2f2ff;margin:0 0 7px}
.form label span{font-weight:400;color:var(--muted)}
.field{margin-bottom:20px}
.input{width:100%;font-family:var(--body);font-size:15px;color:#eaf4fd;background:rgba(4,24,46,.5);border:1px solid var(--line);border-radius:11px;padding:14px 16px;transition:border-color .2s,box-shadow .2s}
.input::placeholder{color:#86abca}
.input:focus{outline:none;border-color:var(--aqua);box-shadow:0 0 0 3px rgba(52,211,216,.25)}
textarea.input{resize:vertical;min-height:130px}
.form .btn-primary{width:100%;justify-content:center;border:0;cursor:pointer}

/* ---------- page header ---------- */
.phead{position:relative;color:#fff;padding:100px 0 92px;overflow:hidden;border-bottom:1px solid var(--line)}
.phead::after{content:"";position:absolute;right:-120px;top:-120px;width:560px;height:560px;border-radius:50%;
  background:radial-gradient(circle at 40% 40%,rgba(52,211,216,.5),rgba(30,143,196,.2) 45%,transparent 70%);filter:blur(6px);pointer-events:none}
.phead .glow{position:absolute;inset:0;background:radial-gradient(760px 420px at 72% 10%,rgba(52,211,216,.2),transparent 62%)}
.phead .wrap{position:relative;z-index:2}
.phead h1{font-family:var(--display);font-weight:800;font-size:clamp(33px,4.7vw,54px);letter-spacing:-.025em;line-height:1.08;color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.phead .sub{color:var(--mist);font-size:clamp(16px,1.8vw,20px);margin-top:18px;max-width:54ch}
.phead .gold-bar{margin-top:26px}

/* ---------- footer ---------- */
.footer{background:linear-gradient(180deg,rgba(4,28,52,.4),rgba(3,22,42,.85));color:#bcd4e8;padding:58px 0 40px;border-top:1px solid var(--line2)}
.footer .top{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;align-items:flex-start}
.footer .tag{color:var(--mist);font-size:14px;margin-top:14px;max-width:34ch}
.footer .fcol h4{color:#fff;font-family:var(--display);font-weight:700;font-size:14px;letter-spacing:.04em;margin-bottom:14px}
.footer .fcol a{display:block;color:#bcd4e8;font-size:14.5px;margin-bottom:9px;transition:color .2s}
.footer .fcol a:hover{color:var(--aqua)}
.footer .bottom{margin-top:42px;padding-top:22px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px;color:#88abc9}

/* ---------- responsive ---------- */
@media(max-width:860px){
  .links{display:none}.menu-btn{display:block}
  .links.open{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;gap:0;background:var(--deep2);padding:10px 0;border-bottom:1px solid var(--line)}
  .links.open a{padding:14px 28px}
  .stats .grid{grid-template-columns:1fr 1fr}
  .stat:nth-child(2){border-right:0}
  .stat{border-bottom:1px solid rgba(255,255,255,.28)}
  .cards,.pillars,.contact-grid{grid-template-columns:1fr}
  .hero::after{width:380px;height:380px;right:-140px}
}
@media(max-width:520px){.stats .grid{grid-template-columns:1fr}.stat{border-right:0}}
