/* =========================================================
   Superr — shared design system
   Warm orange brand · Nunito (rounded, friendly, legible)
   ========================================================= */

:root{
  /* Cool neutrals */
  --bg:        oklch(0.991 0.003 250);
  --surface:   oklch(1 0 0);
  --tint:      oklch(0.967 0.005 250);
  --tint-2:    oklch(0.948 0.007 250);
  --ink:       oklch(0.255 0.035 258);
  --ink-soft:  oklch(0.46 0.024 258);
  --ink-mute:  oklch(0.60 0.018 258);
  --line:      oklch(0.905 0.008 250);
  --line-soft: oklch(0.945 0.006 250);

  /* Superr orange */
  --brand:        oklch(0.672 0.19 46);
  --brand-strong: oklch(0.598 0.185 43);
  --brand-deep:   oklch(0.47 0.14 42);
  --brand-tint:   oklch(0.957 0.034 58);
  --brand-tint-2: oklch(0.925 0.055 56);
  --on-brand:     oklch(0.995 0.006 80);

  /* Navy (dark sections) */
  --navy:      oklch(0.245 0.05 262);
  --navy-deep: oklch(0.205 0.046 264);
  --on-navy:   oklch(0.93 0.012 250);
  --whatsapp:  oklch(0.66 0.16 150);

  /* Radii */
  --r-xs: 8px;
  --r-sm: 12px;
  --r:    18px;
  --r-lg: 26px;
  --r-xl: 34px;
  --pill: 999px;

  /* Shadows */
  --shadow-sm: 0 2px 8px -3px oklch(0.4 0.04 258 / 0.16);
  --shadow:    0 10px 30px -14px oklch(0.35 0.05 260 / 0.22);
  --shadow-lg: 0 26px 60px -24px oklch(0.3 0.05 262 / 0.30);

  /* Type */
  --font-display: "Nunito", system-ui, sans-serif;
  --font-body: "Nunito Sans", system-ui, sans-serif;

  /* Layout */
  --maxw: 1200px;
  --gutter: clamp(20px, 5vw, 56px);
  --section-y: clamp(56px, 8vw, 112px);
}

*,*::before,*::after{ box-sizing:border-box; }

html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }

body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  font-size:clamp(16px, 1rem + 0.2vw, 18px);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{ max-width:100%; display:block; }

a{ color:var(--brand-strong); text-decoration:none; }
a:hover{ color:var(--brand-deep); }

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:800;
  line-height:1.08;
  letter-spacing:-0.015em;
  margin:0 0 .4em;
  color:var(--ink);
  text-wrap:balance;
}
h1{ font-size:clamp(2.3rem, 1.4rem + 3.6vw, 4.1rem); font-weight:900; }
h2{ font-size:clamp(1.8rem, 1.2rem + 2.2vw, 3rem); }
h3{ font-size:clamp(1.25rem, 1rem + 0.9vw, 1.7rem); }
h4{ font-size:1.12rem; font-weight:800; }
p{ margin:0 0 1em; text-wrap:pretty; }

.lead{ font-size:clamp(1.1rem, 1rem + 0.55vw, 1.4rem); color:var(--ink-soft); line-height:1.55; }

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.wrap-wide{ max-width:1320px; }
.section{ padding-block:var(--section-y); }
.section-tint{ background:var(--tint); }
.section-brand{ background:var(--brand-tint); }
.center{ text-align:center; }
.measure{ max-width:62ch; }
.measure-s{ max-width:46ch; }
.mx-auto{ margin-inline:auto; }
.eyebrow{
  font-family:var(--font-display);
  font-weight:800;
  font-size:.82rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--brand-strong);
  margin:0 0 .9rem;
}
.section-head{ max-width:60ch; margin-bottom:clamp(32px,5vw,56px); }
.section-head.center{ margin-inline:auto; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--brand);
  display:inline-flex; align-items:center; gap:.55em;
  font-family:var(--font-display);
  font-weight:800;
  font-size:1rem;
  line-height:1;
  padding:.95em 1.5em;
  border-radius:var(--pill);
  border:2px solid transparent;
  cursor:pointer;
  transition:transform .14s ease, box-shadow .18s ease, background .18s ease, color .15s ease;
  white-space:nowrap;
}
.btn-primary{ background:var(--brand); color:var(--on-brand); box-shadow:var(--shadow); }
.btn-primary:hover{ background:var(--brand-strong); color:var(--on-brand); transform:translateY(-2px); box-shadow:var(--shadow-lg); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--brand); color:var(--brand-strong); transform:translateY(-2px); }
.btn-white{ background:var(--surface); color:var(--brand-strong); box-shadow:var(--shadow); }
.btn-white:hover{ transform:translateY(-2px); box-shadow:var(--shadow-lg); color:var(--brand-deep); }
.btn-lg{ font-size:1.08rem; padding:1.05em 1.8em; }
.btn-arrow{ transition:transform .18s ease; }
.btn:hover .btn-arrow{ transform:translateX(3px); }

