/* ========= Base ========= */
:root{
  --brand:#6c2bd9;
  --brand-ink:#3e1994;
  --ink:#1f1b2d;
  --muted:#6b6578;
  --line:#ebe8f2;
  --bg:#ffffff;
  --tint:#f6f3ff;
  --tint50:#efe9ff;
}
*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  font-family:'Inter', ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  color:var(--ink); background:#fff; line-height:1.55;
}
img{ max-width:100%; display:block; }
a{ color:inherit; }

/* ========= Layout ========= */
.container{ width:min(1100px, 92%); margin-inline:auto; }
.section{ padding:56px 0; }
.section.tint{ background:var(--tint); }
.mt-20{ margin-top:20px; }
.center{ text-align:center; }

/* ========= Header / Nav ========= */
.site-header{
  position:sticky; top:0; z-index:100; background:#fff; border-bottom:1px solid var(--line);
  backdrop-filter:saturate(180%) blur(6px);
}
.nav-row{ display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:16px; }

.brand{ display:inline-flex; align-items:center; text-decoration:none; }
.brand-logo{
  height: 40px;
  width: auto;
  display: block;
}
@media (min-width: 900px){
  .brand-logo{ height: 56px; }
}

.nav-menu{ list-style:none; display:flex; gap:6px; margin:0; padding:0; align-items:center; }
.nav-link{ text-decoration:none; padding:10px 12px; border-radius:10px; color:#2a243a; display:inline-block; }
.nav-link:hover, .nav-link.active{ background:var(--tint); color:var(--brand-ink); }

.btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 16px; border-radius:12px; text-decoration:none; border:1px solid transparent; font-weight:600; }
.btn-primary{ background:var(--brand); color:#fff; }
.btn-primary:hover{ filter:brightness(.95); }
.btn-ghost{ background:#fff; border:1px solid var(--line); color:#2a243a; }
.btn-sm{ padding:8px 12px; font-size:.92rem; }

/* Dropdown */
.has-dropdown{ position:relative; }
.dropdown{
  position:absolute; top:100%; left:0; background:#fff; border:1px solid var(--line);
  border-radius:12px; padding:8px; box-shadow:0 20px 40px rgba(15,15,29,.12);
  display:none; min-width:240px;
}
.has-dropdown:hover > .dropdown{ display:block; }
.dropdown a{
  display:block; padding:10px 12px; border-radius:8px; text-decoration:none; color:#2a243a;
}
.dropdown a:hover{ background:var(--tint); color:var(--brand-ink); }

/* Mobile nav */
.nav-toggle{ display:none; background:transparent; border:0; padding:8px; border-radius:10px; }
.burger, .burger:before, .burger:after{
  content:""; display:block; width:22px; height:2px; background:#2a243a; border-radius:2px; position:relative;
}
.burger:before{ top:-6px; position:relative; }
.burger:after{ top:4px; position:relative; }
@media (max-width:880px){
  .nav-toggle{ display:inline-block; }
  .nav-menu{ position:fixed; inset:64px 0 auto 0; background:#fff; border-bottom:1px solid var(--line);
    padding:12px; display:none; flex-direction:column; gap:4px; }
  .nav-menu.open{ display:flex; }
  .has-dropdown:hover > .dropdown{ display:none; } /* disable hover on mobile */
  .dropdown{ position:static; display:none; box-shadow:none; border-radius:10px; margin-left:6px; }
  .dropdown.open{ display:block; }
}

/* ========= Search band ========= */
.search-band{ background:#fff; border-bottom:1px solid var(--line); padding:12px 0; position:sticky; top:60px; z-index:90; }
@media (max-width:760px){ .search-band{ top:56px; } }
.search-wrap{ display:flex; align-items:center; justify-content:center; }
.search-form{ display:flex; gap:10px; width:min(960px, 100%); }
.search-form input[type="search"], .search-form select{
  padding:12px 14px; border:1px solid var(--line); border-radius:12px; background:#fff;
}
.search-form input[type="search"]{ flex:1; }
.search-form select{ width:230px; }
@media (max-width:680px){
  .search-form{ flex-direction:column; align-items:stretch; }
  .search-form select{ width:100%; }
}

/* ========= Hero ========= */
.hero{ background:linear-gradient(180deg,#fff, var(--tint)); padding:38px 0 24px; border-bottom:1px solid var(--line); }
.hero-grid{ display:grid; grid-template-columns: 1.2fr .8fr; gap:26px; align-items:center; }
.hero-copy h1{ font-size: clamp(28px, 4.4vw, 44px); line-height:1.12; margin:0 0 12px; }
.hero-copy p{ color:#3a3550; margin:0 0 16px; }
.hero-cta{ display:flex; gap:10px; margin-bottom:10px; }
.hero-bullets{ display:flex; flex-wrap:wrap; gap:14px; padding:0; margin:10px 0 0; list-style:none; color:#4c4560; }
.hero-bullets li{ padding:6px 10px; border:1px dashed var(--line); border-radius:999px; background:#fff; }
.accent{ color:var(--brand-ink); }
@media (max-width:860px){ .hero-grid{ grid-template-columns: 1fr; } .hero-art{ display:none; } }

/* ========= Pills ========= */
.pill-row{ display:flex; flex-wrap:wrap; gap:8px; }
.pill{ border:1px solid var(--line); background:#fff; padding:8px 12px; border-radius:999px; cursor:pointer; }
.pill:hover{ border-color:#d8d3e6; }
.pill-active{ background:var(--tint); border-color:#d9ccff; color:var(--brand-ink); }

/* ========= Cards / Grid ========= */
.grid{ display:grid; gap:16px; }
.cards{ grid-template-columns: repeat(3, 1fr); }
@media (max-width:980px){ .cards{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width:640px){ .cards{ grid-template-columns: 1fr; } }

.card{
  background:#fff; border:1px solid var(--line); border-radius:16px; padding:16px;
  box-shadow:0 8px 18px rgba(31,27,45,.05);
}
.card h3{ margin:0 0 8px; font-size:1.1rem; }
.card p{ margin:0 0 12px; color:#4d4760; }
.meta{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.tag{ font-size:.85rem; padding:6px 10px; background:var(--tint); border-radius:999px; color:#3c2a67; }
.price{ font-weight:700; color:#222; }
.card-link{ text-decoration:none; color:inherit; display:block; transition:transform .12s, box-shadow .12s; }
.card-link:hover{ transform:translateY(-2px); box-shadow:0 24px 60px rgba(15,15,29,.14); }
.card-link:active{ transform:translateY(0); }

/* ========= Why ========= */
.why-grid{ grid-template-columns: repeat(4, 1fr); }
@media (max-width:980px){ .why-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width:560px){ .why-grid{ grid-template-columns: 1fr; } }
.why-card{ position:relative; background:#fff; border:1px solid var(--line); padding:16px; border-radius:16px; }
.why-card h3{ margin:0 0 8px; }
.why-card p{ margin:0; color:#4d4760; }
.why-ico{
  display:inline-flex; align-items:center; justify-content:center;
  width:30px; height:30px; border-radius:50%; background:var(--tint50);
  font-weight:800; margin-bottom:8px;
}

/* ========= Clients ========= */
.client-grid{ display:grid; gap:16px; grid-template-columns: repeat(4, 1fr); }
@media (max-width:900px){ .client-grid{ grid-template-columns: repeat(2, 1fr); } }
.client{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:14px; text-align:center; }
.client img{ height:34px; width:auto; margin:6px auto 10px; filter:grayscale(1); opacity:.9; }
.client figcaption{ font-size:.92rem; color:#4a435c; }

/* ========= Footer ========= */
.site-footer{ background:#100a1f; color:#efeaff; padding:36px 0 18px; }
.footer-grid{ display:grid; grid-template-columns: 1.2fr 1fr .8fr; gap:24px; align-items:start; }
.footer-grid a{ color:#efeaff; text-decoration:none; }
.footer-brand{ margin:0 0 8px; font-weight:800; }
.footer-nav{ display:grid; gap:8px; }
.contact-form label{ display:grid; gap:6px; font-size:.95rem; margin-bottom:10px; }
.contact-form input, .contact-form textarea{
  background:#140e26; color:#fff; border:1px solid #2c2050; border-radius:10px; padding:10px 12px;
}
.form-note{ margin:6px 0 0; }
.tiny{ font-size:.85rem; }
.small{ font-size:.92rem; }
.muted{ color:#b5adcc; }

/* === Fancy Footer === */
.footer {
  position: relative;
  color:#fff;
  margin-top: 40px;
  background:
    radial-gradient(1200px 380px at 85% 10%, rgba(255,255,255,.06), transparent 60%),
    radial-gradient(900px 300px at 15% 0%, rgba(255,255,255,.05), transparent 60%),
    linear-gradient(135deg, #6c2bd9 0%, #4b1aa8 45%, #2c0f6a 100%); /* brand gradient */
}
.footer .wrap { max-width:1200px; margin:0 auto; padding:48px 20px; }
.footer .grid { display:grid; grid-template-columns: 260px 1fr 1fr 1fr; gap:28px; }
@media (max-width: 980px){ .footer .grid{ grid-template-columns:1fr 1fr; } }
@media (max-width: 640px){ .footer .grid{ grid-template-columns:1fr; } }

.footer h4 { margin:0 0 14px; font-size:1.05rem; font-weight:800; color:#fff; }
.footer p, .footer a, .footer li { color: rgba(255,255,255,.9); }
.footer a { text-decoration:none; }
.footer a:hover { text-decoration:underline; }

/* Strategist email emphasis */
.footer .email{
  color:#fff;
  font-weight:600;
  text-decoration:none;
}
.footer .email:hover{ text-decoration:underline; }

.footer .badges { display:grid; grid-template-columns:repeat(2, 72px); gap:12px; }
.footer .badge {
  display:flex; align-items:center; justify-content:center;
  width:72px; height:56px; border-radius:14px;
  background:rgba(255,255,255,.12);
  box-shadow:0 6px 20px rgba(0,0,0,.12), inset 0 0 0 1px rgba(255,255,255,.12);
  font-weight:700; font-size:.8rem;
}
.footer .links ul{ list-style:none; padding:0; margin:0; display:grid; gap:8px; }
.footer .links a{ display:inline-block; padding:2px 0; }

.footer .contact li{ display:flex; align-items:center; gap:10px; }
.footer .contact .ico{ width:18px; height:18px; display:inline-block; }

/* Social buttons — refined size & hover */
.footer .social { display:flex; gap:10px; margin-top:10px; }
.footer .social a{
  width:40px; height:40px;
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:12px;
  background:rgba(255,255,255,.07);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.25);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.footer .social a:hover{
  transform:translateY(-2px);
  border-color:#fff;
  background:rgba(255,255,255,.18);
}
.footer .social svg{ width:18px; height:18px; fill:#fff; }

.footer .tinybar { border-top:1px solid rgba(255,255,255,.18); margin-top:18px; }
.footer .copy { text-align:center; padding:14px 0 10px; color:rgba(255,255,255,.86); font-size:.9rem; }

/* optional wave top edge */
.footer::before{
  content:""; position:absolute; inset:-24px 0 auto 0; height:24px;
  background: linear-gradient(to bottom, rgba(0,0,0,0.12), transparent);
  opacity:.25; pointer-events:none;
}
