/* ============================================================
   QuickPOS — Design System
   Aesthetic: offline-first receipt-tape / field-industrial.
   Palette: ink navy, signal amber (the "offline" warmth),
   money emerald, warm paper. Data set in monospace.
   Deliberately avoids cream+serif+clay, black+acid, and
   broadsheet-hairline AI defaults.
   ============================================================ */


:root{
  /* core palette */
  --ink:#0a1626;          /* deep navy near-black */
  --ink-2:#122032;
  --ink-3:#1c2c40;
  --paper:#f4f0e8;        /* warm receipt paper */
  --paper-2:#ece6da;
  --paper-line:#dcd3c2;
  --amber:#f6a821;        /* signal amber — the offline soul */
  --amber-deep:#d8860b;
  --emerald:#0f9d6b;      /* money / committed */
  --emerald-deep:#0a7a52;
  --red:#e5484d;          /* dropped / alert */
  --sky:#3a8ee6;

  --ink-70:rgba(10,22,38,.70);
  --ink-55:rgba(10,22,38,.55);
  --ink-40:rgba(10,22,38,.40);
  --ink-12:rgba(10,22,38,.12);
  --ink-08:rgba(10,22,38,.08);
  --paper-70:rgba(244,240,232,.70);
  --paper-40:rgba(244,240,232,.40);

  --font-display:'Space Grotesk',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
  --font-mono:'Space Mono','SF Mono',ui-monospace,monospace;

  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-xl:30px;
  --maxw:1200px;
  --shadow-card:0 1px 0 var(--paper-line),0 18px 40px -24px rgba(10,22,38,.45);
  --shadow-float:0 30px 70px -30px rgba(10,22,38,.55);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--font-body);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(circle at 12% 8%, rgba(246,168,33,.06), transparent 40%),
    radial-gradient(circle at 88% 0%, rgba(15,157,107,.05), transparent 35%);
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.08;letter-spacing:-.02em;margin:0}
p{margin:0}
.mono{font-family:var(--font-mono)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{
  font-family:var(--font-mono);font-size:.72rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--amber-deep);
  display:inline-flex;align-items:center;gap:8px;
}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--amber);display:inline-block}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-display);font-weight:600;font-size:.95rem;
  padding:13px 22px;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background .2s ease;
  white-space:nowrap;
}
.btn--primary{background:var(--ink);color:var(--paper)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 14px 28px -12px rgba(10,22,38,.6)}
.btn--amber{background:var(--amber);color:var(--ink)}
.btn--amber:hover{transform:translateY(-2px);box-shadow:0 14px 28px -12px rgba(216,134,11,.7)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink-12)}
.btn--ghost:hover{border-color:var(--ink);background:var(--ink-08)}
.btn--lg{padding:16px 30px;font-size:1.02rem}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:var(--paper-70);backdrop-filter:blur(14px);border-bottom:1px solid var(--paper-line)}
.nav__in{display:flex;align-items:center;gap:28px;height:66px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:700;font-size:1.15rem;letter-spacing:-.02em}
.brand__mark{width:30px;height:22px;border-radius:999px;background:linear-gradient(90deg,var(--red) 0 50%,#fff 50% 100%);border:1.5px solid var(--red);color:transparent;font-size:0;transform:rotate(-45deg);display:inline-block;flex:none;position:relative;top:2px}
.nav__links{display:flex;gap:26px;margin-left:8px}
.nav__links a{font-size:.92rem;font-weight:500;color:var(--ink-70);transition:color .15s}
.nav__links a:hover{color:var(--ink)}
.nav__right{margin-left:auto;display:flex;align-items:center;gap:14px}
.nav__toggle{display:none;background:none;border:0;font-size:1.5rem;cursor:pointer;color:var(--ink)}

/* ---------- sections ---------- */
.section{padding:96px 0}
.section--ink{background:var(--ink);color:var(--paper)}
.section--ink h1,.section--ink h2,.section--ink h3{color:var(--paper)}
.section__head{max-width:640px;margin-bottom:52px}
.section__head h2{font-size:clamp(1.9rem,4vw,2.9rem);margin:16px 0 14px}
.section__head p{color:var(--ink-55);font-size:1.08rem}
.section--ink .section__head p{color:var(--paper-40)}

/* ---------- generic cards ---------- */
.card{background:#fffdf8;border:1px solid var(--paper-line);border-radius:var(--r-lg);padding:26px;box-shadow:var(--shadow-card)}
.grid{display:grid;gap:20px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}

/* ---------- footer ---------- */
.footer{background:var(--ink);color:var(--paper-40);padding:70px 0 40px}
.footer h4{color:var(--paper);font-size:.82rem;font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px}
.footer a{display:block;color:var(--paper-40);font-size:.92rem;padding:5px 0;transition:color .15s}
.footer a:hover{color:var(--amber)}
.footer__grid{display:grid;grid-template-columns:1.6fr repeat(4,1fr);gap:36px;margin-bottom:50px}
.footer__bottom{border-top:1px solid rgba(244,240,232,.12);padding-top:26px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-size:.85rem;font-family:var(--font-mono)}

/* ---------- utility ---------- */
.tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.72rem;font-weight:700;padding:5px 11px;border-radius:999px;letter-spacing:.04em}
.tag--amber{background:rgba(246,168,33,.16);color:var(--amber-deep)}
.tag--emerald{background:rgba(15,157,107,.14);color:var(--emerald-deep)}
.tag--ink{background:var(--ink-08);color:var(--ink-70)}

@media(max-width:920px){
  .nav__links{display:none}
  .nav__toggle{display:block}
  .g-4{grid-template-columns:repeat(2,1fr)}
  .g-3{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr 1fr}
  .section{padding:64px 0}
}
@media(max-width:560px){
  .g-2,.g-4{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
  html{scroll-behavior:auto}
}

/* ============ CONFIG-DRIVEN FOOTER (data-site-footer) ============ */
footer[data-site-footer]{background:var(--ink,#0a1626);color:#c9d3e0;padding:64px 0 28px;margin-top:80px}
.sf__grid{display:grid;grid-template-columns:1.6fr repeat(4,1fr);gap:40px}
.sf__brand .brand{color:#fff;margin-bottom:14px}
.sf__brand p{font-size:14px;line-height:1.6;color:#9fb0c4;max-width:34ch}
.sf__meta{font-family:var(--mono,'Space Mono',monospace);font-size:12px;color:#f6a821!important;margin-top:10px}
.sf__social{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}
.sf__social a{font-size:12px;text-transform:capitalize;color:#9fb0c4;text-decoration:none;border:1px solid #23324a;padding:4px 10px;border-radius:999px}
.sf__social a:hover{color:#fff;border-color:#f6a821}
.sf__col h3{color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.06em;margin:0 0 14px}
.sf__col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.sf__col a{color:#9fb0c4;text-decoration:none;font-size:14px}
.sf__col a:hover{color:#f6a821}
.sf__base{display:flex;justify-content:space-between;align-items:center;border-top:1px solid #1a2740;margin-top:48px;padding-top:22px;font-size:13px;color:#7d8da4}
.sf__legal a{color:#9fb0c4;text-decoration:none}
.sf__legal a:hover{color:#f6a821}
@media(max-width:860px){.sf__grid{grid-template-columns:1fr 1fr;gap:28px}.sf__brand{grid-column:1/-1}.sf__base{flex-direction:column;gap:10px;text-align:center}}

/* ============ FLOATING WHATSAPP ============ */
.wa-float{position:fixed;right:20px;bottom:20px;z-index:900;width:54px;height:54px;border-radius:50%;
  background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(0,0,0,.28);transition:transform .15s ease}
.wa-float:hover{transform:scale(1.08)}
@media(max-width:600px){.wa-float{width:48px;height:48px;right:16px;bottom:16px}}

/* subtle section heading for card grids (keeps heading outline valid) */
.sr-section{font-family:var(--font-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-40);margin:0 0 18px;font-weight:600}
.roicard-h{font-family:var(--font-display);font-size:19px;font-weight:700;margin:0 0 4px}
.sr-section-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ============ ACCESSIBILITY: visible keyboard focus (WCAG 2.4.7) ============ */
:focus-visible{outline:3px solid var(--amber);outline-offset:2px;border-radius:3px}
/* on dark surfaces, amber ring already high-contrast; ensure buttons show it */
.btn:focus-visible,a:focus-visible,button:focus-visible,input:focus-visible,
[tabindex]:focus-visible,.sc-tab:focus-visible,.paybtn:focus-visible,.posprod:focus-visible{
  outline:3px solid var(--amber);outline-offset:2px}
/* remove focus ring only for mouse users (keep for keyboard) */
:focus:not(:focus-visible){outline:none}
/* skip-to-content link for keyboard/screen-reader users */
.skip-link{position:absolute;left:-9999px;top:0;z-index:1000;background:var(--ink);color:#fff;
  padding:12px 20px;border-radius:0 0 10px 0;font-weight:600;text-decoration:none}
.skip-link:focus{left:0}

/* ============ CONSOLIDATED NAV WITH DROPDOWNS ============ */
.nav__group{position:relative}
.nav__trigger{display:inline-flex;align-items:center;gap:5px;font-size:.92rem;font-weight:500;color:var(--ink-70);
  background:none;border:0;cursor:pointer;padding:6px 2px;font-family:inherit;transition:color .15s}
.nav__trigger:hover,.nav__group:hover .nav__trigger{color:var(--ink)}
.nav__trigger svg{width:11px;height:11px;transition:transform .18s ease;opacity:.6}
.nav__group:hover .nav__trigger svg{transform:rotate(180deg)}
.nav__menu{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(6px);
  min-width:240px;background:#fff;border:1px solid var(--paper-line);border-radius:14px;padding:8px;
  box-shadow:0 20px 50px -20px rgba(10,22,38,.4);opacity:0;visibility:hidden;transition:all .18s ease;z-index:60}
.nav__group:hover .nav__menu,.nav__group:focus-within .nav__menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav__menu::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}/* hover bridge */
.nav__mi{display:flex;gap:11px;align-items:flex-start;padding:10px 12px;border-radius:10px;text-decoration:none;transition:background .12s}
.nav__mi:hover{background:var(--paper-2)}
.nav__mi__ic{font-size:16px;flex:none;line-height:1.3;width:20px;text-align:center}
.nav__mi__t{font-size:14px;font-weight:600;color:var(--ink);line-height:1.3}
.nav__mi__d{font-size:12px;color:var(--ink-55);margin-top:1px;line-height:1.4}
.nav__links a.nav__direct{padding:6px 2px}

/* mobile: dropdowns become expandable groups */
@media(max-width:960px){
  .mnav__group-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
    color:var(--amber-deep);padding:14px 4px 6px;font-weight:700}
}

/* ============ MOBILE NAV & OVERFLOW FIXES ============ */
@media(max-width:920px){
  /* hide desktop CTAs on mobile — they live in the mobile menu */
  .nav__right{display:none}
  .nav__toggle{display:block;margin-left:auto}
}
/* prevent any oversized button from overflowing its container on small screens */
.btn{max-width:100%;box-sizing:border-box}
@media(max-width:560px){
  .btn--lg{width:100%;box-sizing:border-box;text-align:center;justify-content:center}
  /* stacked CTA rows: make buttons full width so they never overflow */
  .hero__cta .btn,.section .btn--lg{max-width:100%}
}
/* global guard against horizontal scroll */
html,body{overflow-x:hidden}

/* mobile menu CTA buttons */
.mnav__cta{display:block;text-align:center;padding:12px;border-radius:10px;font-weight:600;font-size:15px;
  border:1px solid var(--ink-12);color:var(--ink);text-decoration:none;margin-top:8px}
.mnav__cta--primary{background:var(--ink);color:#fff;border-color:var(--ink)}