.link-arrow{
  font-family:var(--font-display); font-weight:800;
  display:inline-flex; align-items:center; gap:.4em;
  color:var(--brand-strong);
}
.link-arrow svg{ transition:transform .18s ease; }
.link-arrow:hover svg{ transform:translateX(3px); }

/* ---------- Chips / pills ---------- */
.chips{ display:flex; flex-wrap:wrap; gap:.6rem; }
.chip{
  display:inline-flex; align-items:center; gap:.5em;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--pill);
  padding:.5em 1em;
  font-weight:700; font-size:.92rem;
  color:var(--ink-soft);
  box-shadow:var(--shadow-sm);
}
.chip .dot{ width:.5rem; height:.5rem; border-radius:50%; background:var(--brand); }

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:oklch(0.992 0.008 78 / 0.82);
  backdrop-filter:saturate(1.4) blur(12px);
  border-bottom:1px solid var(--line-soft);
}
.nav{ display:flex; align-items:center; gap:1.5rem; height:74px; }
.brand{ display:inline-flex; align-items:center; gap:.55rem; color:var(--ink); }
.brand:hover{ color:var(--ink); }
.logo-mark{ width:36px; height:36px; flex:none; border-radius:10px; background:var(--brand); color:#fff; display:grid; place-items:center; font-family:var(--font-display); font-weight:900; font-size:1.32rem; box-shadow:var(--shadow-sm); }
.logo-word{ font-family:var(--font-display); font-weight:900; font-size:1.5rem; letter-spacing:-0.025em; color:var(--ink); }
.nav-links{ display:flex; align-items:center; gap:.3rem; margin-left:.5rem; }
.nav-links a{
  font-family:var(--font-display); font-weight:700;
  color:var(--ink-soft); padding:.5em .85em; border-radius:var(--r-sm);
  font-size:1rem; white-space:nowrap;
}
.nav-links a:hover{ color:var(--ink); background:var(--tint-2); }
.nav-links a[aria-current="page"]{ color:var(--brand-strong); }
.nav-actions{ margin-left:auto; display:flex; align-items:center; gap:1rem; }
.nav-phone{
  display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--font-display); font-weight:800; color:var(--ink);
  white-space:nowrap;
}
.nav-phone svg{ color:var(--brand); }
.nav-phone:hover{ color:var(--brand-strong); }
.nav-toggle{ display:none; }
.mobile-menu{ display:none; }
.nav-wa{ display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; border-radius:var(--pill); color:var(--whatsapp); border:1.5px solid var(--line); background:var(--surface); }
.nav-wa:hover{ color:#fff; background:var(--whatsapp); border-color:var(--whatsapp); }
.btn-wa{ background:var(--surface); color:var(--ink); border-color:var(--line); }
.btn-wa svg{ color:var(--whatsapp); }
.btn-wa:hover{ border-color:var(--whatsapp); color:var(--ink); transform:translateY(-2px); }

/* Mobile nav */
@media (max-width:980px){
  .nav-links, .nav-phone span{ display:none; }
  .nav-toggle{
    display:inline-flex; align-items:center; justify-content:center;
    width:46px; height:46px; margin-left:auto;
    border:1px solid var(--line); border-radius:var(--r-sm);
    background:var(--surface); cursor:pointer; color:var(--ink);
  }
  .nav-actions{ margin-left:0; gap:.6rem; }
  .nav-actions .btn{ padding:.7em 1.1em; font-size:.95rem; }
  .mobile-menu{
    display:none; flex-direction:column; gap:.2rem;
    padding:.6rem var(--gutter) 1.2rem;
    border-bottom:1px solid var(--line-soft);
    background:var(--bg);
  }
  .mobile-menu.open{ display:flex; }
  .mobile-menu a{
    font-family:var(--font-display); font-weight:800; font-size:1.15rem;
    color:var(--ink); padding:.7em .2em; border-bottom:1px solid var(--line-soft);
  }
  .mobile-menu a:last-child{ border-bottom:0; }
  .mobile-menu .m-phone{ color:var(--brand-strong); }
}

/* ---------- Hero pieces ---------- */
.hero{ position:relative; overflow:hidden; }
.hero > .wrap{ position:relative; z-index:1; }
.hero-glow{
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(60% 70% at 88% 12%, var(--brand-tint-2), transparent 60%),
    radial-gradient(50% 60% at 6% 90%, var(--tint-2), transparent 60%);
}

/* ---------- Cards ---------- */
.card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.card-pad{ padding:clamp(22px,3vw,34px); }
.card-link{ transition:transform .18s ease, box-shadow .2s ease, border-color .2s ease; display:block; }
.card-link:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:var(--brand-tint-2); }

