/* Smiley Pay Limited — public site styles */
:root{
  --butter:#FFD43A;
  --butter-deep:#F5C422;
  --ink:#14120E;
  --ink-soft:rgba(20,18,14,.64);
  --ink-faint:rgba(20,18,14,.14);
  --paper:#FBF7EC;
  --coral:#FF5C39;
  --verified:#1E9E5A;
  --radius:14px;
  --maxw:1180px;
  --disp:"Bricolage Grotesque",system-ui,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;
}
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--disp);
  font-weight:400;
  background:var(--butter);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
::selection{ background:var(--ink); color:var(--butter); }
a{ color:inherit; }
img,svg{ display:block; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.mono{ font-family:var(--mono); }
.eyebrow{
  font-family:var(--mono); font-size:12px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink-soft);
}
:focus-visible{ outline:3px solid var(--ink); outline-offset:3px; border-radius:4px; }
.skip-link{
  position:absolute; left:-9999px; top:0; z-index:100;
  background:var(--ink); color:var(--butter); padding:10px 18px;
  font-weight:700; text-decoration:none; border-radius:0 0 8px 0;
}
.skip-link:focus{ left:0; }

/* ---------- nav ---------- */
nav.site-nav{
  position:sticky; top:0; z-index:50;
  background:var(--butter);
  border-bottom:2px solid var(--ink);
}
.nav-inner{
  display:flex; align-items:center; gap:30px;
  height:66px;
}
.wordmark{
  font-weight:800; font-size:21px; letter-spacing:-.02em;
  text-decoration:none; display:flex; flex-direction:column; line-height:1;
}
.wordmark svg{ margin-top:3px; }
.nav-links{ display:flex; gap:24px; margin-left:auto; align-items:center; }
.nav-links a{
  text-decoration:none; font-size:15px; font-weight:500;
  border-bottom:2px solid transparent; padding:4px 0;
}
.nav-links a:hover{ border-bottom-color:var(--ink); }
.nav-toggle{
  display:none; margin-left:auto; background:none; border:2px solid var(--ink);
  border-radius:8px; padding:8px 10px; cursor:pointer; font-family:var(--mono);
  font-size:12px; letter-spacing:.1em;
}
.btn{
  display:inline-block; font-family:var(--disp); font-weight:700; font-size:15px;
  background:var(--ink); color:var(--butter);
  padding:12px 22px; border-radius:999px; text-decoration:none;
  border:2px solid var(--ink); cursor:pointer;
  transition:transform .12s ease, background .12s ease, color .12s ease;
}
.btn:hover{ transform:translateY(-2px); }
.btn.ghost{ background:transparent; color:var(--ink); }
.btn.ghost:hover{ background:var(--ink); color:var(--butter); }
.btn.coral{ background:var(--coral); border-color:var(--coral); color:#fff; }

/* ---------- hero ---------- */
header.hero{ padding:84px 0 72px; overflow:hidden; }
.hero-grid{
  display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center;
}
h1{
  font-size:clamp(44px,5.6vw,76px);
  font-weight:800; line-height:1.02; letter-spacing:-.035em;
  font-variation-settings:"opsz" 96;
  margin:18px 0 22px;
}
h1 .arc-word{ position:relative; white-space:nowrap; }
h1 .arc-word svg{ position:absolute; left:0; bottom:-10px; width:100%; height:auto; }
.hero p.sub{
  font-size:19px; color:var(--ink-soft); max-width:46ch; margin-bottom:30px;
}
.hero-ctas{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.hero-note{ font-family:var(--mono); font-size:12px; color:var(--ink-soft); margin-top:14px; }

/* ---------- the smile terminal (signature) ---------- */
.terminal{
  background:var(--paper);
  border:2px solid var(--ink);
  border-radius:var(--radius);
  box-shadow:8px 8px 0 var(--ink);
  overflow:hidden;
}
.term-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 18px; border-bottom:2px solid var(--ink);
  font-family:var(--mono); font-size:12px; letter-spacing:.1em;
}
.term-head .dot{ width:9px; height:9px; border-radius:50%; background:var(--coral); display:inline-block; margin-right:6px; animation:blinkdot 2.2s infinite; }
@keyframes blinkdot{ 0%,90%{opacity:1} 95%{opacity:.2} }
.term-body{ padding:26px 26px 22px; }
.face-stage{
  position:relative; user-select:none; touch-action:none;
  display:flex; justify-content:center;
}
.face-stage svg{ width:min(100%,360px); height:auto; cursor:grab; }
.face-stage.dragging svg{ cursor:grabbing; }
.scanline{
  position:absolute; left:8%; right:8%; height:3px;
  background:var(--coral); opacity:0; border-radius:2px;
  box-shadow:0 0 14px var(--coral);
}
.scan .scanline{ animation:scan .55s ease-in-out; }
@keyframes scan{ 0%{opacity:.9; top:8%} 100%{opacity:.9; top:88%} }
.meter-row{
  display:flex; align-items:center; gap:14px; margin-top:18px;
}
.meter{
  flex:1; height:14px; border:2px solid var(--ink); border-radius:999px;
  overflow:hidden; background:#fff;
}
.meter-fill{
  height:100%; width:0%;
  background:linear-gradient(90deg,var(--butter-deep),var(--verified));
  transition:width .08s linear;
}
.meter-label{ font-family:var(--mono); font-size:12px; min-width:128px; text-align:right; }
.smile-slider{ width:100%; margin-top:14px; accent-color:var(--ink); }
.slider-hint{ font-family:var(--mono); font-size:11px; color:var(--ink-soft); margin-top:6px; text-align:center; display:block; }

.receipt{
  margin-top:20px; background:#fff; border:2px solid var(--ink);
  border-radius:6px; position:relative; padding:16px 18px 22px;
  font-family:var(--mono); font-size:12.5px; line-height:1.9;
  display:none;
}
.receipt::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:10px;
  background:
    linear-gradient(45deg,transparent 33.333%,#fff 33.333%,#fff 66.667%,transparent 66.667%),
    linear-gradient(-45deg,transparent 33.333%,#fff 33.333%,#fff 66.667%,transparent 66.667%);
  background-size:14px 20px; background-position:0 -10px;
}
.receipt.show{ display:block; }
.receipt .r-line{ opacity:0; transform:translateY(4px); transition:opacity .25s ease, transform .25s ease; display:flex; justify-content:space-between; gap:10px; }
.receipt .r-line.head{ padding-right:118px; }
.receipt .r-line:first-of-type{ padding-right:110px; }
.receipt .r-line.in{ opacity:1; transform:none; }
.receipt .r-line.total{ border-top:1.5px dashed var(--ink); margin-top:6px; padding-top:6px; font-weight:500; }
.receipt .ok{ color:var(--verified); font-weight:500; }
.receipt .soon{ color:var(--ink-soft); }
.verified-stamp{
  position:absolute; top:10px; right:12px;
  font-family:var(--mono); font-size:13px; font-weight:500; letter-spacing:.14em;
  color:var(--verified); border:2.5px solid var(--verified);
  padding:4px 10px; border-radius:6px; transform:rotate(8deg) scale(0);
  transition:transform .28s cubic-bezier(.2,2,.4,1);
}
.receipt.show .verified-stamp{ transform:rotate(-7deg) scale(1); }
.reset-row{ margin-top:14px; text-align:center; display:none; }
.reset-row.show{ display:block; }
.reset-row button{
  font-family:var(--mono); font-size:12px; background:none; border:none;
  text-decoration:underline; cursor:pointer; color:var(--ink-soft);
}
.confetti-bit{
  position:absolute; width:8px; height:8px; pointer-events:none; z-index:5;
}

/* ---------- ticker ---------- */
.ticker{
  background:var(--ink); color:var(--butter);
  border-top:2px solid var(--ink); border-bottom:2px solid var(--ink);
  overflow:hidden; white-space:nowrap;
}
.ticker-track{
  display:inline-block; padding:11px 0;
  font-family:var(--mono); font-size:12.5px; letter-spacing:.06em;
  animation:tick 38s linear infinite;
}
.ticker-track span{ margin:0 26px; }
.ticker-track .ok{ color:#7CE3A8; }
@keyframes tick{ from{ transform:translateX(0)} to{ transform:translateX(-50%)} }

/* ---------- sections ---------- */
section{ padding:96px 0; }
.sec-head{ max-width:680px; margin-bottom:54px; }
h2{
  font-size:clamp(32px,3.6vw,48px); font-weight:800; letter-spacing:-.03em;
  line-height:1.06; margin:14px 0 16px;
}
.sec-head p{ font-size:17px; color:var(--ink-soft); }

/* comparison */
.compare{ background:var(--paper); border-top:2px solid var(--ink); border-bottom:2px solid var(--ink); }
.compare-scroll{ overflow-x:auto; }
.compare-table{
  width:100%; min-width:640px; border:2px solid var(--ink); border-radius:var(--radius);
  overflow:hidden; background:#fff; box-shadow:8px 8px 0 var(--ink);
  border-collapse:separate; border-spacing:0;
}
.compare-table th,.compare-table td{
  padding:16px 20px; text-align:left; font-size:15px;
  border-bottom:1.5px dashed var(--ink-faint);
}
.compare-table tr:last-child td{ border-bottom:none; }
.compare-table thead th{
  font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  border-bottom:2px solid var(--ink); background:var(--paper);
}
.compare-table td:first-child{ color:var(--ink-soft); width:30%; }
.compare-table .win{ font-weight:700; }

/* steps */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.step{
  background:var(--paper); border:2px solid var(--ink); border-radius:var(--radius);
  padding:26px 24px 28px; position:relative;
}
.step .n{
  font-family:var(--mono); font-size:12px; letter-spacing:.14em; color:var(--ink-soft);
}
.step h3{ font-size:21px; font-weight:700; letter-spacing:-.02em; margin:10px 0 8px; }
.step p{ font-size:14.5px; color:var(--ink-soft); }
.step svg{ margin-top:18px; }

/* applications status grid */
.apps{ background:var(--paper); border-top:2px solid var(--ink); border-bottom:2px solid var(--ink); }
.app-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.app-card{
  background:#fff; border:2px solid var(--ink); border-radius:var(--radius);
  padding:24px 22px; display:flex; flex-direction:column; gap:10px;
}
.app-card h3{ font-size:19px; font-weight:700; letter-spacing:-.015em; line-height:1.2; }
.app-card p{ font-size:14px; color:var(--ink-soft); }
.app-card .who{ font-family:var(--mono); font-size:11.5px; color:var(--ink-soft); }
.app-card .pilot-link{
  margin-top:auto; font-weight:700; font-size:14px; text-decoration:none;
  border-bottom:2px solid var(--coral); align-self:flex-start; padding-bottom:1px;
}
.app-card .pilot-link:hover{ color:var(--coral); }
.status-pill{
  font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase;
  border-radius:999px; padding:4px 11px; align-self:flex-start; font-weight:500;
}
.status-pill.early{ background:var(--verified); color:#fff; border:1.5px solid var(--verified); }
.status-pill.soon{ background:transparent; color:var(--ink-soft); border:1.5px solid var(--ink-faint); }
.app-card.soon-card{ background:var(--paper); }
.app-card.soon-card h3{ color:var(--ink-soft); }

/* pilot / teams */
.pilot-sec .case-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:26px; align-items:stretch; }
.case{
  border:2px solid var(--ink); border-radius:var(--radius); background:var(--paper);
  padding:30px 28px; display:flex; flex-direction:column; gap:14px;
}
.case h3{ font-size:26px; font-weight:800; letter-spacing:-.025em; }
.case p{ color:var(--ink-soft); font-size:15.5px; }
.case .figure{
  margin-top:auto; background:#fff; border:1.5px solid var(--ink);
  border-radius:10px; padding:14px 16px; font-family:var(--mono); font-size:12.5px;
}
.guestline{ display:flex; align-items:center; gap:10px; padding:6px 0; border-bottom:1px dashed var(--ink-faint); }
.guestline:last-child{ border-bottom:none; }
.guestline .face{
  width:24px; height:24px; border-radius:50%; border:1.5px solid var(--ink);
  background:var(--butter); flex:none; position:relative;
}
.guestline .face::before{ content:""; position:absolute; left:6px; top:8px; width:3px; height:3px; border-radius:50%; background:var(--ink); box-shadow:7px 0 0 var(--ink); }
.guestline .face::after{
  content:""; position:absolute; left:6.5px; top:13px; width:9px; height:5px;
  border:1.7px solid var(--ink); border-top:none; border-radius:0 0 9px 9px;
}
.guestline .st{ margin-left:auto; }
.guestline.checked .st{ color:var(--verified); }
.guestline.waiting .st{ color:var(--ink-soft); }
.badge-row{ display:flex; gap:8px; flex-wrap:wrap; }
.pill{
  font-family:var(--mono); font-size:11px; letter-spacing:.08em;
  border:1.5px solid var(--ink); border-radius:999px; padding:4px 10px;
}

/* security */
.security{ background:var(--ink); color:var(--paper); }
.security .eyebrow{ color:rgba(251,247,236,.55); }
.security h2{ color:var(--butter); }
.sec-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:54px; align-items:center; }
.sec-list{ list-style:none; display:flex; flex-direction:column; gap:18px; margin-top:8px; }
.sec-list li{ display:flex; gap:14px; font-size:16px; }
.sec-list li strong{ display:block; font-size:17px; letter-spacing:-.01em; }
.sec-list li span{ color:rgba(251,247,236,.66); font-size:15px; }
.sec-list .arcdot{ flex:none; width:26px; height:26px; margin-top:2px; }
.store-card{
  border:2px solid var(--butter); border-radius:var(--radius);
  padding:22px; font-family:var(--mono); font-size:12.5px; line-height:1.95;
  color:rgba(251,247,236,.75); background:rgba(255,212,58,.04);
}
.store-card .hl{ color:var(--butter); }
.store-card .never{ color:var(--coral); }
.store-card hr{ border:none; border-top:1.5px dashed rgba(251,247,236,.25); margin:10px 0; }
.legal-links{ margin-top:26px; display:flex; gap:10px 18px; flex-wrap:wrap; }
.legal-links a{
  font-family:var(--mono); font-size:12px; color:var(--butter);
  text-decoration:none; border-bottom:1.5px solid rgba(255,212,58,.5); padding-bottom:2px;
}
.legal-links a:hover{ border-bottom-color:var(--butter); }

/* hardware */
.hw-grid{ display:grid; grid-template-columns:1fr 1fr; gap:26px; align-items:start; }
.hw-card{
  background:var(--paper); border:2px solid var(--ink); border-radius:var(--radius);
  padding:28px 26px;
}
.hw-card h3{ font-size:21px; font-weight:700; margin-bottom:14px; letter-spacing:-.015em; }
.hw-card ul{ list-style:none; display:flex; flex-direction:column; gap:11px; font-size:15px; }
.hw-card ul li{ padding-left:26px; position:relative; color:var(--ink-soft); }
.hw-card ul li::before{
  content:""; position:absolute; left:0; top:7px; width:13px; height:7px;
  border:2.2px solid var(--verified); border-top:none; border-radius:0 0 13px 13px;
}
.hw-card.limits ul li::before{ border-color:var(--ink-soft); }

/* pricing */
.pricing-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; align-items:stretch; }
.plan{
  background:var(--paper); border:2px solid var(--ink); border-radius:var(--radius);
  padding:28px 26px; display:flex; flex-direction:column; gap:6px;
}
.plan.feature{ background:#fff; box-shadow:8px 8px 0 var(--ink); }
.plan .name{ font-weight:800; font-size:22px; letter-spacing:-.02em; }
.plan .price{ font-size:36px; font-weight:800; letter-spacing:-.03em; margin:6px 0 0; }
.plan .price small{ font-size:14px; font-weight:500; color:var(--ink-soft); }
.plan .per{ font-family:var(--mono); font-size:13px; color:var(--ink-soft); margin-bottom:4px; }
.plan ul{ list-style:none; margin:14px 0 22px; display:flex; flex-direction:column; gap:9px; font-size:14.5px; }
.plan ul li{ padding-left:24px; position:relative; }
.plan ul li::before{
  content:""; position:absolute; left:0; top:7px; width:13px; height:7px;
  border:2.2px solid var(--ink); border-top:none; border-radius:0 0 13px 13px;
}
.plan .btn{ margin-top:auto; text-align:center; }
.pricing-note{ font-family:var(--mono); font-size:12px; color:var(--ink-soft); margin-top:22px; max-width:62ch; }

/* roadmap / integrations */
.roadmap{ background:var(--paper); border-top:2px solid var(--ink); border-bottom:2px solid var(--ink); }
.roadmap-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.road-card{
  background:#fff; border:2px solid var(--ink); border-radius:var(--radius);
  padding:24px 22px; display:flex; flex-direction:column; gap:10px;
}
.road-card h3{ font-size:19px; font-weight:700; letter-spacing:-.015em; }
.road-card p{ font-size:14.5px; color:var(--ink-soft); }

/* faq */
.faq details{
  border-bottom:2px solid var(--ink); padding:20px 4px;
}
.faq details:first-of-type{ border-top:2px solid var(--ink); }
.faq summary{
  font-size:19px; font-weight:700; letter-spacing:-.015em; cursor:pointer;
  list-style:none; display:flex; justify-content:space-between; align-items:center; gap:20px;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-weight:400; font-size:26px; transition:transform .2s; }
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq details p{ margin-top:12px; color:var(--ink-soft); max-width:64ch; }

/* contact + footer */
.footer-cta{ padding:110px 0 70px; text-align:center; position:relative; overflow:hidden; }
.footer-cta h2{ font-size:clamp(38px,5vw,64px); max-width:18ch; margin:0 auto 26px; }
.footer-cta .contact-line{ font-family:var(--mono); font-size:13px; color:var(--ink-soft); margin-top:18px; }
.footer-cta .contact-line a{ color:var(--ink); }
.big-arc{ width:min(560px,80%); margin:38px auto 0; }
footer{
  border-top:2px solid var(--ink); padding:30px 0 40px;
  font-family:var(--mono); font-size:12px; color:var(--ink-soft);
}
.foot-grid{ display:flex; gap:12px 26px; flex-wrap:wrap; align-items:center; }
.foot-grid a{ text-decoration:none; }
.foot-grid a:hover{ text-decoration:underline; }
.foot-grid .spacer{ margin-left:auto; }

/* legal pages */
.legal-page{ background:var(--paper); min-height:100vh; }
.legal-body{ max-width:760px; margin:0 auto; padding:60px 28px 100px; }
.legal-body h1{ font-size:clamp(32px,4vw,46px); margin:10px 0 8px; }
.legal-body .effective{ font-family:var(--mono); font-size:13px; color:var(--ink-soft); margin-bottom:34px; }
.legal-body h2{ font-size:22px; margin:38px 0 12px; }
.legal-body h3{ font-size:17px; margin:24px 0 8px; }
.legal-body p, .legal-body li{ font-size:15.5px; color:rgba(20,18,14,.82); margin-bottom:12px; }
.legal-body ul{ padding-left:24px; margin-bottom:14px; }
.legal-body ul li{ margin-bottom:6px; }
.draft-banner{
  background:#fff; border:2px solid var(--coral); border-radius:10px;
  padding:14px 18px; font-family:var(--mono); font-size:12.5px;
  color:var(--ink); margin-bottom:30px; line-height:1.7;
}
.back-link{
  font-family:var(--mono); font-size:12px; text-decoration:none;
  border-bottom:1.5px solid var(--ink-faint); padding-bottom:2px;
}
.back-link:hover{ border-bottom-color:var(--ink); }

/* reveal on scroll */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in{ opacity:1; transform:none; }

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; }
  html{ scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; }
}
@media (max-width:1020px){
  .app-grid{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:repeat(2,1fr); }
  .roadmap-grid{ grid-template-columns:1fr; }
}
@media (max-width:900px){
  .hero-grid,.sec-grid,.pilot-sec .case-grid,.hw-grid{ grid-template-columns:1fr; }
  .pricing-grid{ grid-template-columns:1fr; }
  .nav-links{
    display:none; position:absolute; top:66px; left:0; right:0;
    background:var(--butter); border-bottom:2px solid var(--ink);
    flex-direction:column; align-items:flex-start; padding:18px 28px 22px; gap:16px;
  }
  .nav-links.open{ display:flex; }
  .nav-toggle{ display:block; }
  .nav-inner > .btn{ font-size:13px; padding:10px 16px; }
  header.hero{ padding:54px 0 60px; }
  section{ padding:70px 0; }
}
@media (max-width:560px){
  .app-grid,.steps{ grid-template-columns:1fr; }
  .wrap{ padding:0 20px; }
}
