/* ============ Vicinto — marketing site ============ */
:root{
  --ink:#101319;
  --bg:#faf7f2;
  --bg-2:#f4efe6;
  --line:#e9e5dc;
  --coral:#ff5a4e;
  --coral-dark:#e8473b;
  --coral-soft:#ffeae8;
  --teal:#0e7c6b;
  --teal-soft:#e7f4f1;
  --amber:#eb9b2d;
  --violet:#6a5cff;
  --muted:#6e7480;
  --r-lg:22px;
  --shadow-sm:0 1px 3px rgba(16,19,25,.06);
  --shadow-md:0 10px 34px rgba(16,19,25,.10);
  --shadow-lg:0 24px 60px rgba(16,19,25,.16);
  --maxw:1120px;
  color-scheme:light;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.eyebrow{font-weight:800;letter-spacing:.14em;text-transform:uppercase;font-size:.74rem;color:var(--coral-dark)}

/* ---------- wordmark ---------- */
.wordmark{display:inline-flex;align-items:center;gap:9px;font-weight:850;font-size:1.28rem;letter-spacing:-.02em}
.wordmark .pin{width:26px;height:26px;flex:0 0 auto;position:static;transform:none;border-radius:0;box-shadow:none}
.wordmark .w{color:var(--ink)}
.wordmark .w .to{color:var(--coral)}

/* ---------- header ---------- */
.site-head{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(1.4) blur(14px);
  -webkit-backdrop-filter:saturate(1.4) blur(14px);
  background:rgba(250,247,242,.72);
  border-bottom:1px solid transparent;
  transition:border-color .3s ease, background .3s ease;
}
.site-head.scrolled{border-color:var(--line);background:rgba(250,247,242,.9)}
.site-head .row{display:flex;align-items:center;justify-content:space-between;height:68px}
.nav{display:flex;align-items:center;gap:26px}
.nav a{font-weight:650;font-size:.94rem;color:var(--muted);transition:color .2s}
.nav a:hover{color:var(--ink)}
.pill{
  display:inline-flex;align-items:center;gap:7px;font-weight:750;font-size:.8rem;
  padding:7px 13px;border-radius:99px;border:1px solid var(--line);background:#fff;color:var(--ink)
}
.pill .dot{width:8px;height:8px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 0 rgba(14,124,107,.5);animation:ping 2.4s infinite}
@keyframes ping{0%{box-shadow:0 0 0 0 rgba(14,124,107,.45)}70%{box-shadow:0 0 0 9px rgba(14,124,107,0)}100%{box-shadow:0 0 0 0 rgba(14,124,107,0)}}
.nav-hide{display:flex}
@media(max-width:720px){.nav-hide{display:none}}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:750;font-size:.96rem;border:none;cursor:pointer;
  padding:13px 22px;border-radius:99px;font-family:inherit;transition:transform .16s ease, box-shadow .25s ease, background .2s}