/* Pillar cards */
.pillars{ display:grid; gap:clamp(18px,2.4vw,28px); grid-template-columns:1fr 1fr; }
@media (max-width:760px){ .pillars{ grid-template-columns:1fr; } }
.pillar{ position:relative; padding:clamp(26px,3.4vw,40px); display:flex; flex-direction:column; min-height:100%; }
.pillar .pillar-icon{
  width:56px; height:56px; border-radius:var(--r-sm);
  display:grid; place-items:center; background:var(--brand-tint); color:var(--brand-strong);
  margin-bottom:1.1rem;
}
.pillar h3{ margin-bottom:.4rem; }
.pillar p{ color:var(--ink-soft); }
.pillar .link-arrow{ margin-top:auto; }

/* ---------- Stats ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(14px,2vw,24px); }
@media (max-width:760px){ .stats{ grid-template-columns:1fr 1fr; } }
.stat{ text-align:center; padding:1rem .5rem; }
.stat .num{ font-family:var(--font-display); font-weight:900; font-size:clamp(2rem,1.4rem+1.8vw,2.9rem); color:var(--brand-strong); line-height:1; letter-spacing:-0.02em; }
.stat .lbl{ color:var(--ink-soft); font-weight:700; font-size:.95rem; margin-top:.5rem; }

/* ---------- Device mockups (placeholders) ---------- */
.mock{ position:relative; }
.mock-browser{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r);
  box-shadow:var(--shadow-lg);
  overflow:hidden;
}
.mock-bar{
  display:flex; align-items:center; gap:.5rem;
  padding:.7rem .9rem; border-bottom:1px solid var(--line-soft);
  background:var(--tint);
}
.mock-bar .traffic{ display:flex; gap:.4rem; }
.mock-bar .traffic i{ width:.7rem; height:.7rem; border-radius:50%; background:var(--line); }
.mock-bar .url{
  flex:1; height:1.5rem; border-radius:var(--pill); background:var(--surface);
  border:1px solid var(--line-soft);
  display:flex; align-items:center; padding:0 .8rem;
  font-family:ui-monospace,Menlo,Consolas,monospace; font-size:.72rem; color:var(--ink-mute);
}
.ph{
  position:relative;
  background:
    repeating-linear-gradient(135deg,
      oklch(0.95 0.012 70) 0 14px,
      oklch(0.975 0.01 72) 14px 28px);
  display:grid; place-items:center;
  color:var(--ink-mute);
}
.ph .ph-label{
  font-family:ui-monospace,Menlo,Consolas,monospace;
  font-size:.78rem; letter-spacing:.02em; color:var(--ink-mute);
  background:oklch(1 0 0 / 0.78); border:1px solid var(--line-soft);
  padding:.4em .7em; border-radius:var(--pill);
}
.mock-browser .ph{ aspect-ratio:16/10; }

