:root{
  --bg: #fbf9f5;
  --bg-2: #f3efe6;
  --ink: #0b0e16;
  --ink-2: #2a2f3d;
  --ink-3: #5b6075;
  --line: #e6e1d4;
  --line-2: #d6cfbe;
  --accent: #2c3e74;       /* deep navy */
  --accent-2: #c9591a;     /* burnt orange — used sparingly */
  --serif: 'Fraunces', Georgia, serif;
  --sans: 'Inter', system-ui, sans-serif;
  --maxw: 1180px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{background:var(--bg);color:var(--ink)}
body{
  font-family:var(--sans);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
  background:var(--bg);
}
a{color:inherit}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
img,svg{display:block;max-width:100%}
::selection{background:var(--accent);color:#fff}
em{font-style:italic}

/* ============ NAV ============ */
.nav{
  display:flex;align-items:center;gap:24px;
  max-width:var(--maxw);margin:0 auto;
  padding:24px 32px;
}
.brand{
  display:flex;align-items:center;gap:10px;
  font-family:var(--serif);font-weight:600;font-size:20px;text-decoration:none;color:var(--ink);
}
.brand em{font-style:italic;color:var(--accent);font-weight:500}
.brand-mark{
  display:inline-block;width:22px;height:22px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, var(--accent-2), var(--accent) 70%);
  box-shadow:inset -2px -2px 4px rgba(0,0,0,0.2);
}
.nav-links{
  display:flex;gap:24px;margin-left:auto;
  font-size:14px;color:var(--ink-3);font-weight:500;
}
.nav-links a{text-decoration:none;color:inherit;transition:color .2s}
.nav-links a:hover{color:var(--ink)}
@media (max-width:780px){.nav-links{display:none}}

/* ============ buttons ============ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;font-size:14px;font-weight:500;
  border-radius:99px;border:1px solid transparent;
  text-decoration:none;cursor:pointer;
  transition:transform .2s, box-shadow .2s, background .2s, border-color .2s;
}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:#1f2e58;transform:translateY(-1px);box-shadow:0 8px 20px rgba(44,62,116,0.25)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--ink-3);background:var(--bg-2)}
.btn-lg{padding:14px 24px;font-size:15px}

/* ============ HERO ============ */
.hero{
  position:relative;overflow:hidden;
  max-width:var(--maxw);margin:0 auto;
  padding:60px 32px 80px;
}
.hero-inner{position:relative;z-index:2;max-width:760px}
.eyebrow{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
  display:inline-block;margin-bottom:24px;font-weight:500;
}
h1{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(44px, 6.8vw, 84px);line-height:1.02;letter-spacing:-0.02em;
  margin:0 0 24px;color:var(--ink);
}
h1 em{color:var(--accent);font-style:italic;font-weight:500}
.lede{
  font-size:18px;color:var(--ink-2);max-width:620px;margin:0 0 32px;
}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:48px}
.hero-meta{
  display:flex;gap:48px;flex-wrap:wrap;
  border-top:1px solid var(--line);padding-top:28px;
}
.hero-meta div{display:flex;flex-direction:column;gap:2px}
.hero-meta strong{font-family:var(--serif);font-size:32px;font-weight:500;color:var(--ink);letter-spacing:-0.02em}
.hero-meta span{font-size:13px;color:var(--ink-3)}

/* hero-art: subtle decorative orb in the background */
.hero-art{position:absolute;top:0;right:0;width:50%;height:100%;pointer-events:none;z-index:1;opacity:.6}
.hero-art .orb{
  position:absolute;right:-100px;top:30px;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(201,89,26,0.18), rgba(44,62,116,0.06) 60%, transparent 70%);
  filter:blur(20px);
}
.hero-art .grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(to right, rgba(11,14,22,0.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(11,14,22,0.05) 1px, transparent 1px);
  background-size:36px 36px;
  mask-image:radial-gradient(circle at 60% 50%, black 30%, transparent 70%);
}
@media (max-width:880px){.hero-art{display:none}}

