/* ============================================================
   Westchase Ads — Google Ads agency — shared styles
   Identity: performance marketing, indigo + amber, rising-curve motif
   ============================================================ */

:root{
  --ink:#14213d;
  --ink-soft:#5b6b86;
  --indigo:#2f4cdd;
  --indigo-deep:#2238b4;
  --amber:#f4a52e;
  --amber-deep:#dd8a12;
  --tint:#eef1fb;
  --tint-2:#dfe5fb;
  --line:#e4e7f2;
  --white:#ffffff;
  --shadow:0 22px 60px -32px rgba(20,33,61,.5);
  --radius:16px;
  --maxw:1140px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);background:var(--white);line-height:1.6;font-size:17px;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:"Space Grotesk","Inter",sans-serif;line-height:1.1;letter-spacing:-.02em;color:var(--ink);margin:0 0 .4em;font-weight:600}
h1{font-size:clamp(2.4rem,5.4vw,3.9rem)}
h2{font-size:clamp(1.8rem,3.6vw,2.6rem)}
h3{font-size:1.2rem}
p{margin:0 0 1rem}
a{color:var(--indigo-deep);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.eyebrow{
  font-family:"Space Grotesk",sans-serif;text-transform:uppercase;letter-spacing:.18em;
  font-size:.74rem;font-weight:600;color:var(--indigo);margin:0 0 .9rem;
  display:inline-flex;align-items:center;gap:.5rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--amber);display:inline-block}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-weight:600;font-size:.98rem;
  padding:.85rem 1.55rem;border-radius:10px;border:1.5px solid transparent;cursor:pointer;
  transition:transform .15s ease,background .15s ease,box-shadow .15s ease;text-decoration:none}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn-primary{background:var(--indigo);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{background:var(--indigo-deep)}
.btn-ghost{background:transparent;color:var(--indigo-deep);border-color:var(--tint-2)}
.btn-ghost:hover{background:var(--tint)}
.btn-amber{background:var(--amber);color:#1a1606}
.btn-amber:hover{background:var(--amber-deep);color:#1a1606}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.88);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem 0}
.brand{display:flex;align-items:center;gap:.7rem;font-weight:700;color:var(--ink);text-decoration:none}
.brand:hover{text-decoration:none}
.brand .mark{flex:0 0 auto}
.brand .brand-name{display:flex;flex-direction:column;line-height:1.05}
.brand .brand-name b{font-family:"Space Grotesk",sans-serif;font-size:1.08rem;font-weight:600}
.brand .brand-name span{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}
.nav-links{display:flex;align-items:center;gap:1.6rem;list-style:none;margin:0;padding:0}
.nav-links a{color:var(--ink);font-size:.95rem;font-weight:500}
.nav-links a:hover{color:var(--indigo-deep);text-decoration:none}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.nav-phone{font-weight:600;color:var(--ink);white-space:nowrap}
.nav-phone:hover{color:var(--indigo-deep);text-decoration:none}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;padding:.4rem}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;background:radial-gradient(120% 90% at 88% -10%,var(--tint-2) 0%,rgba(223,229,251,0) 58%),linear-gradient(180deg,#fff 0%,var(--tint) 100%)}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:3rem;align-items:center;padding:4.6rem 0 5rem}
.hero p.lead{font-size:1.13rem;color:var(--ink-soft);max-width:35rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin:1.7rem 0 1.8rem}
.trust-row{display:flex;flex-wrap:wrap;gap:1.4rem;border-top:1px solid var(--line);padding-top:1.3rem}
.trust-row div{display:flex;align-items:center;gap:.55rem;font-size:.9rem;color:var(--ink-soft)}
.trust-row svg{flex:0 0 auto;color:var(--indigo)}

/* hero panel: rising performance curve */
.hero-card{position:relative;background:#fff;border-radius:20px;padding:1.6rem;box-shadow:var(--shadow);border:1px solid var(--line)}
.hero-card .panel-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.hero-card .panel-top b{font-family:"Space Grotesk",sans-serif;font-size:.95rem}
.hero-card .pill{font-size:.72rem;font-weight:600;color:var(--indigo-deep);background:var(--tint);padding:.25rem .6rem;border-radius:99px}
.hero-card .chart{width:100%;height:auto;display:block;border-radius:12px;background:linear-gradient(180deg,#fff,var(--tint))}
.hero-card .legend{display:flex;gap:1.2rem;margin-top:.9rem;font-size:.8rem;color:var(--ink-soft)}
.hero-card .legend i{width:10px;height:10px;border-radius:3px;display:inline-block;margin-right:.4rem;vertical-align:middle}
.hero-card .stat{position:absolute;background:#fff;border:1px solid var(--line);border-radius:12px;padding:.6rem .85rem;box-shadow:var(--shadow);font-size:.8rem}
.hero-card .stat b{font-family:"Space Grotesk",sans-serif;font-size:1.15rem;color:var(--indigo-deep);display:block}
.stat.s1{top:-.9rem;right:1.2rem}

/* ---------- sections ---------- */
section{padding:4.6rem 0}
.section-head{max-width:42rem;margin-bottom:2.4rem}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head p{color:var(--ink-soft);font-size:1.05rem;margin:0}
.tint{background:var(--tint)}
.ink-bg{background:var(--ink);color:#cdd6ea}
.ink-bg h2{color:#fff}
.ink-bg .section-head p{color:#9fadc9}

/* services */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;transition:transform .15s ease,box-shadow .15s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .ic{width:46px;height:46px;border-radius:11px;background:var(--tint-2);display:flex;align-items:center;justify-content:center;color:var(--indigo-deep);margin-bottom:1rem}
.card h3{margin-bottom:.35rem}
.card p{font-size:.95rem;color:var(--ink-soft);margin:0}

/* process steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;counter-reset:step}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;position:relative}
.step .num{font-family:"Space Grotesk",sans-serif;font-size:.8rem;font-weight:600;letter-spacing:.1em;color:var(--amber-deep)}
.step h3{font-size:1.05rem;margin:.5rem 0 .35rem}
.step p{font-size:.92rem;color:var(--ink-soft);margin:0}

/* split / about */
.split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.feature-list{list-style:none;margin:1.2rem 0 0;padding:0;display:grid;gap:.9rem}
.feature-list li{display:flex;gap:.7rem;align-items:flex-start;font-size:.98rem}
.feature-list svg{flex:0 0 auto;color:var(--indigo);margin-top:.2rem}
.about-visual{border-radius:18px;min-height:300px;border:1px solid var(--line);background:radial-gradient(80% 60% at 70% 20%,var(--tint-2),transparent),linear-gradient(160deg,var(--tint),#fff);display:flex;align-items:center;justify-content:center;color:var(--indigo-deep)}

/* info / location */
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.info-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem}
.info-card h3{margin-bottom:.8rem}
.info-row{display:flex;gap:.7rem;padding:.6rem 0;border-bottom:1px dashed var(--line);font-size:.96rem}
.info-row:last-child{border-bottom:0}
.info-row svg{flex:0 0 auto;color:var(--indigo);margin-top:.15rem}
.map-embed{width:100%;height:100%;min-height:300px;border:0;border-radius:var(--radius);filter:saturate(.92)}

/* CTA band */
.cta-band{background:linear-gradient(120deg,var(--indigo-deep),var(--indigo));color:#fff;border-radius:20px;padding:2.8rem;text-align:center}
.cta-band h2{color:#fff}
.cta-band p{color:rgba(255,255,255,.85);max-width:36rem;margin:0 auto 1.4rem}
.cta-band .btn-ghost{color:#fff;border-color:rgba(255,255,255,.55)}
.cta-band .btn-ghost:hover{background:rgba(255,255,255,.12)}

/* contact form */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.form{display:grid;gap:1rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem}
.field{display:grid;gap:.35rem}
.field label{font-size:.85rem;font-weight:600;color:var(--ink)}
.field input,.field textarea{font:inherit;padding:.75rem .9rem;border:1.5px solid var(--line);border-radius:10px;background:#fbfcff;color:var(--ink)}
.field input:focus,.field textarea:focus{outline:2px solid var(--indigo);outline-offset:1px;border-color:var(--indigo)}
.consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.85rem;color:var(--ink-soft)}
.consent input{margin-top:.25rem}
.form-note{font-size:.82rem;color:var(--ink-soft)}

/* legal pages */
.legal-hero{background:var(--tint);padding:3rem 0 2.4rem;border-bottom:1px solid var(--line)}
.legal{max-width:780px;margin:0 auto;padding:3rem 22px 4rem}
.legal h2{font-size:1.4rem;margin-top:2.4rem}
.legal h3{font-size:1.08rem;margin-top:1.6rem}
.legal p,.legal li{color:#33405c;font-size:1rem}
.legal ul{padding-left:1.2rem}
.legal li{margin-bottom:.4rem}
.legal .updated{color:var(--ink-soft);font-size:.9rem}
.legal table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.92rem}
.legal th,.legal td{border:1px solid var(--line);padding:.6rem .7rem;text-align:left;vertical-align:top}
.legal th{background:var(--tint)}
.callout{background:#fff7ea;border-left:3px solid var(--amber);padding:1rem 1.1rem;border-radius:0 12px 12px 0;margin:1.2rem 0;font-size:.95rem}

/* footer */
.site-footer{background:var(--ink);color:#c6d0e6;padding:3.4rem 0 1.8rem;font-size:.92rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.4rem;padding-bottom:2.2rem;border-bottom:1px solid rgba(255,255,255,.12)}
.site-footer h4{color:#fff;font-family:"Space Grotesk",sans-serif;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;margin:0 0 1rem}
.site-footer a{color:#c6d0e6}
.site-footer a:hover{color:#fff}
.footer-links{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}
.footer-brand .brand .brand-name b{color:#fff}
.footer-brand .brand .brand-name span{color:#93a3c4}
.footer-brand p{color:#9fadc9;max-width:24rem;margin-top:1rem}
.company-info{margin-top:1rem;line-height:1.7}
.company-info dt{color:#93a3c4;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;margin-top:.5rem}
.company-info dd{margin:0;color:#dde4f2}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;padding-top:1.4rem;color:#93a3c4;font-size:.84rem}
.footer-bottom .legal-links{display:flex;flex-wrap:wrap;gap:1.1rem}
.disclaimer-line{color:#8593b3;font-size:.8rem;max-width:60rem;margin:1rem 0 0;line-height:1.6}

/* responsive */
@media (max-width:960px){
  .hero-grid,.split,.loc-grid,.contact-grid{grid-template-columns:1fr;gap:2.2rem}
  .cards,.steps{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-card{max-width:440px;margin:0 auto}
  .about-visual{min-height:240px}
}
@media (max-width:620px){
  body{font-size:16px}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:flex-start;gap:0;padding:.5rem 22px 1rem;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .nav-links.open{display:flex}
  .nav-links li{width:100%;padding:.5rem 0;border-bottom:1px solid var(--line)}
  .menu-toggle{display:block}
  .nav-phone{display:none}
  .cards,.steps{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  section{padding:3rem 0}
  .cta-band{padding:1.9rem}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
:focus-visible{outline:2px solid var(--indigo-deep);outline-offset:2px;border-radius:4px}

/* cookie banner */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:60;max-width:640px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:1.1rem 1.2rem;display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.cookie-banner p{margin:0;font-size:.9rem;color:var(--ink-soft);flex:1 1 240px}
.cookie-banner .cookie-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.cookie-banner .btn{padding:.6rem 1.1rem;font-size:.88rem}
@media (max-width:480px){.cookie-banner{flex-direction:column;align-items:stretch}.cookie-banner .cookie-actions{justify-content:stretch}.cookie-banner .btn{flex:1}}