/* About hero photo */
.about-photo{ width:100%; height:auto; border-radius:var(--r-lg); box-shadow:var(--shadow-lg); display:block; }
.mock .photo-cap{
  position:absolute; left:14px; bottom:14px;
  background:oklch(0.255 0.035 258 / 0.74); color:#fff;
  -webkit-backdrop-filter:blur(5px); backdrop-filter:blur(5px);
  font-family:var(--font-display); font-weight:800; font-size:.85rem;
  padding:.45em .95em; border-radius:var(--pill);
}

/* Phone overlay */
.mock-phone{
  position:absolute;
  width:clamp(96px,18%,150px);
  aspect-ratio:9/19;
  right:-4%; bottom:-7%;
  background:var(--ink);
  border-radius:22px;
  padding:7px;
  box-shadow:var(--shadow-lg);
}
.mock-phone .screen{
  width:100%; height:100%; border-radius:15px; overflow:hidden;
  background:var(--surface);
}
.mock-phone .ph{ height:100%; }

/* Solo phone */
.phone-solo{
  width:clamp(220px,80%,280px); aspect-ratio:9/19; margin-inline:auto;
  background:var(--ink); border-radius:34px; padding:9px; box-shadow:var(--shadow-lg);
}
.phone-solo .screen{ width:100%; height:100%; border-radius:26px; overflow:hidden; background:var(--surface); }
.phone-solo .ph{ height:100%; }

/* ---------- Work cards ---------- */
.work-row{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,28px); }
@media (max-width:880px){ .work-row{ grid-template-columns:1fr 1fr; } }
@media (max-width:600px){ .work-row{ grid-template-columns:1fr; } }
.work-card{ display:flex; flex-direction:column; }
.work-card.standalone{ transition:transform .18s ease, box-shadow .2s ease, border-color .2s ease; }
.work-card.standalone:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:var(--brand-tint-2); }
.work-card .card-pad:hover .work-meta b{ color:var(--brand-strong); }
.work-meta{ display:flex; flex-direction:column; gap:.1rem; margin-bottom:.55rem; }
.work-meta b{ font-family:var(--font-display); font-weight:900; font-size:1.18rem; color:var(--ink); }
.work-meta span{ color:var(--brand-strong); font-weight:700; font-size:.9rem; }
.work-card .ph{ aspect-ratio:16/10; }
.shot-img{ display:block; width:100%; aspect-ratio:16/10; object-fit:cover; object-position:top center; background:var(--tint); }
.support-card{ background:var(--brand-tint); border-color:var(--brand-tint-2); }

/* ---------- Portfolio (Our Work) ---------- */
.portfolio{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(22px,3vw,38px); }
@media (max-width:820px){ .portfolio{ grid-template-columns:1fr; } }
.project{ display:flex; flex-direction:column; }
.project .shot{ border-bottom:1px solid var(--line-soft); }
.project .shot .ph{ aspect-ratio:16/10; }
.project .body{ padding:clamp(22px,3vw,32px); display:flex; flex-direction:column; flex:1; }
.project .top{ display:flex; align-items:flex-start; justify-content:space-between; gap:1rem; }
.project h3{ margin-bottom:.15rem; }
.sector{
  display:inline-block; background:var(--brand-tint); color:var(--brand-deep);
  font-family:var(--font-display); font-weight:800; font-size:.78rem;
  padding:.35em .8em; border-radius:var(--pill); white-space:nowrap;
}
.project .did{ color:var(--ink-soft); margin-top:.7rem; }
.result{
  display:flex; gap:.7rem; align-items:flex-start;
  background:var(--tint); border:1px solid var(--line-soft);
  border-radius:var(--r-sm); padding:.9rem 1.1rem; margin-top:1.1rem;
}
.result .ic{ color:var(--brand); flex:none; margin-top:.15rem; }
.result p{ margin:0; font-style:italic; color:var(--ink); }
.result .by{ font-style:normal; font-weight:800; font-family:var(--font-display); color:var(--ink-soft); font-size:.86rem; margin-top:.35rem; }
.project .visit{ margin-top:auto; padding-top:1.2rem; }
.project .visit .note{ color:var(--ink-mute); font-size:.9rem; font-weight:700; }

