/* ============================================================
   Vilina Commerce — shared stylesheet
   Brand: deep teal #225B64 + warm orange #F1864E
   Type:  Schibsted Grotesk (display) / Hanken Grotesk (body)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700&family=Schibsted+Grotesk:wght@500;600;700;800;900&display=swap');

:root{
  --teal:#225B64;
  --teal-deep:#143A41;
  --teal-700:#1C4C54;
  --teal-soft:#3B7882;
  --orange:#F1864E;
  --orange-deep:#DD6E32;
  --orange-soft:#FBE7D7;

  --bg:#FBF7F1;
  --bg-warm:#F4ECE2;
  --surface:#FFFFFF;
  --ink:#16343A;
  --body:#3D5358;
  --muted:#6A7E83;
  --line:rgba(34,91,100,.14);
  --line-strong:rgba(34,91,100,.24);

  --radius:18px;
  --radius-sm:12px;
  --radius-lg:28px;
  --shadow:0 1px 2px rgba(20,58,65,.04), 0 18px 40px -24px rgba(20,58,65,.28);
  --shadow-soft:0 1px 2px rgba(20,58,65,.04), 0 10px 30px -20px rgba(20,58,65,.22);

  --maxw:1200px;
  --pad:clamp(20px,5vw,64px);

  --display:'Schibsted Grotesk',system-ui,sans-serif;
  --text:'Hanken Grotesk',system-ui,sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--text);
  color:var(--body);
  background:var(--bg);
  font-size:17px;
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

h1,h2,h3,h4{
  font-family:var(--display);
  color:var(--ink);
  line-height:1.05;
  margin:0;
  letter-spacing:-.02em;
  font-weight:800;
}
p{margin:0;}
.text-pretty{text-wrap:pretty;}

/* ---- layout helpers ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);}
.wrap-narrow{max-width:840px;margin:0 auto;padding-inline:var(--pad);}
.section{padding-block:clamp(64px,9vw,128px);}
.section-sm{padding-block:clamp(48px,6vw,80px);}

.eyebrow{
  font-family:var(--text);
  font-weight:700;
  font-size:13px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--orange-deep);
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin:0;
}
.eyebrow::before{
  content:"";width:24px;height:2px;background:var(--orange);border-radius:2px;
}
.eyebrow.center::before{display:none;}

.lead{font-size:clamp(18px,2.2vw,21px);color:var(--body);line-height:1.6;}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--text);font-weight:700;font-size:15.5px;
  padding:14px 26px;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease,border-color .18s ease;
  white-space:nowrap;
}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 12px 24px -12px rgba(221,110,50,.7);}
.btn-primary:hover{background:var(--orange-deep);transform:translateY(-2px);}
.btn-teal{background:var(--teal);color:#fff;}
.btn-teal:hover{background:var(--teal-deep);transform:translateY(-2px);}
.btn-ghost{background:transparent;color:var(--teal);border-color:var(--line-strong);}
.btn-ghost:hover{border-color:var(--teal);background:rgba(34,91,100,.05);}
.btn-white{background:#fff;color:var(--teal);}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 16px 30px -16px rgba(0,0,0,.4);}
.btn-outline-white{background:transparent;color:#fff;border-color:rgba(255,255,255,.45);}
.btn-outline-white:hover{border-color:#fff;background:rgba(255,255,255,.1);}

.arrow{transition:transform .18s ease;}
.btn:hover .arrow{transform:translateX(3px);}

/* ---- store badges ---- */
.stores{display:flex;flex-wrap:wrap;gap:12px;}
.store-badge{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--teal-deep);color:#fff;
  padding:10px 20px 10px 18px;border-radius:14px;
  transition:transform .18s ease,background .18s ease;
}
.store-badge:hover{transform:translateY(-2px);background:#0F2D33;}
.store-badge svg{width:24px;height:24px;flex:none;}
.store-badge .sb-small{font-size:10.5px;letter-spacing:.04em;opacity:.78;line-height:1;text-transform:uppercase;}
.store-badge .sb-big{font-family:var(--display);font-weight:700;font-size:17px;line-height:1.15;}
.stores.on-dark .store-badge{background:#fff;color:var(--teal-deep);}
.stores.on-dark .store-badge:hover{background:var(--bg);}

/* ============================================================
   NAVBAR
   ============================================================ */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(251,247,241,.82);
  backdrop-filter:saturate(1.4) blur(14px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:var(--maxw);margin:0 auto;padding:14px var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.nav-logo{display:flex;align-items:center;}
.nav-logo img{width: 160px;}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0;}
.nav-links a{
  font-weight:600;font-size:15px;color:var(--teal-700);
  padding:9px 14px;border-radius:10px;transition:background .16s ease,color .16s ease;
}
.nav-links a:hover{background:rgba(34,91,100,.07);color:var(--teal-deep);}
.nav-links a.active{color:var(--orange-deep);}
.nav-cta{display:flex;align-items:center;gap:10px;}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;}
.nav-toggle svg{width:26px;height:26px;color:var(--teal);}

@media(max-width:980px){
  .nav-links,.nav-cta .btn{display:none;}
  .nav-toggle{display:inline-flex;}
  .nav-links.open{
    display:flex;flex-direction:column;align-items:stretch;gap:2px;
    position:absolute;top:100%;left:0;right:0;
    background:var(--bg);border-bottom:1px solid var(--line);
    padding:14px var(--pad);box-shadow:var(--shadow);
  }
  .nav-links.open a{padding:13px 14px;font-size:16px;}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;overflow:hidden;}
.hero-grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);
  align-items:center;padding-block:clamp(56px,7vw,104px);
}
.hero h1{font-size:clamp(40px,6vw,72px);font-weight:900;color:var(--teal-deep);}
.hero h1 .accent{color:var(--orange);}
.hero .lead{margin-top:24px;max-width:46ch;}
.hero-actions{margin-top:34px;display:flex;flex-wrap:wrap;gap:14px;align-items:center;}
.hero-meta{margin-top:30px;display:flex;flex-wrap:wrap;gap:26px;}
.hero-meta .hm{display:flex;flex-direction:column;gap:2px;}
.hero-meta .hm b{font-family:var(--display);font-size:24px;color:var(--teal);font-weight:800;}
.hero-meta .hm span{font-size:13.5px;color:var(--muted);}