/* ============ LOGO STRIP ============ */
.logos{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:28px 32px;text-align:center;
  background:var(--bg-2);
}
.logos-eyebrow{
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-3);
  margin:0 0 12px;font-weight:500;
}
.logos-row{
  display:flex;justify-content:center;gap:18px;flex-wrap:wrap;
  font-family:var(--serif);font-size:18px;color:var(--ink-2);
}
.logos-row .dot{color:var(--line-2)}

/* ============ SECTIONS ============ */
.section{
  max-width:var(--maxw);margin:0 auto;
  padding:100px 32px;
}
.section-alt{background:var(--bg-2);max-width:none}
.section-alt > *{max-width:var(--maxw);margin-left:auto;margin-right:auto}
.section-head{text-align:center;max-width:680px;margin:0 auto 56px}
.kicker{
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);
  font-weight:600;display:inline-block;margin-bottom:14px;
}
h2{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(32px, 4.4vw, 52px);line-height:1.1;letter-spacing:-0.02em;
  margin:0 0 14px;color:var(--ink);
}
.section-head p{color:var(--ink-3);font-size:17px;margin:0}

/* ============ SERVICES ============ */
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
@media (max-width:900px){.services-grid{grid-template-columns:1fr}}

.service{
  background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:32px;position:relative;
  display:flex;flex-direction:column;gap:14px;
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.service:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(11,14,22,0.06);border-color:var(--line-2)}
.service.highlight{
  background:var(--ink);color:#fbf9f5;border-color:var(--ink);
}
.service.highlight h3,.service.highlight p,.service.highlight .checks li{color:#fbf9f5}
.service.highlight .checks li::before{background:var(--accent-2)}
.service-num{
  font-family:var(--serif);font-weight:500;font-size:14px;color:var(--ink-3);
  letter-spacing:.04em;
}
.service.highlight .service-num{color:rgba(251,249,245,0.6)}
.service h3{font-family:var(--serif);font-weight:500;font-size:24px;margin:0;letter-spacing:-0.01em}
.service p{margin:0;color:var(--ink-2);font-size:15px}

.checks{list-style:none;padding:0;margin:6px 0 0;display:flex;flex-direction:column;gap:8px;font-size:14px;color:var(--ink-2)}
.checks li{position:relative;padding-left:22px}
.checks li::before{
  content:"";position:absolute;left:0;top:.55em;width:8px;height:8px;border-radius:50%;
  background:var(--accent);
}
.badge{
  position:absolute;top:18px;right:18px;
  font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;
  padding:4px 10px;border-radius:99px;background:var(--accent-2);color:#fff;
}

/* ============ CASE STUDIES ============ */
.cases{display:grid;grid-template-columns:1fr;gap:18px}
.case{
  background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:32px;display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:start;
}
@media (max-width:780px){.case{grid-template-columns:1fr}}
.case > header{display:flex;gap:8px;align-items:center;grid-column:1 / -1}
.case-platform{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--accent);
}
.case-cat{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
  border-left:1px solid var(--line-2);padding-left:8px;
}
.case h3{font-family:var(--serif);font-weight:500;font-size:26px;margin:0;letter-spacing:-0.01em;line-height:1.2}
.case p{margin:0;color:var(--ink-2);font-size:15px}
.case-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
  align-self:start;
  border-top:1px dashed var(--line-2);padding-top:18px;
  grid-column:1 / -1;
}
.case-stats div{display:flex;flex-direction:column;gap:2px}
.case-stats strong{font-family:var(--serif);font-size:24px;font-weight:500;color:var(--ink);letter-spacing:-0.02em}
.case-stats span{font-size:12px;color:var(--ink-3);letter-spacing:.04em}