/* ---------- Pricing (Hosting) ---------- */
.plans{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,26px); align-items:stretch; }
@media (max-width:880px){ .plans{ grid-template-columns:1fr; max-width:440px; margin-inline:auto; } }
.plan{ display:flex; flex-direction:column; padding:clamp(24px,3vw,34px); position:relative; }
.plan.featured{ border-color:var(--brand); box-shadow:var(--shadow-lg); }
.plan.featured::before{
  content:"Most popular"; position:absolute; top:-13px; left:50%; transform:translateX(-50%);
  background:var(--brand); color:var(--on-brand);
  font-family:var(--font-display); font-weight:800; font-size:.74rem; letter-spacing:.06em;
  padding:.4em 1em; border-radius:var(--pill); white-space:nowrap;
}
.plan .plan-name{ font-family:var(--font-display); font-weight:900; font-size:1.4rem; color:var(--ink); }
.plan .plan-for{ color:var(--ink-soft); font-size:.95rem; margin-top:.2rem; min-height:2.6em; }
.plan .price{ display:flex; align-items:baseline; gap:.2rem; margin:1.1rem 0 .2rem; }
.plan .price .amt{ font-family:var(--font-display); font-weight:900; font-size:3rem; line-height:1; letter-spacing:-0.02em; color:var(--ink); }
.plan .price .per{ color:var(--ink-soft); font-weight:700; }
.plan .feat{ list-style:none; margin:1.4rem 0; padding:1.4rem 0 0; border-top:1px solid var(--line-soft); display:flex; flex-direction:column; gap:.8rem; }
.plan .feat li{ display:flex; gap:.6rem; align-items:flex-start; color:var(--ink-soft); }
.plan .feat .tk{ flex:none; color:var(--brand); margin-top:.15rem; }
.plan .feat b{ color:var(--ink); font-family:var(--font-display); }
.plan .btn{ width:100%; justify-content:center; margin-top:auto; }

/* Support heart band */
.support-band{ background:var(--navy); color:var(--on-navy); border-radius:var(--r-xl); overflow:hidden; position:relative; }
.support-band .deco{ position:absolute; inset:0; pointer-events:none; background:radial-gradient(50% 70% at 88% 8%, var(--brand-deep), transparent 62%); opacity:.5; }
.support-band h2{ color:var(--on-brand); }
.support-band .lead{ color:oklch(0.84 0.012 250); }
.support-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,30px); }
@media (max-width:760px){ .support-grid{ grid-template-columns:1fr; } }
.support-item .si-ic{ width:48px; height:48px; border-radius:var(--r-sm); background:oklch(1 0 0 / 0.08); color:var(--on-brand); display:grid; place-items:center; margin-bottom:.9rem; }
.support-item h4{ color:var(--on-brand); }
.support-item p{ color:oklch(0.82 0.012 250); margin:0; }