/* page hero (interior pages) */
.page-hero{padding-block:clamp(56px,7vw,96px) clamp(8px,3vw,32px);}
.page-hero h1{font-size:clamp(36px,5.2vw,60px);font-weight:900;color:var(--teal-deep);}
.page-hero .lead{margin-top:22px;max-width:60ch;}

/* ---- decorative blobs ---- */
.blob{position:absolute;border-radius:50%;filter:blur(8px);opacity:.5;pointer-events:none;z-index:0;}

/* ============================================================
   PLACEHOLDER IMAGE BOXES
   ============================================================ */
.ph{
  position:relative;border-radius:var(--radius);overflow:hidden;
  background:
    repeating-linear-gradient(135deg,rgba(34,91,100,.05) 0 14px,rgba(34,91,100,.09) 14px 28px);
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;text-align:center;
  color:var(--teal-700);
}
.ph::after{
  content:attr(data-label);
  font-family:'Hanken Grotesk',monospace;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:12px;letter-spacing:.04em;color:var(--teal-soft);
  background:rgba(251,247,241,.85);padding:7px 12px;border-radius:8px;
  border:1px solid var(--line);max-width:80%;
}
.ph-phone{aspect-ratio:9/16;border-radius:34px;border:2px solid var(--teal-deep);background-color:#fff;}
.ph-tall{aspect-ratio:4/5;}
.ph-wide{aspect-ratio:16/10;}
.ph-square{aspect-ratio:1/1;}

/* ============================================================
   CARDS / GRIDS
   ============================================================ */
.grid{display:grid;gap:22px;}
.cols-2{grid-template-columns:repeat(2,1fr);}
.cols-3{grid-template-columns:repeat(3,1fr);}
.cols-4{grid-template-columns:repeat(4,1fr);}
@media(max-width:900px){.cols-3,.cols-4{grid-template-columns:repeat(2,1fr);}}
@media(max-width:620px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr;}}

.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px;box-shadow:var(--shadow-soft);transition:transform .2s ease,box-shadow .2s ease;
  height:100%;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.card h3{font-size:21px;margin-bottom:10px;font-weight:700;}
.card p{font-size:15.5px;color:var(--body);}

.icon-badge{
  width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  background:var(--orange-soft);color:var(--orange-deep);margin-bottom:20px;
}
.icon-badge.teal{background:rgba(34,91,100,.1);color:var(--teal);}
.icon-badge svg{width:26px;height:26px;}

.section-head{max-width:640px;margin-bottom:clamp(36px,5vw,56px);}
.section-head.center{margin-inline:auto;text-align:center;}
.section-head h2{font-size:clamp(30px,4vw,46px);margin-top:16px;font-weight:800;}
.section-head .lead{margin-top:18px;}

