/* ===== TGX Shared Stylesheet ===== */
/* Used by /tools/ pages and /tools/growth-intelligence/ tools */

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body{font-family:'Figtree',sans-serif;background:var(--ash);color:var(--paper);line-height:1.6;overflow-x:hidden}
img,svg{display:block;max-width:100%}
ul{list-style:none}
a{text-decoration:none;color:inherit}
button{cursor:pointer;background:none;border:none;font:inherit;color:inherit}
h1,h2,h3,h4,h5,h6{line-height:1.15}
::selection{background:rgba(24,201,222,.25);color:#f6f6f6}
:focus-visible{outline:2px solid var(--miami);outline-offset:3px;border-radius:4px}

/* ── Variables ── */
:root{
  --ash:       #2f3846;
  --ash-d:     #263040;
  --ash-dd:    #1a2230;
  --border:    rgba(172,185,200,.15);
  --miami:     #18c9de;
  --miami-dim: rgba(24,201,222,.12);
  --paper:     #f6f6f6;
  --haze:      #acb9c8;
  --coral:     #f38375;
  --coral-dim: rgba(243,131,117,.12);
  --yellow:    #c8f028;
  --nav-h:     64px;
  --ease:      cubic-bezier(.16,1,.3,1);
  --fast:      120ms;
  --med:       200ms;
  --wrap:      1120px;
  --gutter:    clamp(20px,4vw,48px);
}

/* ── Utility ── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--gutter)}

/* ── Typography ── */
.t-display{font-size:clamp(2rem,4.5vw,3.5rem);font-weight:800;color:var(--paper);letter-spacing:-.03em;line-height:1.08}
.t-1{font-size:clamp(1.5rem,3vw,2.25rem);font-weight:700;color:var(--paper);letter-spacing:-.02em}
.t-2{font-size:clamp(1.1rem,1.8vw,1.35rem);font-weight:700;color:var(--paper);letter-spacing:-.01em}
.t-body{font-size:clamp(.95rem,1.1vw,1.05rem);line-height:1.65}
.t-sm{font-size:.875rem;line-height:1.55}
.t-xs{font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.t-muted{color:var(--haze)}
.t-accent{color:var(--miami)}
.t-coral{color:var(--coral)}

/* ── Reveal animation ── */
.rv{opacity:0;transform:translateY(18px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv.vis{opacity:1;transform:translateY(0)}

/* ── Sections ── */
.section{padding:clamp(48px,6vw,96px) 0}
.section--lg{padding:clamp(64px,8vw,120px) 0}
.bg-ash{background:var(--ash)}
.bg-deep{background:var(--ash-dd)}

/* ── Grid ── */
.grid{display:grid;gap:clamp(16px,2vw,28px)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid--3,.grid--4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid--2,.grid--3,.grid--4{grid-template-columns:1fr}}

/* ── Rules ── */
.rule{border:0;border-top:1px solid var(--border);margin:clamp(32px,4vw,56px) 0}

/* ── Navigation ── */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);display:flex;align-items:center;padding:0 var(--gutter);background:rgba(26,34,48,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
.nav__inner{width:100%;max-width:var(--wrap);margin:0 auto;display:flex;align-items:center;justify-content:space-between}
.nav__logo{font-size:1.15rem;font-weight:700;color:var(--paper);display:flex;align-items:center}
.nav__logo em{color:var(--miami);font-weight:300;font-size:1.2em;font-style:normal;margin-left:.06em}
.nav__links{display:none;align-items:center;gap:2rem;list-style:none}
@media(min-width:960px){.nav__links{display:flex}}
.nav__links a{font-size:14px;font-weight:500;color:rgba(246,246,246,.6);transition:color .15s}
.nav__links a:hover{color:var(--paper)}
.nav__cta{background:var(--miami);color:var(--paper);font-size:13px;font-weight:600;padding:9px 22px;border-radius:8px;white-space:nowrap;transition:background .15s}
.nav__cta:hover{background:#14b5c9}

/* Dropdown in nav */
.dd{position:relative}
.dd__trigger{font-size:14px;font-weight:500;color:rgba(246,246,246,.6);cursor:pointer;display:flex;align-items:center;gap:4px;transition:color .15s}
.dd__trigger:hover{color:var(--paper)}
.dd__trigger::after{content:'';border:4px solid transparent;border-top-color:currentColor;margin-top:2px}
.dd__menu{display:none;position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--ash-dd);border:1px solid var(--border);border-radius:10px;padding:8px;min-width:180px;box-shadow:0 12px 40px rgba(0,0,0,.3)}
.dd:hover .dd__menu{display:block}
.dd__menu a{display:block;padding:8px 14px;font-size:13px;font-weight:500;color:var(--haze);border-radius:6px;transition:background .12s,color .12s}
.dd__menu a:hover{background:rgba(24,201,222,.06);color:var(--paper)}

/* ── Hamburger ── */
.burger{display:flex;flex-direction:column;gap:5px;width:24px;padding:2px 0;cursor:pointer}
.burger span{display:block;height:2px;background:var(--paper);border-radius:2px;transition:transform .2s,opacity .2s}
@media(min-width:960px){.burger{display:none}}

/* ── Mobile menu ── */
.mmenu{position:fixed;inset:0;z-index:99;background:var(--ash-dd);padding:calc(var(--nav-h) + 24px) var(--gutter) 32px;display:none;flex-direction:column;gap:24px;overflow-y:auto}
.mmenu[aria-hidden="false"]{display:flex}
.mmenu__label{font-size:.65rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--haze);opacity:.5;margin-bottom:6px}
.mmenu__group{display:flex;flex-direction:column;gap:4px}
.mmenu__group a{font-size:1.1rem;font-weight:600;color:var(--paper);padding:10px 0;border-bottom:1px solid var(--border);transition:color .15s}
.mmenu__group a:hover{color:var(--miami)}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;padding:12px 26px;border-radius:8px;white-space:nowrap;transition:background .15s,color .15s,border-color .15s}
.btn--p{background:var(--yellow);color:#1a2230}
.btn--p:hover{background:#b8e020}
.btn--o{background:transparent;border:1px solid var(--border);color:var(--paper)}
.btn--o:hover{border-color:var(--haze);background:rgba(246,246,246,.04)}
.btn--ghost{color:var(--miami);font-weight:600;font-size:.85rem;display:inline-flex;align-items:center;gap:6px}
.btn--ghost:hover{color:#14b5c9}
.btn--ghost::after{content:'→';transition:transform .15s}
.btn--ghost:hover::after{transform:translateX(3px)}
.btn-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;font-size:.65rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:5px 12px;border-radius:6px;white-space:nowrap}
.badge--miami{background:rgba(24,201,222,.1);color:var(--miami);border:1px solid rgba(24,201,222,.2)}
.badge--yellow{background:rgba(200,240,40,.1);color:var(--yellow);border:1px solid rgba(200,240,40,.2)}
.badge--coral{background:rgba(243,131,117,.1);color:var(--coral);border:1px solid rgba(243,131,117,.2)}

/* ── Device mockup ── */
.device__bar{display:flex;align-items:center;gap:6px;padding:10px 14px;background:rgba(0,0,0,.25);border-radius:12px 12px 0 0;border:1px solid var(--border);border-bottom:0}
.device__dot{width:8px;height:8px;border-radius:50%;background:rgba(172,185,200,.2)}
.device__body{background:var(--ash-dd);border:1px solid var(--border);border-radius:0 0 12px 12px;padding:clamp(16px,2vw,28px);overflow:hidden}

/* ── V-Cards (tool cards) ── */
.v-card{background:var(--ash-dd);border:1px solid var(--border);border-radius:12px;padding:clamp(20px,2vw,28px);transition:border-color .2s,transform .2s}
.v-card:hover{border-color:rgba(24,201,222,.2);transform:translateY(-2px)}
.v-card__label{font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--haze);opacity:.5;margin-bottom:10px}
.v-card__title{font-size:1.05rem;font-weight:700;color:var(--paper);margin-bottom:8px}
.v-card__desc{font-size:.85rem;color:var(--haze);line-height:1.55}

/* ── CTA Section ── */
.cta-section{text-align:center}
.cta-section .t-display,.cta-section .t-1{margin:0 auto}
.cta-section .t-body{margin:0 auto 20px}

/* ── Footer ── */
.footer{background:var(--ash-dd);border-top:1px solid var(--border);padding:clamp(48px,5vw,72px) 0 32px}
.footer__top{display:flex;flex-direction:column;gap:32px}
.footer__grid{display:grid;grid-template-columns:2fr repeat(3,1fr);gap:clamp(24px,3vw,48px)}
@media(max-width:768px){.footer__grid{grid-template-columns:1fr 1fr;gap:28px}}
@media(max-width:480px){.footer__grid{grid-template-columns:1fr}}
.footer__desc{font-size:.85rem;color:var(--haze);line-height:1.6;max-width:280px;margin-top:12px}
.footer__h{font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--haze);opacity:.5;margin-bottom:12px}
.footer__links{display:flex;flex-direction:column;gap:8px}
.footer__links a,.footer__links li{font-size:.85rem;color:rgba(246,246,246,.6);transition:color .15s}
.footer__links a:hover{color:var(--paper)}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;margin-top:40px;border-top:1px solid var(--border);font-size:.75rem;color:var(--haze);opacity:.5;flex-wrap:wrap;gap:12px}

/* ── Progress bar (scroll) ── */
.progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:200;background:linear-gradient(90deg,var(--miami),var(--yellow));transform-origin:left;transform:scaleX(0);transition:transform 60ms linear}

/* ── Spacing for nav ── */
body{padding-top:var(--nav-h)}