/* ---------- Contact form ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1.25fr; gap:clamp(28px,5vw,64px); align-items:start; }
@media (max-width:880px){ .contact-grid{ grid-template-columns:1fr; gap:36px; } }
.contact-aside .lozenge{ display:flex; gap:.8rem; align-items:flex-start; margin-bottom:1.6rem; }
.contact-aside .lz-ic{ flex:none; width:44px; height:44px; border-radius:var(--r-sm); background:var(--brand-tint); color:var(--brand-strong); display:grid; place-items:center; }
.contact-aside .lz b{ font-family:var(--font-display); display:block; color:var(--ink); }
.contact-aside .lz span{ color:var(--ink-soft); font-size:.95rem; }
.contact-aside .lz a{ font-weight:800; white-space:nowrap; }

.form{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--shadow); padding:clamp(24px,3.5vw,40px); }
.field{ margin-bottom:1.15rem; }
.field label{ display:block; font-family:var(--font-display); font-weight:800; font-size:.95rem; color:var(--ink); margin-bottom:.45rem; }
.field .req{ color:var(--brand-strong); }
.field input, .field select, .field textarea{
  width:100%; font:inherit; color:var(--ink);
  background:var(--bg); border:1.5px solid var(--line);
  border-radius:var(--r-sm); padding:.85em 1em; min-height:52px;
  transition:border-color .15s ease, box-shadow .15s ease;
}
.field textarea{ min-height:120px; resize:vertical; }
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--brand);
  box-shadow:0 0 0 4px var(--brand-tint);
}
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:1.15rem; }
@media (max-width:540px){ .field-row{ grid-template-columns:1fr; gap:0; } }
.radio-row{ display:flex; gap:.7rem; flex-wrap:wrap; }
.radio-pill{ position:relative; }
.radio-pill input{ position:absolute; opacity:0; inset:0; cursor:pointer; min-height:0; }
.radio-pill span{
  display:inline-flex; align-items:center; padding:.7em 1.15em; border-radius:var(--pill);
  border:1.5px solid var(--line); font-family:var(--font-display); font-weight:700; color:var(--ink-soft);
  cursor:pointer; transition:all .14s ease;
}
.radio-pill input:checked + span{ border-color:var(--brand); background:var(--brand-tint); color:var(--brand-deep); }
.radio-pill input:focus-visible + span{ box-shadow:0 0 0 4px var(--brand-tint); }
.form .btn{ width:100%; justify-content:center; }
.form-foot{ text-align:center; color:var(--ink-mute); font-size:.88rem; margin-top:.9rem; }

.confirm{
  display:none; text-align:center; padding:clamp(34px,5vw,56px);
  background:var(--brand-tint); border:1px solid var(--brand-tint-2); border-radius:var(--r-lg);
}
.confirm.show{ display:block; }
.confirm .ok{ width:72px; height:72px; border-radius:50%; background:var(--brand); color:var(--on-brand); display:grid; place-items:center; margin:0 auto 1.2rem; box-shadow:var(--shadow); }
.confirm h3{ margin-bottom:.4rem; }

/* ---------- Testimonial ---------- */
.quote{
  font-family:var(--font-display); font-weight:800;
  font-size:clamp(1.5rem,1.1rem+1.7vw,2.4rem);
  line-height:1.28; letter-spacing:-0.015em; color:var(--ink);
}
.quote-mark{ color:var(--brand); font-size:1.1em; line-height:0; }
.cite{ display:flex; align-items:center; gap:.85rem; margin-top:1.6rem; }
.cite .avatar{ width:48px; height:48px; border-radius:50%; background:var(--brand-tint-2); display:grid; place-items:center; font-family:var(--font-display); font-weight:900; color:var(--brand-deep); }
.cite .who{ font-weight:800; font-family:var(--font-display); color:var(--ink); }
.cite .role{ color:var(--ink-soft); font-size:.92rem; }