/* tone bands */
.band-teal{background:var(--teal-deep);color:#D9E6E8;}
.band-teal h1,.band-teal h2,.band-teal h3{color:#fff;}
.band-teal .lead{color:#BFD4D7;}
.band-teal .eyebrow{color:var(--orange);}
.band-warm{background:var(--bg-warm);}

/* feature split row */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,80px);align-items:center;}
.split.reverse .split-media{order:-1;}
@media(max-width:840px){.split{grid-template-columns:1fr;}.split.reverse .split-media{order:0;}}
.split h2{font-size:clamp(26px,3.4vw,40px);font-weight:800;margin-bottom:18px;}

/* numbered list */
.steps{display:grid;gap:18px;counter-reset:step;}
.step{display:flex;gap:18px;align-items:flex-start;}
.step .num{
  flex:none;width:40px;height:40px;border-radius:50%;background:var(--teal);color:#fff;
  font-family:var(--display);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:16px;
}
.step h4{font-size:18px;margin-bottom:4px;}
.step p{font-size:15px;}

/* audience pills */
.pills{display:flex;flex-wrap:wrap;gap:10px;}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--surface);border:1px solid var(--line);border-radius:999px;
  padding:9px 18px;font-weight:600;font-size:14.5px;color:var(--teal-700);
}
.pill .dot{width:8px;height:8px;border-radius:50%;background:var(--orange);}
.band-teal .pill{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.16);color:#EAF1F2;}

/* stat row */
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
@media(max-width:680px){.stat-row{grid-template-columns:1fr;}}
.stat b{display:block;font-family:var(--display);font-weight:900;font-size:clamp(34px,4vw,52px);color:var(--orange);line-height:1;}
.stat span{display:block;margin-top:10px;color:var(--body);font-size:15px;}
.band-teal .stat span{color:#BFD4D7;}

/* CTA band */
.cta-band{
  background:linear-gradient(135deg,var(--teal) 0%,var(--teal-deep) 100%);
  border-radius:var(--radius-lg);padding:clamp(40px,6vw,72px);
  text-align:center;color:#fff;position:relative;overflow:hidden;
}
.cta-band h2{color:#fff;font-size:clamp(28px,4vw,44px);max-width:18ch;margin:0 auto 18px;font-weight:800;}
.cta-band p{color:#C6DADC;max-width:52ch;margin:0 auto 30px;}
.cta-band .cta-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;}
.cta-band .ring{position:absolute;border:2px solid rgba(241,134,78,.25);border-radius:50%;}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--teal-deep);color:#A9C3C7;padding-block:64px 32px;}
.footer a{color:#A9C3C7;transition:color .16s ease;}
.footer a:hover{color:#fff;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;}
@media(max-width:860px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px;}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr;}}
.footer-logo{height:42px;width:auto;margin-bottom:18px;filter:brightness(0) invert(1);opacity:.95;}
.footer .tag{font-size:15px;max-width:34ch;line-height:1.6;}
.footer h5{font-family:var(--display);color:#fff;font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin:0 0 16px;font-weight:700;}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px;font-size:15px;}
.footer .contact-line{display:flex;gap:10px;align-items:flex-start;font-size:15px;margin-bottom:12px;}
.footer .contact-line svg{width:18px;height:18px;flex:none;margin-top:3px;color:var(--orange);}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);margin-top:48px;padding-top:24px;
  display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;font-size:13.5px;color:#7F9CA0;
}

/* ---- contact blocks ---- */
.contact-block{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--line);}
.contact-block .cb-icon{
  flex:none;width:44px;height:44px;border-radius:12px;background:var(--orange-soft);color:var(--orange-deep);
  display:flex;align-items:center;justify-content:center;
}
.contact-block .cb-icon svg{width:22px;height:22px;}
.cb-label{font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:3px;}
.cb-value{font-family:var(--display);font-weight:700;font-size:17px;color:var(--ink);}
a.cb-value:hover{color:var(--orange-deep);}
.cb-sub{font-size:14px;color:var(--muted);margin-top:2px;}
.contact-block .stores{margin-top:12px;}

/* ---- form ---- */
.field{margin-bottom:18px;}
.field label{display:block;font-size:13.5px;font-weight:700;color:var(--teal-700);margin-bottom:7px;}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--text);font-size:15.5px;color:var(--ink);
  background:var(--bg);border:1.5px solid var(--line);border-radius:12px;
  padding:12px 14px;transition:border-color .16s ease,box-shadow .16s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(34,91,100,.12);background:#fff;
}
.field textarea{resize:vertical;min-height:96px;}
.form-note{
  display:none;margin-top:16px;padding:13px 16px;border-radius:12px;
  background:rgba(34,91,100,.08);color:var(--teal-deep);font-size:14.5px;font-weight:600;
}
.form-note.show{display:block;}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}