/* ============ PRICING ============ */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:stretch}
@media (max-width:900px){.tiers{grid-template-columns:1fr}}
.tier{
  background:#fff;border:1px solid var(--line);border-radius:16px;padding:32px;
  display:flex;flex-direction:column;gap:18px;position:relative;
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.tier:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(11,14,22,0.06);border-color:var(--line-2)}
.tier.highlight{
  background:var(--ink);color:#fbf9f5;border-color:var(--ink);
}
.tier.highlight h3,.tier.highlight .price,.tier.highlight .checks li,.tier.highlight .tier-sub{color:#fbf9f5}
.tier.highlight .checks li::before{background:var(--accent-2)}
.tier > header{display:flex;flex-direction:column;gap:4px}
.tier h3{font-family:var(--serif);font-weight:500;font-size:24px;margin:0;letter-spacing:-0.01em}
.tier-sub{margin:0;font-size:13px;color:var(--ink-3)}
.price{
  font-family:var(--serif);font-weight:500;font-size:48px;letter-spacing:-0.03em;color:var(--ink);
  margin:0;display:flex;align-items:baseline;gap:4px;
}
.price span{font-size:24px;color:var(--ink-3);font-weight:400}
.price em{font-size:14px;color:var(--ink-3);font-style:normal;font-weight:400;margin-left:6px}
.tier .btn{margin-top:auto;justify-content:center}

/* ============ TESTIMONIALS ============ */
.quotes{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
@media (max-width:900px){.quotes{grid-template-columns:1fr}}
.quotes blockquote{
  background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:28px;margin:0;
  display:flex;flex-direction:column;gap:16px;
}
.quotes p{
  font-family:var(--serif);font-size:18px;line-height:1.5;letter-spacing:-0.005em;
  color:var(--ink);margin:0;
}
.quotes p::before{content:"\201C";font-size:42px;line-height:0;display:block;color:var(--accent-2);margin-bottom:10px}
.quotes footer{font-size:13px;color:var(--ink-3)}

/* ============ FAQ ============ */
.faqs{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:8px}
.faqs details{
  background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px 24px;
  transition:border-color .2s;
}
.faqs details[open]{border-color:var(--line-2)}
.faqs summary{
  cursor:pointer;font-family:var(--serif);font-size:18px;font-weight:500;letter-spacing:-0.01em;
  list-style:none;display:flex;align-items:center;justify-content:space-between;
}
.faqs summary::-webkit-details-marker{display:none}
.faqs summary::after{
  content:"+";font-size:24px;color:var(--ink-3);font-weight:300;transition:transform .2s;
}
.faqs details[open] summary::after{transform:rotate(45deg)}
.faqs p{margin:14px 0 0;color:var(--ink-2);font-size:15px;line-height:1.65}

/* ============ CONTACT ============ */
.contact{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;
  max-width:1000px;margin:0 auto;
}
@media (max-width:780px){.contact{grid-template-columns:1fr;gap:32px}}
.contact-copy h2{margin-top:14px}
.contact-copy p{color:var(--ink-2);font-size:16px;margin:0 0 14px}
.contact-meta{font-size:14px;color:var(--ink-3)}
.contact-meta a{color:var(--accent);font-weight:500;text-decoration:none}
.contact-form{
  display:flex;flex-direction:column;gap:14px;
  background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:28px;
}
.contact-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--ink-3);font-weight:500}
.contact-form input,
.contact-form textarea{
  font:inherit;font-size:15px;color:var(--ink);
  background:var(--bg);border:1px solid var(--line);border-radius:8px;
  padding:12px 14px;outline:none;transition:border-color .2s, background .2s;
  font-family:var(--sans);resize:vertical;
}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--accent);background:#fff}
.contact-form .btn{align-self:flex-start;margin-top:6px}
.thanks{
  font-family:var(--serif);font-size:20px;color:var(--accent);text-align:center;padding:40px 20px;
}

/* ============ FOOTER ============ */
.foot{
  border-top:1px solid var(--line);
  padding:32px;background:var(--bg);
}
.foot-row{
  display:flex;align-items:center;gap:14px;
  max-width:var(--maxw);margin:0 auto;
  font-size:13px;color:var(--ink-3);
}
.foot-row .brand{font-size:18px}
.foot-spacer{flex:1}
.foot-fine{margin-top:14px;color:var(--ink-3);justify-content:space-between}
@media (max-width:680px){.foot-row{flex-direction:column;align-items:flex-start;gap:6px}}