/* ---------- CTA band ---------- */
.cta-band{
  background:linear-gradient(135deg, var(--brand-strong), var(--brand));
  color:var(--on-brand);
  border-radius:var(--r-xl);
  padding:clamp(34px,5vw,68px);
  position:relative; overflow:hidden;
}
.cta-band h2{ color:var(--on-brand); }
.cta-band p{ color:oklch(0.99 0.01 80 / 0.92); }
.cta-band .deco{
  position:absolute; inset:0; pointer-events:none; opacity:.5;
  background:radial-gradient(40% 60% at 90% 10%, oklch(1 0 0 / 0.18), transparent 60%);
}
.cta-row{ display:flex; flex-wrap:wrap; gap:.9rem; align-items:center; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--navy-deep); color:var(--on-navy); }
.site-footer a{ color:oklch(0.88 0.012 250); }
.site-footer a:hover{ color:#fff; }
.footer-grid{
  display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:clamp(28px,4vw,56px);
  padding-block:clamp(48px,6vw,72px);
}
@media (max-width:860px){ .footer-grid{ grid-template-columns:1fr 1fr; gap:36px; } }
@media (max-width:520px){ .footer-grid{ grid-template-columns:1fr; } }
.footer-brand{ display:inline-flex; align-items:center; gap:.5rem; font-family:var(--font-display); font-weight:900; font-size:1.4rem; color:#fff; }
.footer-brand .logo-mark{ width:32px; height:32px; font-size:1.15rem; }
.footer-col h4{ color:var(--on-brand); font-size:.85rem; letter-spacing:.12em; text-transform:uppercase; margin-bottom:1rem; }
.footer-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.6rem; }
.footer-contact{ font-style:normal; line-height:1.8; }
.footer-contact .big{ font-family:var(--font-display); font-weight:800; font-size:1.25rem; color:var(--on-brand); }
.footer-bottom{
  border-top:1px solid oklch(0.32 0.03 262);
  padding-block:1.4rem;
  display:flex; flex-wrap:wrap; gap:.6rem 1.4rem; justify-content:space-between; align-items:center;
  font-size:.9rem; color:oklch(0.72 0.014 250);
}

/* ---------- Utilities ---------- */
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,72px); align-items:center; }
@media (max-width:880px){ .grid-2{ grid-template-columns:1fr; gap:40px; } }
.flow > * + *{ margin-top:1rem; }
.mt-s{ margin-top:1rem; } .mt-m{ margin-top:1.6rem; } .mt-l{ margin-top:2.4rem; }
.cta-group{ display:flex; flex-wrap:wrap; gap:.9rem; }
.muted{ color:var(--ink-soft); }
.tick-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.85rem; }
.tick-list li{ display:flex; gap:.7rem; align-items:flex-start; }
.tick-list .tick{
  flex:none; width:1.55rem; height:1.55rem; border-radius:50%;
  background:var(--brand-tint); color:var(--brand-strong);
  display:grid; place-items:center; margin-top:.1rem;
}
.tick-list b{ color:var(--ink); font-family:var(--font-display); }

@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
}

/* ---------- Trust chips (hero) ---------- */
.trust-row{ display:flex; flex-wrap:wrap; gap:1rem 1.6rem; }
.trust-row.center{ justify-content:center; }
.trust-row .ti{ display:inline-flex; align-items:center; gap:.5rem; font-family:var(--font-display); font-weight:800; color:var(--ink-soft); font-size:.98rem; }
.trust-row .ti svg{ color:var(--brand); flex:none; }

/* ---------- Dark band (problem / how it works) ---------- */
.band-navy{ background:var(--navy); color:var(--on-navy); }
.band-navy h1, .band-navy h2, .band-navy h3{ color:#fff; }
.band-navy .lead{ color:oklch(0.83 0.014 250); }
.band-navy .muted{ color:oklch(0.74 0.014 250); }
.band-navy .eyebrow{ color:oklch(0.82 0.09 58); }

/* ---------- How it works steps ---------- */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(22px,3.4vw,48px); }
@media (max-width:760px){ .steps{ grid-template-columns:1fr; gap:32px; } }
.step .n{ font-family:var(--font-display); font-weight:900; font-size:clamp(2.6rem,2rem+1.6vw,3.6rem); line-height:1; color:var(--brand); }
.step h3{ margin:.5rem 0 .35rem; }
.step p{ color:oklch(0.78 0.014 250); margin:0; }

/* ---------- Feature cards (what you get) ---------- */
.features{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(18px,2.4vw,26px); }
@media (max-width:720px){ .features{ grid-template-columns:1fr; } }
.feature{ padding:clamp(24px,3vw,34px); }
.feature .f-ic{ width:54px; height:54px; border-radius:var(--r-sm); background:var(--brand-tint); color:var(--brand-strong); display:grid; place-items:center; margin-bottom:1rem; }
.feature h3{ margin-bottom:.4rem; }
.feature p{ color:var(--ink-soft); margin:0; }