.btn:active{transform:scale(.97)}
.btn.primary{background:var(--coral);color:#fff;box-shadow:0 10px 24px rgba(255,90,78,.32)}
.btn.primary:hover{background:var(--coral-dark);box-shadow:0 14px 30px rgba(255,90,78,.4)}
.btn.ghost{background:#fff;color:var(--ink);border:1.5px solid var(--line)}
.btn.ghost:hover{border-color:var(--coral)}

/* ---------- hero ---------- */
.hero{position:relative;padding:64px 0 40px;overflow:hidden}
.aurora{position:absolute;inset:-10% -10% auto -10%;height:680px;z-index:0;filter:blur(60px);opacity:.7;pointer-events:none}
.aurora span{position:absolute;border-radius:50%;mix-blend-mode:multiply;opacity:.5}
.aurora .a1{width:520px;height:520px;background:radial-gradient(circle,#ffd0cb,transparent 65%);top:-60px;left:-40px;animation:float1 16s ease-in-out infinite}
.aurora .a2{width:480px;height:480px;background:radial-gradient(circle,#c7efe6,transparent 65%);top:20px;right:-30px;animation:float2 19s ease-in-out infinite}
.aurora .a3{width:420px;height:420px;background:radial-gradient(circle,#ffe6c2,transparent 65%);top:180px;left:38%;animation:float3 22s ease-in-out infinite}
@keyframes float1{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,30px)}}
@keyframes float2{0%,100%{transform:translate(0,0)}50%{transform:translate(-36px,26px)}}
@keyframes float3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(20px,-24px) scale(1.08)}}

.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:38px;align-items:center}
@media(max-width:880px){.hero-grid{grid-template-columns:1fr;gap:30px}}
.hero h1{font-size:clamp(2.5rem,6vw,4.1rem);line-height:1.02;letter-spacing:-.03em;margin:14px 0 0;font-weight:850}
.hero h1 .grad{color:var(--coral)}
.hero .lede{font-size:1.16rem;color:var(--muted);max-width:30ch;margin:18px 0 26px;line-height:1.5}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.store-badge{
  display:inline-flex;align-items:center;gap:11px;background:var(--ink);color:#fff;border-radius:15px;
  padding:11px 18px;box-shadow:var(--shadow-md);transition:transform .18s ease
}
.store-badge:hover{transform:translateY(-2px)}
.store-badge .apple{width:24px;height:24px}
.store-badge .s1{font-size:.62rem;opacity:.8;letter-spacing:.02em}
.store-badge .s2{font-size:1.02rem;font-weight:750;margin-top:-2px}
.trust{display:flex;gap:18px;margin-top:24px;flex-wrap:wrap}
.trust div{font-size:.84rem;color:var(--muted)}
.trust b{color:var(--ink)}

/* ---------- hero phone / map ---------- */
.device{
  position:relative;z-index:2;justify-self:center;width:300px;height:620px;border-radius:46px;
  background:#0e1014;padding:13px;box-shadow:var(--shadow-lg);
  transform:rotate(-2.5deg);transition:transform .4s cubic-bezier(.22,1,.36,1)
}
.device:hover{transform:rotate(0deg) translateY(-6px)}
.device .island{position:absolute;top:22px;left:50%;transform:translateX(-50%);width:92px;height:27px;background:#0e1014;border-radius:99px;z-index:7}
.screen{position:relative;width:100%;height:100%;border-radius:34px;overflow:hidden;background:linear-gradient(180deg,#eef5f3,#f6f1ea)}
.map-canvas{position:absolute;inset:0;background:
  radial-gradient(120px 120px at 22% 18%,#e7f4f1,transparent 70%),
  radial-gradient(160px 160px at 80% 70%,#ffeae8,transparent 70%),
  linear-gradient(180deg,#eaf2ef,#f3ede4)}
.map-canvas::before{content:"";position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(rgba(14,124,107,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(14,124,107,.07) 1px,transparent 1px);
  background-size:34px 34px}
.road{position:absolute;background:#fff;opacity:.85;border-radius:6px}
.r1{top:36%;left:-4%;width:108%;height:9px;transform:rotate(-7deg)}
.r2{top:8%;left:30%;width:9px;height:90%;transform:rotate(6deg)}
.r3{top:62%;left:-4%;width:108%;height:8px;transform:rotate(4deg)}
.pin{position:absolute;width:18px;height:18px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 4px 10px rgba(0,0,0,.18)}
.pin::after{content:"";position:absolute;inset:5px;background:#fff;border-radius:50%}
.pin.coral{background:var(--coral)}.pin.teal{background:var(--teal)}.pin.amber{background:var(--amber)}
.ring{position:absolute;border-radius:50%;border:2px solid;opacity:.0;animation:ripple 3s ease-out infinite}
.ring.coral{border-color:var(--coral)}.ring.teal{border-color:var(--teal)}.ring.amber{border-color:var(--amber)}
@keyframes ripple{0%{width:14px;height:14px;opacity:.55;transform:translate(-50%,-50%) scale(.4)}70%{opacity:0}100%{width:70px;height:70px;opacity:0;transform:translate(-50%,-50%) scale(1)}}
.float{animation:bob 5s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.pin.big{width:25px;height:25px}
.pin.big::after{inset:7px}

/* ---- in-phone app chrome (real platform view) ---- */
.app-top{position:absolute;top:60px;left:11px;right:11px;z-index:5;display:flex;align-items:flex-start;justify-content:space-between}
.app-logo{display:inline-flex;align-items:center;gap:5px;background:#fff;border-radius:99px;padding:6px 12px 6px 8px;box-shadow:0 5px 14px rgba(16,19,25,.12);font-weight:850;font-size:.82rem;letter-spacing:-.01em}
.app-logo-ic{width:18px;height:18px;flex:0 0 auto}
.al-w{color:var(--ink)} .al-w span{color:var(--coral)}
.app-filter{display:inline-flex;align-items:center;gap:5px;background:#fff;border-radius:99px;padding:6px 12px;box-shadow:0 5px 14px rgba(16,19,25,.12);font-weight:750;font-size:.74rem;color:var(--ink)}
.app-filter svg{width:13px;height:13px}
.app-city{position:absolute;top:98px;left:11px;z-index:5;display:inline-flex;align-items:center;gap:6px;background:#fff;border-radius:99px;padding:6px 11px;box-shadow:0 5px 14px rgba(16,19,25,.12);font-weight:800;font-size:.76rem}
.app-city .cdot{width:8px;height:8px;border-radius:50%;background:var(--coral)}
.app-city svg{width:12px;height:12px;color:var(--muted)}

.pop-card{position:absolute;left:50%;top:48%;transform:translate(-50%,-52%);width:202px;background:#fff;border-radius:16px;padding:14px;box-shadow:0 20px 44px rgba(16,19,25,.24);z-index:6}
.pop-x{position:absolute;top:9px;right:11px;color:var(--muted);font-size:1.05rem;line-height:1}
.pop-top{display:flex;gap:9px;align-items:center}
.pop-av{width:34px;height:34px;border-radius:50%;background:var(--coral-soft);color:var(--coral-dark);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.74rem;flex:0 0 auto}
.pop-id b{font-size:.84rem;display:block;letter-spacing:-.01em}
.pop-id span{font-size:.72rem;color:var(--muted)}
.pop-tags{display:flex;gap:6px;margin:10px 0 9px}
.tg{font-size:.64rem;font-weight:800;padding:3px 8px;border-radius:99px}
.tg.biz{background:var(--teal-soft);color:var(--teal)}
.tg.conv{background:var(--coral-soft);color:var(--coral-dark)}
.pop-need{font-size:.73rem;font-weight:750;color:var(--teal);line-height:1.3;margin-bottom:12px}
.pop-actions{display:flex;gap:7px}
.pb{flex:1;text-align:center;font-size:.73rem;font-weight:800;padding:8px 0;border-radius:10px}
.pb.ghost{border:1.5px solid var(--coral);color:var(--coral-dark)}
.pb.solid{background:var(--coral);color:#fff}

.app-tabs{position:absolute;left:11px;right:11px;bottom:12px;z-index:5;display:flex;justify-content:space-between;background:rgba(255,255,255,.96);border-radius:18px;padding:9px 6px;box-shadow:0 8px 22px rgba(16,19,25,.14);backdrop-filter:blur(6px)}
.app-tabs .tab{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1;font-size:.56rem;font-weight:700;color:var(--muted)}
.app-tabs .tab svg{width:17px;height:17px}
.app-tabs .tab.on{color:var(--coral)}

/* ---------- sections ---------- */
section{position:relative}
.band{padding:78px 0}
.band.alt{background:linear-gradient(180deg,#fff,var(--bg-2))}
.sec-head{max-width:620px;margin-bottom:40px}
.sec-head h2{font-size:clamp(1.9rem,4vw,2.7rem);letter-spacing:-.025em;line-height:1.06;margin:10px 0 0;font-weight:850}
.sec-head p{color:var(--muted);font-size:1.08rem;margin:14px 0 0;line-height:1.5}

/* ---------- iridescent feature cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:880px){.cards{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.cards{grid-template-columns:1fr}}
.irid{
  position:relative;border-radius:var(--r-lg);padding:2px;
  background:linear-gradient(150deg,#fff,#fff);
  transition:transform .25s cubic-bezier(.22,1,.36,1), box-shadow .35s ease;
  transform-style:preserve-3d;will-change:transform
}
.irid::before{ /* shifting holographic border */
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;
  background:conic-gradient(from var(--ang,120deg),
     var(--coral),var(--amber),var(--teal),var(--violet),var(--coral));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.45;transition:opacity .35s ease;animation:spin 9s linear infinite
}
@keyframes spin{to{--ang:480deg}}
.irid:hover::before{opacity:1}
.irid .inner{
  position:relative;z-index:2;border-radius:calc(var(--r-lg) - 2px);background:#fff;
  padding:26px 24px 24px;height:100%;overflow:hidden
}
.irid .inner::after{ /* cursor sheen */
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(240px 240px at var(--mx,50%) var(--my,0%),
     rgba(255,255,255,.0),transparent 60%),
     radial-gradient(420px 320px at var(--mx,50%) var(--my,0%),
     color-mix(in srgb,var(--accent,var(--coral)) 16%, transparent),transparent 62%);
  opacity:0;transition:opacity .3s ease
}
.irid:hover .inner::after{opacity:1}
.irid:hover{box-shadow:var(--shadow-lg)}
.f-ico{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;
  background:color-mix(in srgb,var(--accent,var(--coral)) 14%, #fff);color:var(--accent,var(--coral))}
.f-ico svg{width:25px;height:25px}
.irid h3{font-size:1.16rem;margin:0 0 7px;letter-spacing:-.01em}
.irid p{color:var(--muted);font-size:.96rem;line-height:1.5;margin:0}

/* ---------- steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:s}
@media(max-width:760px){.steps{grid-template-columns:1fr}}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px 22px}
.step .n{width:38px;height:38px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;margin-bottom:14px}
.step h3{margin:0 0 6px;font-size:1.1rem}
.step p{margin:0;color:var(--muted);line-height:1.5;font-size:.96rem}

/* ---------- cities marquee ---------- */
.cities{overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee{display:flex;gap:14px;width:max-content;animation:slide 26s linear infinite}
.marquee:hover{animation-play-state:paused}
@keyframes slide{to{transform:translateX(-50%)}}
.city-chip{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:99px;padding:12px 20px;font-weight:750;white-space:nowrap;box-shadow:var(--shadow-sm)}
.city-chip .d{width:9px;height:9px;border-radius:50%}

/* ---------- privacy band ---------- */
.priv{display:grid;grid-template-columns:1.1fr .9fr;gap:34px;align-items:center}
@media(max-width:820px){.priv{grid-template-columns:1fr}}
.priv-card{background:linear-gradient(160deg,#0e7c6b,#0b5f53);color:#fff;border-radius:26px;padding:30px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.priv-card .blur-ring{position:absolute;width:200px;height:200px;border-radius:50%;border:2px dashed rgba(255,255,255,.35);top:-40px;right:-40px}
.priv-card h3{margin:0 0 8px;font-size:1.3rem}
.priv-card ul{margin:14px 0 0;padding:0;list-style:none}
.priv-card li{display:flex;gap:10px;align-items:flex-start;margin:11px 0;font-size:.98rem;line-height:1.4}
.priv-card li svg{flex:0 0 auto;margin-top:2px}

/* ---------- final CTA ---------- */
.final{text-align:center;padding:84px 0}
.final h2{font-size:clamp(2rem,5vw,3rem);letter-spacing:-.03em;margin:0 0 10px;font-weight:850}
.final p{color:var(--muted);font-size:1.12rem;margin:0 0 26px}

/* ---------- footer ---------- */
.site-foot{background:#fff;border-top:1px solid var(--line);padding:54px 0 40px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
@media(max-width:720px){.foot-grid{grid-template-columns:1fr 1fr}}
.foot-grid .col h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:0 0 14px}
.foot-grid .col a{display:block;color:var(--ink);font-weight:600;margin:9px 0;font-size:.96rem;transition:color .2s}
.foot-grid .col a:hover{color:var(--coral-dark)}
.foot-tag{color:var(--muted);font-size:.95rem;max-width:30ch;margin:14px 0 0;line-height:1.5}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin-top:36px;padding-top:22px;border-top:1px solid var(--line);color:var(--muted);font-size:.86rem}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .7s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}.reveal[data-d="3"]{transition-delay:.24s}.reveal[data-d="4"]{transition-delay:.32s}

/* ---------- legal pages ---------- */
.legal-wrap{max-width:760px;margin:0 auto;padding:40px 22px 80px}
.legal-wrap .back{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-weight:650;margin-bottom:22px}
.legal-wrap .back:hover{color:var(--ink)}
.legal-wrap h1{font-size:clamp(1.9rem,4vw,2.5rem);letter-spacing:-.02em;margin:0}
.legal-wrap .sub{color:var(--muted);margin:6px 0 24px}
.legal-wrap h2{font-size:1.18rem;margin:30px 0 6px;letter-spacing:-.01em}
.legal-wrap p{line-height:1.65;color:#2b2f38;margin:8px 0}
.legal-wrap a[href^="mailto"],.legal-wrap .strong{font-weight:750;color:var(--coral-dark)}
.legal-wrap table{width:100%;border-collapse:collapse;margin:14px 0}
.legal-wrap th,.legal-wrap td{border:1px solid var(--line);padding:10px 12px;text-align:left;font-size:.95rem}
.legal-wrap th{background:var(--bg-2)}
.legal-head{border-bottom:1px solid var(--line);background:rgba(250,247,242,.9);position:sticky;top:0;z-index:20;backdrop-filter:blur(12px)}
.legal-head .row{display:flex;align-items:center;justify-content:space-between;height:64px;max-width:760px;margin:0 auto;padding:0 22px}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .device{transform:none}
}