/* ---------- Trades grid ---------- */
.trades{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(12px,1.6vw,18px); }
@media (max-width:880px){ .trades{ grid-template-columns:1fr 1fr; } }
@media (max-width:460px){ .trades{ grid-template-columns:1fr; } }
.trade{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-sm); padding:1.05rem 1.2rem; transition:border-color .15s ease, transform .15s ease, box-shadow .15s ease; }
.trade:hover{ border-color:var(--brand-tint-2); transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.trade b{ font-family:var(--font-display); font-weight:800; display:block; color:var(--ink); }
.trade span{ color:var(--ink-mute); font-size:.9rem; }

/* ---------- Testimonial cards ---------- */
.tcards{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(18px,2.4vw,26px); }
@media (max-width:760px){ .tcards{ grid-template-columns:1fr; } }
.tcard{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(24px,3vw,34px); box-shadow:var(--shadow-sm); }
.tcard p{ font-style:italic; color:var(--ink); font-size:1.05rem; line-height:1.6; margin:0; }
.tcard .by{ font-family:var(--font-display); font-weight:800; color:var(--brand-strong); margin-top:1rem; }

/* ---------- Pricing teaser ---------- */
.pricing-teaser .big{ font-family:var(--font-display); font-weight:900; font-size:clamp(1.3rem,1rem+1.4vw,1.95rem); color:var(--ink); }
.pricing-teaser .big b{ color:var(--brand-strong); }

/* ---------- Tweaks panel ---------- */
.tw-panel{
  position:fixed; right:18px; bottom:18px; z-index:2000;
  width:300px; max-width:calc(100vw - 36px);
  background:var(--surface); color:var(--ink);
  border:1px solid var(--line); border-radius:var(--r);
  box-shadow:var(--shadow-lg);
  font-family:var(--font-body); display:none; overflow:hidden;
}
.tw-panel.open{ display:block; }
.tw-head{ display:flex; align-items:center; gap:.6rem; padding:.85rem 1rem; border-bottom:1px solid var(--line-soft); background:var(--tint); cursor:grab; }
.tw-head .tw-dot{ width:.6rem; height:.6rem; border-radius:50%; background:var(--brand); }
.tw-head h5{ margin:0; font-family:var(--font-display); font-weight:900; font-size:1rem; }
.tw-head .tw-x{ margin-left:auto; width:28px; height:28px; border:0; background:transparent; border-radius:8px; cursor:pointer; color:var(--ink-soft); display:grid; place-items:center; }
.tw-head .tw-x:hover{ background:var(--line-soft); color:var(--ink); }
.tw-body{ padding:.9rem 1rem 1.1rem; max-height:min(70vh,560px); overflow:auto; }
.tw-sec{ font-family:var(--font-display); font-weight:800; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--brand-strong); margin:.9rem 0 .6rem; }
.tw-sec:first-child{ margin-top:0; }
.tw-field{ margin-bottom:.85rem; }
.tw-field label{ display:block; font-weight:700; font-size:.85rem; color:var(--ink-soft); margin-bottom:.35rem; }
.tw-field input[type="text"], .tw-field textarea{
  width:100%; font:inherit; font-size:.92rem; color:var(--ink);
  background:var(--bg); border:1.5px solid var(--line); border-radius:10px; padding:.55em .7em;
}
.tw-field textarea{ resize:vertical; min-height:64px; line-height:1.4; }
.tw-field input:focus, .tw-field textarea:focus{ outline:none; border-color:var(--brand); box-shadow:0 0 0 3px var(--brand-tint); }
.tw-step{ display:flex; align-items:center; gap:.5rem; }
.tw-step button{ width:36px; height:36px; flex:none; border:1.5px solid var(--line); background:var(--bg); border-radius:10px; font-size:1.2rem; font-weight:800; color:var(--ink); cursor:pointer; line-height:1; }
.tw-step button:hover{ border-color:var(--brand); color:var(--brand-strong); }
.tw-step .tw-val{ flex:1; text-align:center; font-family:var(--font-display); font-weight:900; font-size:1.1rem; }
.tw-step .tw-pre{ color:var(--ink-soft); font-weight:700; }
.tw-reset{ width:100%; margin-top:.4rem; padding:.6em; border:1.5px solid var(--line); background:var(--bg); border-radius:10px; font-family:var(--font-display); font-weight:800; font-size:.85rem; color:var(--ink-soft); cursor:pointer; }
.tw-reset:hover{ border-color:var(--brand); color:var(--brand-strong); }
