@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&family=Manrope:wght@400;500;600;700;800&display=swap";:root{--bg: #eef8fb;--bg-soft: #f8fdff;--surface: rgba(255, 255, 255, .9);--surface-strong: #ffffff;--surface-muted: rgba(238, 248, 251, .84);--ink: #11314d;--ink-soft: #456783;--line: rgba(15, 76, 129, .12);--line-strong: rgba(15, 76, 129, .22);--brand: #0f4c81;--brand-soft: #1e7cb2;--accent: #f48b1f;--accent-strong: #f7c63a;--success: #31a868;--warm: #efb72c;--cold: #17a7dc;--danger: #d55a42;--shadow-lg: 0 32px 64px rgba(15, 76, 129, .12);--shadow-md: 0 18px 36px rgba(15, 76, 129, .08);--radius-xl: 30px;--radius-lg: 22px;--radius-md: 16px;--radius-sm: 12px}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;color:var(--ink);font-family:Manrope,sans-serif;background:radial-gradient(circle at top left,rgba(247,198,58,.26),transparent 24%),radial-gradient(circle at 88% 10%,rgba(23,167,220,.18),transparent 24%),radial-gradient(circle at 18% 82%,rgba(49,168,104,.16),transparent 22%),linear-gradient(180deg,#fbfeff,#f0f9fc 56%,#e8f4f8);background-attachment:fixed}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(120deg,rgba(255,255,255,.56),transparent 30%),linear-gradient(180deg,rgba(35,23,16,.04),transparent 24%)}button,input,select{font:inherit}a{color:inherit}.app-shell{position:relative;min-height:100vh;overflow:hidden;padding:28px 20px 48px}.ambient-orb,.ambient-mesh,.grid-noise{position:absolute;pointer-events:none}.ambient-orb{border-radius:999px;filter:blur(68px);opacity:.62}.ambient-orb-a{width:340px;height:340px;top:-84px;right:-120px;background:#f7c63a57}.ambient-orb-b{width:260px;height:260px;bottom:4%;left:-90px;background:#31a8682e}.ambient-orb-c{width:260px;height:260px;top:28%;left:18%;background:#17a7dc29}.ambient-mesh{top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 12% 12%,rgba(255,255,255,.58),transparent 16%),radial-gradient(circle at 84% 24%,rgba(255,255,255,.38),transparent 18%),radial-gradient(circle at 72% 84%,rgba(255,255,255,.24),transparent 18%);opacity:.8}.grid-noise{top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(15,76,129,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(15,76,129,.03) 1px,transparent 1px);background-size:32px 32px;opacity:.4}.content{position:relative;z-index:1;max-width:1180px;margin:0 auto;display:grid;gap:22px}.card{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:var(--radius-xl);padding:26px;background:linear-gradient(180deg,rgba(255,255,255,.72),transparent 26%),var(--surface);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.2),transparent 24%);pointer-events:none}.hero-card,.landing-hero{color:#f8fcff;border-color:#f8fcff1f;background:radial-gradient(circle at top left,rgba(247,198,58,.24),transparent 20%),radial-gradient(circle at 86% 10%,rgba(49,168,104,.2),transparent 22%),radial-gradient(circle at 74% 82%,rgba(23,167,220,.22),transparent 24%),linear-gradient(145deg,#0e406b,#0f5f95 52%,#1893be);box-shadow:0 32px 64px #0f4c8142}.landing-hero .muted,.hero-card .muted,.hero-card .eyebrow,.hero-card .screen-title{color:#fff8f1db}.landing-clean{gap:22px}.landing-stage,.landing-panel,.landing-panel-stack,.landing-clean-flow,.board-copy,.customer-hero,.history-hero,.topbar-copy,.topbar-meta,.auth-aside,.coupon-vault,.admin-quick-grid{display:grid;gap:16px}.topbar-shell{padding:32px}.topbar-grid,.topbar-meta-grid,.landing-grid,.board-hero-grid,.auth-grid,.history-layout,.admin-layout,.admin-command-grid,.admin-form-grid,.grid-2,.grid-3,.grid-4,.metric-grid,.landing-ribbon,.landing-mini-grid,.scan-preview{display:grid;gap:16px}.topbar-grid-meta{grid-template-columns:minmax(0,1.22fr) minmax(300px,.78fr);align-items:start}.hero-head,.section-head,.landing-brand-row,.batch-card-top,.batch-card-stats,.landing-banner,.landing-meta,.hero-actions,.top-nav,.badge-panel,.badge-row,.action-row{display:flex;flex-wrap:wrap;gap:10px}.hero-head,.section-head,.landing-brand-row{justify-content:space-between;align-items:flex-start}.landing-brand-row-clean{align-items:stretch}.landing-brand-note,.landing-panel-card,.inline-card,.batch-card,.coupon-vault-card,.signal-card,.topbar-stat,.ops-lane,.insight-item,.ribbon-item,.scan-preview-code,.scan-preview-status{border-radius:var(--radius-lg);border:1px solid rgba(248,252,255,.12);background:linear-gradient(180deg,rgba(255,255,255,.16),transparent 36%),#f8fcff1a;box-shadow:inset 0 1px #ffffff14}.landing-brand-note,.landing-panel-card,.inline-card,.batch-card,.coupon-vault-card,.signal-card,.ops-lane,.insight-item,.ribbon-item,.scan-preview-code,.scan-preview-status,.topbar-stat{padding:18px}.landing-brand-note{width:min(100%,380px);align-content:start}.landing-brand-note strong,.landing-panel-card h3,.screen-title,.landing-title,h2,h3,.metric-card strong,.timeline-title,.brand-caption,.print-sheet-meta strong,.print-coupon-code{font-family:Fraunces,serif}.landing-brand-note strong{display:block;font-size:28px;line-height:1.06}.landing-brand-note p{color:#f8fcffd6;line-height:1.65}.landing-grid{grid-template-columns:minmax(0,1.12fr) minmax(320px,.88fr);align-items:start}.landing-grid-clean{grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr)}.landing-public-grid{grid-template-columns:1fr}.landing-grid-strong{gap:20px}.board-hero{background:radial-gradient(circle at top left,rgba(247,198,58,.12),transparent 18%),radial-gradient(circle at 84% 10%,rgba(23,167,220,.12),transparent 22%),linear-gradient(180deg,#ffffffd6,#f4fbfef5),var(--surface);color:var(--ink);border-color:var(--line);box-shadow:var(--shadow-lg)}.board-hero .muted,.board-hero .eyebrow.dark{color:var(--ink-soft)}.board-hero-grid{grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr);align-items:start}.board-hero-grid-strong{gap:20px}.auth-grid{grid-template-columns:minmax(0,1fr) minmax(320px,.84fr);align-items:start}.history-layout{grid-template-columns:minmax(0,1.16fr) minmax(300px,.84fr)}.admin-layout,.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4,.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.landing-copy,.landing-copy-clean,.landing-panel,.topbar-copy,.board-copy,.landing-column-stack,.landing-proof-card,.landing-how-header,.auth-inline-badges,.customer-focus-card{display:grid;gap:14px}.landing-copy-clean .landing-title{max-width:11ch}.eyebrow,.hero-kicker,.panel-tag,.topbar-stat span,.metric-card span,.ops-lane span,.insight-item span,.ribbon-label,.scan-preview-code span,.scan-preview-status span,.badge{text-transform:uppercase;letter-spacing:.14em;font-weight:800}.eyebrow{font-size:11px;color:#fff8f1b3}.eyebrow.dark{color:var(--ink-soft)}.hero-kicker,.panel-tag{display:inline-flex;align-items:center;gap:8px;width:fit-content;padding:8px 12px;border-radius:999px;font-size:11px;border:1px solid rgba(248,252,255,.18);background:#f8fcff1f}.landing-title{margin:0;font-size:clamp(44px,6vw,72px);line-height:.95;letter-spacing:-.04em}.screen-title{margin:0;font-size:clamp(34px,4.2vw,54px);line-height:.96;letter-spacing:-.04em;max-width:10ch}h2,h3,p{margin:0}h2{font-size:clamp(30px,4vw,48px);line-height:1;letter-spacing:-.03em}h3{font-size:clamp(24px,3vw,34px);line-height:1.08;letter-spacing:-.02em}.landing-text,.muted{color:var(--ink-soft);line-height:1.7}.landing-hero .landing-text,.landing-hero .muted,.landing-hero .eyebrow.dark,.landing-hero .proof-item p,.landing-hero .proof-item strong,.landing-hero .landing-how-header strong{color:#f8fcffeb}.landing-text{max-width:58ch;font-size:17px}.hero-actions{margin-top:4px}.hero-actions.compact{margin-top:0}.top-nav{justify-content:flex-end}.badge,.pill{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;font-size:11px;padding:10px 14px}.badge{background:#0f4c8114;color:var(--brand);border:1px solid rgba(15,76,129,.12)}.badge-outline{background:#ffffff4d;border-style:dashed}.badge-success{background:#3c7a571f;color:var(--success);border-color:#3c7a572e}.badge-warm{background:#b8832f1f;color:var(--warm);border-color:#b8832f2e}.badge-accent,.badge-contrast{background:#f48b1f24;color:#fff8ef;border-color:#f7c63a38}.badge-accent{color:var(--accent)}.badge-contrast{background:linear-gradient(135deg,#f48b1ff0,#f7c63af0);color:#11314d}.btn,.pill{cursor:pointer;border:0;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease,opacity .18s ease}.btn{padding:14px 18px;border-radius:16px;font-weight:800;letter-spacing:-.01em;color:#11314d;background:linear-gradient(135deg,#f7c63a,#f48b1f);box-shadow:0 16px 28px #f48b1f3d}.btn-alt{color:#f8fcff;background:linear-gradient(135deg,#0f4c81,#17a7dc)}.btn-ghost,.pill{color:var(--brand);border:1px solid var(--line);background:#ffffffd6;box-shadow:none}.btn:hover,.pill:hover{transform:translateY(-2px);filter:saturate(1.03)}.btn:disabled{opacity:.55;cursor:not-allowed}label{font-size:13px;font-weight:800;letter-spacing:.02em;color:var(--brand)}input,select{width:100%;border:1px solid var(--line);border-radius:var(--radius-md);padding:14px 15px;background:#ffffffc2;color:var(--ink);outline:0;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}input:focus,select:focus{border-color:#17a7dc5c;box-shadow:0 0 0 4px #17a7dc1a;transform:translateY(-1px)}.stack,.batch-list,.ledger-list,.coupon-vault-list,.insight-list,.signal-list{display:grid;gap:12px}.control-card,.data-surface,.action-card{background:linear-gradient(180deg,#ffffffad,#fffcf7f0),var(--surface)}.action-card-accent,.landing-panel-accent,.attendant-callout,.admin-note{background:radial-gradient(circle at top right,rgba(247,198,58,.18),transparent 22%),radial-gradient(circle at bottom left,rgba(49,168,104,.14),transparent 24%),linear-gradient(180deg,#fffc,#f7fcfefa)}.topbar-meta-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.topbar-stat{color:#fffaf4;min-width:0}.topbar-stat strong{display:block;margin-top:10px;font-size:16px;line-height:1.45;overflow-wrap:anywhere}.topbar-stat span{overflow-wrap:anywhere}.brand-lockup{--logo-width: clamp(300px, 34vw, 460px);display:grid;gap:12px;width:fit-content}.brand-lockup-compact{--logo-width: clamp(190px, 18vw, 242px)}.brand-logo-frame{width:var(--logo-width);aspect-ratio:2.12 / 1;display:grid;place-items:center;overflow:hidden;border-radius:28px;padding:14px 16px;background:linear-gradient(180deg,#fffffffa,#f3fafdf0),#fff;border:1px solid rgba(15,76,129,.08);box-shadow:0 18px 34px #0f4c811f}.brand-logo-frame-compact{border-radius:20px;padding:10px 12px}.brand-logo-image{width:100%;height:100%;object-fit:contain;display:block}.brand-caption{margin-left:10px;font-size:11px;color:#f8fcffd1;letter-spacing:.18em;text-transform:uppercase}.metric-card{position:relative;overflow:hidden;border-radius:var(--radius-lg);padding:18px;border:1px solid var(--line);background:linear-gradient(180deg,#ffffffd1,#fffcf7f5),var(--surface);box-shadow:var(--shadow-md)}.metric-card:before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:var(--brand)}.metric-card strong{display:block;margin-top:12px;font-size:34px;line-height:1;letter-spacing:-.04em;color:var(--brand)}.metric-card span{color:var(--ink-soft);font-size:11px}.metric-warm:before{background:var(--warm)}.metric-success:before{background:var(--success)}.metric-accent:before{background:var(--accent)}.badge-panel{align-content:start;padding:20px;border-radius:var(--radius-lg);border:1px solid var(--line);background:linear-gradient(180deg,#ffffffd1,#fffaf4f0),var(--surface-strong)}.command-panel{gap:12px}.insight-item strong,.ops-lane strong,.ribbon-item strong,.ledger-main strong,.ledger-side strong,.coupon-vault-card strong,.scan-preview-code strong,.scan-preview-status strong{display:block;margin-top:8px;font-size:18px;line-height:1.35;color:var(--brand)}.insight-item p,.ops-lane p,.ribbon-item p,.coupon-vault-card p,.ledger-main p{margin-top:8px;color:var(--ink-soft);line-height:1.55}.hero-progress-label{display:flex;justify-content:space-between;gap:12px;font-size:13px;font-weight:800;color:var(--brand)}.progress{width:100%;overflow:hidden;height:14px;border-radius:999px;background:#2d201714}.progress-strong{height:16px}.progress-bar{height:100%;border-radius:inherit;background:linear-gradient(90deg,#17a7dc,#31a868 58%,#f7c63a);transition:width .35s ease}.landing-cup-wrap{display:grid;place-items:center;min-height:210px;padding:18px;border-radius:var(--radius-lg);background:radial-gradient(circle at top left,rgba(247,198,58,.24),transparent 30%),radial-gradient(circle at bottom right,rgba(23,167,220,.18),transparent 26%),linear-gradient(180deg,#ffffffd6,#f3fafdf5)}.landing-cup-image{width:min(100%,240px);display:block;filter:drop-shadow(0 24px 24px rgba(30,22,18,.18))}.ops-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.landing-ops-grid,.compact-grid{grid-template-columns:1fr}.landing-public-shell,.landing-feature-stack{gap:18px}.landing-clean-minimal{gap:12px}.landing-minimal-grid{align-items:center}.landing-copy-minimal{gap:18px;align-content:center}.landing-inline-highlights{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.landing-inline-item{padding:14px 16px;border-radius:18px;border:1px solid rgba(248,252,255,.14);background:#f8fcff14;display:grid;gap:6px}.landing-inline-item span{text-transform:uppercase;letter-spacing:.14em;font-size:11px;color:#f8fcffc2;font-weight:800}.landing-inline-item strong{font-size:18px;line-height:1.1;color:#f8fcff}.landing-panel-minimal{justify-content:center}.landing-showcase-minimal{gap:16px}.landing-minimal-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.landing-minimal-step{padding:12px 14px;border-radius:18px;border:1px solid rgba(248,252,255,.12);background:#f8fcff14;display:grid;gap:6px}.landing-minimal-step span{text-transform:uppercase;letter-spacing:.14em;font-size:11px;font-weight:800;color:#f8fcffc2}.landing-minimal-step strong{color:#f8fcff;font-size:16px;line-height:1.15}.landing-proof-card{grid-template-columns:repeat(2,minmax(0,1fr));padding:18px;border-radius:var(--radius-lg);border:1px solid rgba(248,252,255,.14);background:linear-gradient(180deg,rgba(255,255,255,.12),transparent 48%),#ffffff14}.proof-item{display:grid;gap:8px}.proof-item span,.landing-how-header strong{text-transform:uppercase;letter-spacing:.14em;font-size:11px;font-weight:800}.proof-item strong{font-size:20px;line-height:1.15}.proof-item p{line-height:1.6}.landing-showcase-card{padding-bottom:22px}.landing-how-header strong{font-family:Manrope,sans-serif}.hero-actions-stack{display:grid;grid-template-columns:1fr}.btn-xl{min-height:64px;border-radius:20px;font-size:20px}.social-links{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.social-link{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:14px 16px;border-radius:18px;border:1px solid rgba(248,252,255,.16);background:#f8fcff1f;box-shadow:inset 0 1px #ffffff14;color:#f8fcff;text-decoration:none;font-weight:800;transition:transform .18s ease,background .18s ease,border-color .18s ease}.social-link-whatsapp{background:#31a86833}.social-link:hover{transform:translateY(-2px);background:#f8fcff2e}.auth-grid-refined{align-items:stretch}.auth-inline-badges{grid-template-columns:repeat(2,minmax(0,1fr))}.auth-footnote{font-size:14px}.landing-ribbon{grid-template-columns:repeat(3,minmax(0,1fr))}.customer-home-grid{align-items:stretch}.customer-ribbon{grid-template-columns:1fr}.hero-quick-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.hero-stat-chip{padding:14px 16px;border-radius:18px;border:1px solid var(--line);background:#ffffffb8;display:grid;gap:6px}.hero-stat-chip span{text-transform:uppercase;letter-spacing:.14em;font-size:11px;font-weight:800;color:var(--ink-soft)}.hero-stat-chip strong{color:var(--brand);font-size:17px;line-height:1.2}.coffee-progress-card{position:relative;overflow:hidden;padding:20px;border-radius:26px;border:1px solid rgba(15,76,129,.14);background:radial-gradient(circle at top,rgba(247,198,58,.18),transparent 28%),radial-gradient(circle at 80% 20%,rgba(23,167,220,.14),transparent 24%),linear-gradient(180deg,#fffffff0,#f4fafefa);box-shadow:inset 0 1px #ffffffa6;display:grid;gap:18px}.coffee-progress-card-active{animation:cupCelebrate 1.2s ease}.coffee-progress-head{display:grid;gap:6px}.coffee-progress-head strong{color:var(--brand);font-size:18px;line-height:1.25}.coffee-cup-stage{position:relative;min-height:250px;display:grid;place-items:center}.coffee-steam{position:absolute;top:12px;width:28px;height:82px;border-radius:999px;border:2px solid rgba(17,49,77,.1);border-bottom:0;border-left:0;opacity:.45;filter:blur(.2px);animation:steamRise 4.6s ease-in-out infinite}.coffee-steam-a{left:calc(50% - 54px)}.coffee-steam-b{left:calc(50% - 12px);height:92px;animation-delay:1s}.coffee-steam-c{left:calc(50% + 30px);animation-delay:2s}.coffee-cup{--cup-fill: 0%;position:relative;width:min(100%,220px);height:176px;border-radius:24px 24px 72px 72px;border:6px solid #f7fbff;background:linear-gradient(180deg,#fffc,#e6f1f8f5);box-shadow:0 18px 34px #0f4c8124,inset 0 -10px 20px #0f4c810f}.coffee-cup:before{content:"";position:absolute;top:12px;right:12px;bottom:12px;left:12px;border-radius:16px 16px 56px 56px;border:1px solid rgba(15,76,129,.08)}.coffee-cup-handle{position:absolute;right:calc(50% - 144px);top:86px;width:46px;height:74px;border-radius:999px;border:9px solid #f7fbff;border-left:0;box-shadow:10px 10px 18px #0f4c8114}.coffee-liquid{position:absolute;inset:auto 12px 12px;height:var(--cup-fill);min-height:0;border-radius:16px 16px 52px 52px;background:linear-gradient(180deg,#7a411f,#8b4a23 22%,#6f3518);overflow:hidden;transition:height 1.4s cubic-bezier(.22,1,.36,1);box-shadow:inset 0 10px 18px #ffd6a633}.coffee-liquid-wave{position:absolute;left:-10%;width:120%;height:22px;border-radius:999px;background:#ffe6be5c;top:-8px}.coffee-liquid-wave-a{animation:coffeeWave 3.2s linear infinite}.coffee-liquid-wave-b{top:-2px;opacity:.55;animation:coffeeWave 2.4s linear infinite reverse}.coffee-foam{position:absolute;left:22px;right:22px;top:calc(100% - var(--cup-fill) - 14px);height:16px;border-radius:999px;background:#fae7d2e6;box-shadow:0 2px 8px #6f35181f;transition:top 1.4s cubic-bezier(.22,1,.36,1),opacity .3s ease;opacity:calc(var(--cup-fill) / 100)}.coffee-gloss{position:absolute;inset:16px auto 28px 18px;width:32px;border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,.68),transparent);opacity:.75}.coffee-progress-copy strong{color:var(--brand);font-size:18px;line-height:1.25}.coffee-progress-copy p{color:var(--ink-soft);line-height:1.6}.coffee-dot{height:10px;border-radius:999px;background:#0f4c811f;transition:transform .35s ease,background .35s ease,box-shadow .35s ease}.coffee-dot.active{background:linear-gradient(135deg,#f7c63a,#f48b1f);box-shadow:0 6px 12px #f48b1f38;transform:translateY(-1px)}.scan-ribbon{margin-top:4px}.insight-compact{padding:16px}.admin-feedback{padding:16px 18px}.section-head{margin-bottom:4px}.table-wrap{overflow-x:auto;border-radius:20px;margin-top:8px;border:1px solid var(--line);background:#ffffff94}table{width:100%;min-width:560px;border-collapse:collapse;font-size:14px}th,td{text-align:left;padding:14px 16px;border-top:1px solid rgba(45,32,23,.08)}th{font-size:11px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.12em}tr:first-child td,tr:first-child th{border-top:0}tbody tr:hover{background:#17a7dc0f}.timeline,.step-list,.list{list-style:none;padding:0;margin:0}.timeline li,.step-list li,.list li{position:relative;padding:14px 0 14px 30px;border-top:1px solid rgba(45,32,23,.08)}.timeline li:first-child,.step-list li:first-child,.list li:first-child{border-top:0;padding-top:0}.step-list li:before,.timeline li:before{content:"";position:absolute;left:0;top:16px;width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,#d18d59,#6f8da5)}.timeline-title{font-size:18px;line-height:1.25}.timeline-meta,.batch-card-stats,.ledger-side span{color:var(--ink-soft);line-height:1.55}.ledger-row{display:flex;justify-content:space-between;gap:18px;align-items:center;padding:18px;border-radius:var(--radius-lg);border:1px solid var(--line);background:#ffffffa3}.ledger-main,.ledger-side{display:grid;gap:6px}.ledger-side{min-width:120px;justify-items:end;text-align:right}.scan-layout,.history-hero,.customer-hero{display:grid;gap:18px}.scan-preview{grid-template-columns:minmax(0,1.2fr) minmax(180px,.8fr)}.scanner-video{width:100%;min-height:240px;border-radius:20px;border:1px solid var(--line);background:#120d09;object-fit:cover}.qr-wrap{margin-top:14px;display:grid;place-items:center;min-height:280px;padding:18px;border-radius:var(--radius-lg);background:#ffffffbd;border:1px dashed var(--line-strong)}.empty-card{text-align:center;padding:38px 24px}.loading-card{min-height:220px;display:grid;place-items:center;gap:10px}.success-surface{background:linear-gradient(180deg,#ffffffd1,#f1f9f4f5),#f6fcf7}.error-surface{background:linear-gradient(180deg,#ffffffd1,#fcf2eff5),#fff9f7}.error{color:var(--danger);font-weight:800}.success{color:var(--success);font-weight:800}.pulse{animation:pulse .45s ease}.hidden{display:none}.customer-hero-stage{grid-template-columns:minmax(0,1.02fr) minmax(340px,.98fr);align-items:stretch}.customer-home-simple{gap:18px}.customer-home-simple-grid{align-items:stretch}.customer-home-primary{align-content:start}.customer-menu-shell{padding:18px 20px}.customer-menu-row{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.customer-menu-brand{display:flex;align-items:center;gap:12px;min-width:0}.customer-menu-logo{margin:0}.customer-menu-copy{display:grid;gap:2px;min-width:0}.customer-menu-copy h1{margin:0;font-size:20px;line-height:1.05;letter-spacing:-.02em}.customer-menu-copy span{font-size:13px;font-weight:700;color:#2b475cc7}.customer-menu-tabs{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center}.customer-menu-tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid rgba(15,76,129,.14);background:#ffffffe0;color:var(--ink);border-radius:999px;padding:11px 14px;font-size:13px;font-weight:800;letter-spacing:.01em;box-shadow:0 8px 18px #0f4c8114;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease}.customer-menu-tab:hover{transform:translateY(-1px);box-shadow:0 12px 24px #0f4c811f}.customer-menu-tab.active{color:#103459;border-color:#f7c63a8c;background:linear-gradient(180deg,#fff8d6fa,#ffecadfa)}.customer-redeemed-spotlight{position:relative;overflow:hidden;gap:12px;padding:24px 26px;border:1px solid rgba(240,161,26,.2);background:radial-gradient(circle at top right,rgba(247,198,58,.26),transparent 28%),linear-gradient(180deg,#fffbf3fa,#fff5e3f5);box-shadow:0 20px 44px #8c5c0e1f,inset 0 1px #ffffffb8}.customer-redeemed-spotlight:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,#f0a11a,#f7c63a)}.customer-redeemed-spotlight-row{display:flex;align-items:baseline;justify-content:space-between;gap:16px}.customer-redeemed-spotlight-row strong{font-size:clamp(1.5rem,3vw,2.2rem);line-height:1;color:var(--ink)}.customer-redeemed-spotlight-row span{color:#2b475cd1;font-weight:700}@media(max-width:640px){.customer-menu-row{align-items:flex-start}.customer-menu-tabs{justify-content:flex-start}.customer-redeemed-spotlight-row{flex-direction:column;align-items:flex-start;gap:8px}}.customer-home-ribbon{grid-template-columns:repeat(2,minmax(0,1fr))}.customer-home-summary{max-width:420px}.customer-home-highlight{border-color:#31a86838}.customer-hero-warm{background:radial-gradient(circle at top left,rgba(247,198,58,.18),transparent 22%),radial-gradient(circle at 84% 8%,rgba(244,139,31,.14),transparent 22%),linear-gradient(180deg,#ffffffe0,#fff8effa),var(--surface)}.daily-brief,.history-featured,.scan-status-chip,.history-coupon-card{position:relative;overflow:hidden;border-radius:24px;border:1px solid var(--line);background:linear-gradient(180deg,#ffffffd1,#f8fcfef5),var(--surface-strong)}.daily-brief{padding:20px;gap:10px}.daily-brief:before,.history-featured:before,.scan-status-chip:before,.history-coupon-card:before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,#f48b1fc7,#17a7dcd6)}.daily-brief-warm{background:radial-gradient(circle at top right,rgba(247,198,58,.2),transparent 22%),linear-gradient(180deg,#ffffffe0,#fff6ebfa),var(--surface-strong)}.coffee-progress-card{position:relative;min-height:100%;padding:22px;gap:14px;box-shadow:0 28px 54px #0f4c8124,inset 0 1px #ffffffc2}.coffee-progress-card:after{content:"";position:absolute;inset:auto 18px 12px;height:28px;border-radius:999px;background:radial-gradient(circle,rgba(17,49,77,.16),transparent 72%);filter:blur(10px);z-index:0}.coffee-progress-head,.coffee-progress-copy,.milestone-preview,.coffee-progress-dots,.coffee-event-card{position:relative;z-index:1}.customer-cycle-progress .progress-bar{background:linear-gradient(90deg,#f0a11a,#f7c63a)}.coffee-cup-stage{position:relative;min-height:308px;border-radius:30px;background:radial-gradient(circle at top,rgba(255,255,255,.94),transparent 26%),radial-gradient(circle at 20% 24%,rgba(247,198,58,.2),transparent 22%),radial-gradient(circle at 84% 18%,rgba(23,167,220,.12),transparent 26%),linear-gradient(180deg,#f2f8fcf5,#fffaf5fa);border:1px solid rgba(15,76,129,.1);overflow:hidden;isolation:isolate}.coffee-cup-stage:before{content:"";position:absolute;inset:auto 12% 10px;height:22px;border-radius:999px;background:radial-gradient(circle,rgba(17,49,77,.16),transparent 72%);filter:blur(8px)}.coffee-cup-stage-unlocked{box-shadow:inset 0 0 0 1px #f7c63a3d,0 20px 34px #f48b1f1f}.coffee-stage-glow{position:absolute;top:10px;right:10px;bottom:10px;left:10px;border-radius:28px;background:radial-gradient(circle at 50% 30%,rgba(247,198,58,.26),transparent 30%),radial-gradient(circle at 30% 20%,rgba(244,139,31,.14),transparent 22%),radial-gradient(circle at 70% 22%,rgba(23,167,220,.14),transparent 24%);animation:rewardHalo 1.25s ease forwards;pointer-events:none;z-index:0}.coffee-point-flight{position:absolute;top:30px;left:24px;width:22px;height:22px;border-radius:999px;background:linear-gradient(135deg,#f7c63a,#f48b1f);box-shadow:0 0 0 8px #f7c63a29;z-index:4;animation:pointFlight 1s cubic-bezier(.22,1,.36,1) forwards}.coffee-steam{top:16px;width:24px;height:74px;border-color:#11314d24}.coffee-steam-a{left:calc(50% - 56px)}.coffee-steam-b{left:calc(50% - 12px)}.coffee-steam-c{left:calc(50% + 32px)}.coffee-cup-takeaway{--cup-fill: 0%;position:relative;width:min(100%,216px);z-index:1;filter:drop-shadow(0 22px 24px rgba(44,27,18,.16));transform-origin:center bottom}.coffee-cup-takeaway-complete{animation:cupSettle .9s cubic-bezier(.22,1,.36,1)}.coffee-cup-body{position:relative;height:246px;border-radius:20px 20px 42px 42px;border:1px solid rgba(15,76,129,.12);background:linear-gradient(180deg,#fffcf6fa,#f4e9d8f0 48%,#e9dfd0f5);overflow:hidden;clip-path:polygon(15% 0%,85% 0%,74% 100%,26% 100%);box-shadow:inset 0 1px #ffffffb3,0 24px 36px #0f4c811a,0 12px 18px #4a2e1c1f}.coffee-cup-body:before{content:"";position:absolute;top:10px;right:14px;bottom:20px;left:14px;border-radius:16px 16px 34px 34px;background:linear-gradient(180deg,rgba(255,255,255,.34),transparent 28%),linear-gradient(90deg,transparent 0%,rgba(255,255,255,.2) 18%,transparent 38%);border-top:4px solid rgba(126,81,45,.22);pointer-events:none}.coffee-cup-body:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.2),transparent 26%),radial-gradient(circle at 50% 118%,rgba(110,72,39,.16),transparent 28%);pointer-events:none}.coffee-liquid{position:absolute;inset:auto 2px 0;height:var(--cup-fill);min-height:0;border-radius:18px 18px 30px 30px;background:linear-gradient(180deg,#8d5527,#6d4020 48%,#4e2c18);transition:height .9s cubic-bezier(.22,1,.36,1)}.coffee-liquid:before{content:"";position:absolute;inset:-10px 0 auto;height:16px;background:radial-gradient(circle at 16% 60%,rgba(255,236,205,.86),transparent 24%),radial-gradient(circle at 48% 42%,rgba(255,236,205,.82),transparent 26%),radial-gradient(circle at 76% 58%,rgba(255,236,205,.82),transparent 24%);opacity:.86}.coffee-liquid-wave{position:absolute;left:-12%;width:124%;height:24px;border-radius:50%;background:#fff1e033}.coffee-liquid-wave-a{top:-10px;animation:coffeeWave 2.4s ease-in-out infinite alternate}.coffee-liquid-wave-b{top:-4px;opacity:.68;animation:coffeeWave 2.1s ease-in-out infinite alternate-reverse}.coffee-foam{position:absolute;inset:auto 20% calc(var(--cup-fill) - 8px);height:16px;border-radius:999px;background:radial-gradient(circle at 18% 56%,rgba(255,244,224,.72),transparent 22%),radial-gradient(circle at 48% 42%,rgba(255,244,224,.76),transparent 24%),radial-gradient(circle at 78% 50%,rgba(255,244,224,.7),transparent 22%);pointer-events:none}.coffee-cup-mark{position:absolute;inset:54% auto auto 50%;width:66px;height:66px;transform:translateY(-50%);display:grid;place-items:center;transform:translate(-50%,-50%);border-radius:999px;border:1px solid rgba(124,86,51,.18);background:radial-gradient(circle at 32% 28%,rgba(255,255,255,.48),transparent 28%),linear-gradient(180deg,#fff9eeeb,#e5d4bff5);box-shadow:0 12px 20px #6e482724,inset 0 1px #ffffff6b}.coffee-cup-mark-reward{background:radial-gradient(circle at 32% 28%,rgba(255,255,255,.5),transparent 28%),linear-gradient(180deg,#f7c63aeb,#f48b1ff5),var(--accent);box-shadow:0 16px 24px #f48b1f38,inset 0 1px #ffffff47}.coffee-cup-mark-medallion{position:relative;width:50px;height:50px;border-radius:999px;border:1px solid rgba(124,86,51,.14);background:radial-gradient(circle at 32% 28%,rgba(255,255,255,.34),transparent 28%),linear-gradient(180deg,#fffdf8db,#e7d6c3d6);box-shadow:inset 0 1px #ffffff4d,0 10px 16px #6e48271a}.coffee-cup-mark-reward .coffee-cup-mark-medallion{background:radial-gradient(circle at 32% 28%,rgba(255,255,255,.46),transparent 30%),linear-gradient(180deg,#fff9ebeb,#f1c071eb);box-shadow:inset 0 1px #ffffff4d,0 12px 20px #85420824}.coffee-cup-bean{position:absolute;top:12px;width:16px;height:24px;border-radius:60% 40% 58% 42%/52% 38% 62% 48%;background:linear-gradient(180deg,#9f693deb,#694125fa);box-shadow:inset -1px -2px #3f26142e}.coffee-cup-bean:after{content:"";position:absolute;top:3px;right:6px;bottom:3px;left:6px;border-radius:999px;background:#fff3e229;transform:rotate(8deg)}.coffee-cup-bean-left{left:11px;transform:rotate(-18deg)}.coffee-cup-bean-right{right:11px;transform:rotate(18deg)}.coffee-cup-mark-reward .coffee-cup-bean{background:linear-gradient(180deg,#794314eb,#5b2f09f5);box-shadow:inset -1px -2px #ffffff14}.coffee-cup-mark-reward .coffee-cup-bean:after{background:#ffffff2e}.coffee-gloss{position:absolute;inset:18px 30px 28px auto;width:20px;border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,.34),transparent);filter:blur(1px)}.coffee-reward-burst{position:absolute;top:18px;right:18px;bottom:18px;left:18px;border-radius:30px;background:radial-gradient(circle at 50% 50%,rgba(247,198,58,.28),transparent 36%),radial-gradient(circle at 24% 28%,rgba(244,139,31,.18),transparent 22%),radial-gradient(circle at 74% 30%,rgba(23,167,220,.16),transparent 24%);animation:rewardHalo 1.2s ease forwards;pointer-events:none}.coffee-reward-token-pop{position:absolute;top:68px;right:calc(50% - 126px);width:84px;min-height:92px;padding:14px 12px;border-radius:26px;background:linear-gradient(180deg,#fffffff5,#fff7ebfa),#fff;border:1px solid rgba(244,139,31,.18);box-shadow:0 24px 32px #f48b1f29,inset 0 1px #ffffffa8;display:grid;place-items:center;gap:2px;z-index:3;animation:rewardTokenRise 1.1s cubic-bezier(.22,1,.36,1) forwards}.coffee-reward-token-pop span{font-size:30px;font-weight:800;line-height:1;color:var(--accent)}.coffee-reward-token-pop strong{text-transform:uppercase;letter-spacing:.18em;font-size:10px;color:var(--brand)}.coffee-confetti{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:2}.coffee-confetti-piece{position:absolute;top:18px;left:var(--left);width:12px;height:22px;border-radius:999px;background:linear-gradient(180deg,#f7c63a,#f48b1f);transform:rotate(var(--rotate));animation:confettiDrop 1.2s ease-out var(--delay) forwards}.coffee-confetti-piece:nth-child(3n){background:linear-gradient(180deg,#17a7dc,#0f4c81)}.coffee-confetti-piece:nth-child(4n){background:linear-gradient(180deg,#31a868,#1f7d4b)}.coffee-event-card{padding:16px 18px;border-radius:20px;border:1px solid rgba(15,76,129,.12);background:#ffffffd1;display:grid;gap:8px;opacity:0;transform:translateY(10px);transition:opacity .26s ease,transform .26s ease}.coffee-event-card-visible{opacity:1;transform:translateY(0)}.coffee-event-card strong,.coffee-progress-copy strong{color:var(--brand);font-size:18px;line-height:1.35}.coffee-progress-copy{display:grid;gap:8px}.coffee-progress-dots{display:grid;grid-template-columns:repeat(10,minmax(0,1fr));gap:8px}.coffee-dot{height:10px;border-radius:999px;background:#11314d1f;transition:background .3s ease,transform .3s ease}.coffee-dot.active{background:linear-gradient(90deg,#f48b1f,#f7c63a);transform:scaleY(1.2)}.milestone-preview{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.milestone-card{padding:14px 12px;border-radius:20px;border:1px solid rgba(15,76,129,.1);background:#ffffffd1;display:grid;gap:6px}.milestone-card span{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-weight:800}.milestone-card strong{color:var(--brand);font-size:20px}.milestone-card p{color:var(--ink-soft);line-height:1.45}.reward-banner{background:radial-gradient(circle at top right,rgba(247,198,58,.24),transparent 22%),radial-gradient(circle at bottom left,rgba(23,167,220,.16),transparent 24%),linear-gradient(180deg,#ffffffe0,#fff7e9fa);border-color:#f48b1f2e;overflow:hidden}.reward-banner:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(115deg,rgba(255,255,255,.16),transparent 36%);pointer-events:none}.reward-banner-active{box-shadow:0 28px 42px #f48b1f24,inset 0 1px #ffffffb3}.reward-token-stack{display:flex;flex-wrap:wrap;gap:12px}.reward-token{width:58px;height:78px;border-radius:20px;border:1px solid rgba(15,76,129,.12);background:linear-gradient(180deg,#fffffff0,#eaf2f8fa);position:relative;overflow:hidden}.reward-token:before{content:"CAFÉ";position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#11314d75;font-size:10px;letter-spacing:.22em;font-weight:800}.reward-token.active{background:linear-gradient(180deg,#f7c63af0,#f48b1ff5);box-shadow:0 14px 24px #f48b1f2e}.reward-token.active:before{color:#11314d}.scanner-stage{gap:20px}.scanner-status-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.scan-status-chip{padding:16px 18px;display:grid;gap:8px}.scan-status-chip span{text-transform:uppercase;letter-spacing:.14em;font-size:11px;color:var(--ink-soft);font-weight:800}.scan-status-chip strong{color:var(--brand);font-size:18px;line-height:1.35;word-break:break-word}.scan-status-chip-live{background:linear-gradient(180deg,#ffffffe0,#f1f9f4fa),var(--surface-strong)}.scan-status-chip-ready{background:linear-gradient(180deg,#ffffffe0,#fff7ebfa),var(--surface-strong)}.scan-grid{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(300px,.92fr);gap:18px}.scanner-shell,.scan-side-panel,.public-coupon-panel,.public-coupon-steps,.history-moment-feed,.history-coupon-list{display:grid;gap:14px}.scanner-frame{position:relative;min-height:332px;padding:16px;border-radius:30px;overflow:hidden;border:1px solid rgba(15,76,129,.12);background:radial-gradient(circle at top left,rgba(247,198,58,.14),transparent 22%),radial-gradient(circle at bottom right,rgba(23,167,220,.16),transparent 22%),linear-gradient(180deg,#f1f7fbfa,#fffcf7fa);display:grid;place-items:center}.scanner-frame-live{box-shadow:0 20px 34px #0f4c811a}.scanner-frame-corners{position:absolute;top:18px;right:18px;bottom:18px;left:18px;border-radius:24px;border:1px dashed rgba(255,255,255,.08);background:linear-gradient(var(--accent),var(--accent)) left 0 top 0 / 28px 4px no-repeat,linear-gradient(var(--accent),var(--accent)) left 0 top 0 / 4px 28px no-repeat,linear-gradient(var(--accent),var(--accent)) right 0 top 0 / 28px 4px no-repeat,linear-gradient(var(--accent),var(--accent)) right 0 top 0 / 4px 28px no-repeat,linear-gradient(var(--accent),var(--accent)) left 0 bottom 0 / 28px 4px no-repeat,linear-gradient(var(--accent),var(--accent)) left 0 bottom 0 / 4px 28px no-repeat,linear-gradient(var(--accent),var(--accent)) right 0 bottom 0 / 28px 4px no-repeat,linear-gradient(var(--accent),var(--accent)) right 0 bottom 0 / 4px 28px no-repeat;pointer-events:none}.scanner-frame-line{position:absolute;left:22px;right:22px;top:22%;height:3px;border-radius:999px;background:linear-gradient(90deg,transparent,rgba(247,198,58,.96),transparent);box-shadow:0 0 16px #f7c63a52;animation:coffeeLineScan 2.3s ease-in-out infinite;z-index:2}.scanner-placeholder{position:relative;z-index:1;display:grid;gap:8px;text-align:center;max-width:28ch}.scanner-placeholder strong{color:var(--brand);font-size:24px;line-height:1.15;font-family:Fraunces,serif}.scanner-placeholder p{color:var(--ink-soft);line-height:1.55}.scan-manual-form{padding:18px;border-radius:24px;border:1px solid rgba(15,76,129,.1);background:#ffffffc7}.scan-primary-actions{max-width:420px}.scan-success-card{position:relative;overflow:hidden;opacity:.82;transition:transform .2s ease,opacity .2s ease,border-color .2s ease}.scan-success-card-visible{opacity:1;border-color:#31a86833;background:linear-gradient(180deg,#ffffffe6,#f1f9f4fa),var(--surface)}.scan-success-orbit{position:absolute;width:180px;height:180px;top:-84px;right:-72px;border-radius:999px;background:radial-gradient(circle,rgba(49,168,104,.18),transparent 64%);pointer-events:none}.scanner-stage-simple{gap:18px}.scan-grid-simple{align-items:start}.scan-side-panel-simple{align-content:start}.scan-result-card{display:grid;gap:12px}.history-hero-grid{align-items:stretch}.public-coupon-stage-simple{padding:40px 32px}.public-coupon-grid-simple{justify-items:start}.history-featured{padding:20px;gap:12px;align-content:start}.history-featured strong{color:var(--brand);font-size:24px;line-height:1.16}.history-featured p{color:var(--ink-soft);line-height:1.6}.history-filter-row{display:flex;flex-wrap:wrap;gap:10px}.history-filter-chip{border:1px solid var(--line);background:#ffffffc2;color:var(--brand);border-radius:999px;padding:11px 15px;font-weight:800;cursor:pointer;transition:transform .18s ease,border-color .18s ease,background .18s ease}.history-filter-chip.active{background:linear-gradient(135deg,#f7c63a,#f48b1f);border-color:#f48b1f3d;color:#11314d}.history-moment-card{display:grid;grid-template-columns:72px minmax(0,1fr);gap:16px;padding:18px;border-radius:24px;border:1px solid rgba(15,76,129,.1);background:linear-gradient(180deg,#ffffffe0,#f7fbfdfa),var(--surface)}.history-moment-card-warm{border-color:#f48b1f2e}.history-moment-card-success{border-color:#31a8682e}.history-moment-card-accent{border-color:#17a7dc2e}.history-moment-icon{width:72px;height:72px;border-radius:22px;display:grid;place-items:center;font-size:13px;letter-spacing:.18em;font-weight:800}.history-moment-icon-default{background:#0f4c811a;color:var(--brand)}.history-moment-icon-warm{background:#f48b1f1f;color:#a75a10}.history-moment-icon-success{background:#31a8681f;color:#1d7747}.history-moment-icon-accent{background:#17a7dc1f;color:#0f6f94}.history-moment-copy{display:grid;gap:10px}.history-coupon-panel{align-content:start}.history-coupon-card{padding:18px;gap:8px}.history-coupon-card strong{color:var(--brand);font-size:18px;line-height:1.35}.history-coupon-card p{color:var(--ink-soft);line-height:1.55}.public-coupon-stage{gap:18px}.public-coupon-grid{align-items:center}.public-coupon-ribbon{grid-template-columns:repeat(3,minmax(0,1fr))}.public-coupon-feedback-success{border-color:#31a86833;background:linear-gradient(180deg,#ffffffe6,#f1f9f4fa),var(--surface)}.public-coupon-cup-card{gap:18px}.public-coupon-cup-visual{display:grid;place-items:center;padding:8px 0 4px}.public-coupon-live-cup{width:min(100%,238px);min-height:248px;justify-self:center}.public-coupon-live-cup .coffee-cup-takeaway{width:min(100%,172px)}.public-coupon-live-cup .coffee-cup-body{height:176px}.public-coupon-cue{display:grid;gap:10px;justify-items:center;text-align:center}.public-coupon-cue p{max-width:26ch;color:var(--ink-soft);line-height:1.6}@keyframes pointFlight{0%{transform:translate(0) scale(.7);opacity:0}12%{opacity:1}65%{transform:translate(132px,126px) scale(1);opacity:1}to{transform:translate(162px,154px) scale(.3);opacity:0}}@keyframes rewardHalo{0%{transform:scale(.92);opacity:0}25%{opacity:1}to{transform:scale(1.04);opacity:0}}@keyframes coffeeLineScan{0%,to{transform:translateY(0);opacity:.4}50%{transform:translateY(180px);opacity:1}}@keyframes miniCupRise{0%{height:40%}to{height:56%}}@keyframes rewardTokenRise{0%{transform:translateY(28px) scale(.76) rotate(-8deg);opacity:0}30%{opacity:1}to{transform:translateY(0) scale(1) rotate(0);opacity:1}}@keyframes confettiDrop{0%{transform:translateY(-12px) rotate(var(--rotate)) scale(.8);opacity:0}25%{opacity:1}to{transform:translateY(168px) rotate(calc(var(--rotate) + 32deg)) scale(1);opacity:0}}@keyframes cupSettle{0%{transform:translateY(10px) scale(.94)}45%{transform:translateY(-6px) scale(1.03)}to{transform:translateY(0) scale(1)}}.terms{display:flex;align-items:flex-start;gap:12px;width:100%;padding:14px 16px;border-radius:var(--radius-md);border:1px solid rgba(15,76,129,.12);background:#ffffffd1;font-size:14px;color:var(--ink-soft);line-height:1.5}.terms input{width:auto;margin:2px 0 0;flex:0 0 auto;accent-color:var(--brand)}.terms span{min-width:0;flex:1;overflow-wrap:anywhere}.text-link{color:var(--brand);font-weight:800;text-decoration:none}.text-link:hover{text-decoration:underline}.print-layout{min-height:100vh;padding:18px;background:#eae3d9}.print-toolbar{max-width:1100px;margin:0 auto 18px;padding:18px 20px;border-radius:24px;border:1px solid rgba(45,32,23,.08);background:#ffffffd1;display:flex;justify-content:space-between;gap:16px;align-items:center}.print-loading{min-height:100vh;display:grid;place-items:center;font-family:Manrope,sans-serif;color:var(--brand)}.print-sheet-page{width:210mm;min-height:297mm;padding:8mm;margin:0 auto 18px;background:#fff;color:#17100b;box-shadow:0 16px 34px #0000001a;display:grid;grid-template-rows:auto 1fr;gap:3mm}.print-sheet-header{display:flex;justify-content:space-between;align-items:center;gap:8mm;padding-bottom:2.5mm;border-bottom:1px solid #d7cfc6}.print-sheet-brand{display:flex;align-items:center}.print-sheet-logo{width:56mm;max-width:100%;height:auto;display:block;object-fit:contain}.print-sheet-meta{display:grid;justify-items:end;text-align:right;gap:2px;font-size:11px;color:#4e433b}.print-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:2.6mm;align-content:start}.print-coupon{position:relative;min-height:50mm;padding:2.6mm;border:1px dashed #b5aba0;border-radius:3.5mm;display:grid;grid-template-rows:auto 1fr auto;gap:2.2mm;justify-items:center;background:#fff;break-inside:avoid;page-break-inside:avoid}.print-coupon-top{width:100%;display:flex;justify-content:space-between;align-items:center;gap:2mm}.print-coupon-logo{width:18mm;height:8.5mm;display:block;object-fit:contain}.print-coupon-number{font-size:10px;font-weight:800;color:#4e433b}.print-coupon-code{display:block;width:100%;text-align:center;font-size:13px;letter-spacing:.08em;line-height:1.24;word-break:break-word}.print-qr-frame{padding:1.4mm;border:1px solid #d7cfc6;border-radius:2.3mm;background:#fff;display:grid;place-items:center}.cut-mark{position:absolute;width:4mm;height:4mm;border-color:#a79c91;border-style:solid}.cut-mark-top-left{top:-1.4mm;left:-1.4mm;border-width:1px 0 0 1px}.cut-mark-top-right{top:-1.4mm;right:-1.4mm;border-width:1px 1px 0 0}.cut-mark-bottom-left{bottom:-1.4mm;left:-1.4mm;border-width:0 0 1px 1px}.cut-mark-bottom-right{bottom:-1.4mm;right:-1.4mm;border-width:0 1px 1px 0}@media(hover:hover){.card,.metric-card,.landing-panel-card,.ops-lane,.insight-item,.ribbon-item,.batch-card,.coupon-vault-card,.topbar-stat,.scan-preview-code,.scan-preview-status{transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.metric-card:hover,.landing-panel-card:hover,.ops-lane:hover,.insight-item:hover,.ribbon-item:hover,.batch-card:hover,.coupon-vault-card:hover,.topbar-stat:hover,.scan-preview-code:hover,.scan-preview-status:hover{transform:translateY(-2px);box-shadow:0 22px 34px #0f4c811a;border-color:var(--line-strong)}}@keyframes pulse{0%{transform:scale(.98)}to{transform:scale(1)}}@keyframes coffeeWave{0%{transform:translate(-4%)}to{transform:translate(4%)}}@keyframes steamRise{0%,to{transform:translateY(10px) scale(.92);opacity:0}30%,70%{opacity:.45}50%{transform:translateY(-10px) scale(1);opacity:.28}}@keyframes cupCelebrate{0%{transform:translateY(0) scale(1)}30%{transform:translateY(-4px) scale(1.01)}60%{transform:translateY(0) scale(1)}to{transform:translateY(0) scale(1)}}@media(max-width:960px){.landing-grid,.landing-grid-clean,.board-hero-grid,.topbar-grid-meta,.auth-grid,.history-layout,.admin-layout,.grid-2,.grid-3,.grid-4,.metric-grid,.scan-preview,.landing-ribbon,.scan-grid,.scanner-status-strip,.customer-hero-stage,.public-coupon-ribbon{grid-template-columns:1fr}.landing-brand-row{align-items:stretch}.landing-brand-note{width:100%}.landing-proof-card,.auth-inline-badges,.landing-minimal-steps,.hero-quick-stats,.milestone-preview,.coffee-progress-dots,.history-moment-card{grid-template-columns:1fr}.history-moment-icon{width:56px;height:56px}}@media(min-width:961px){.landing-public-grid{grid-template-columns:minmax(0,1.02fr) minmax(320px,.98fr);align-items:stretch}}@media(max-width:720px){.app-shell{padding:16px 12px 36px}.card,.topbar-shell{padding:20px}.landing-title{font-size:44px}.screen-title{font-size:36px}.hero-head,.section-head,.landing-brand-row,.print-toolbar{flex-direction:column;align-items:stretch}.hero-actions{display:grid;grid-template-columns:1fr}.social-links{grid-template-columns:1fr}.landing-inline-highlights{display:none}.brand-lockup{--logo-width: min(100%, 340px)}.brand-lockup-compact{--logo-width: min(100%, 230px)}.ledger-row{flex-direction:column;align-items:stretch}.ledger-side{justify-items:start;text-align:left;min-width:0}.print-layout{padding:8px}.coffee-cup-stage{min-height:258px}.coffee-cup-takeaway{width:min(100%,196px)}.coffee-cup-body{height:196px}.coffee-reward-token-pop{right:calc(50% - 104px);width:72px;min-height:80px}.public-coupon-live-cup{width:min(100%,206px);min-height:224px}.public-coupon-live-cup .coffee-cup-takeaway{width:min(100%,154px)}.public-coupon-live-cup .coffee-cup-body{height:160px}.terms{padding:12px 14px}.scanner-frame{min-height:280px}.history-filter-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.history-filter-chip{width:100%}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media print{@page{size:A4 portrait;margin:6mm}body{background:#fff;-webkit-print-color-adjust:exact;print-color-adjust:exact}body:before{display:none}.print-toolbar{display:none}.print-layout{padding:0;background:#fff}.print-sheet-page{width:auto;min-height:0;margin:0;padding:0;box-shadow:none;gap:1.5mm;break-after:page;page-break-after:always}.print-sheet-header{gap:4mm;padding-bottom:1.5mm}.print-sheet-logo{width:42mm}.print-sheet-meta{font-size:10px}.print-sheet-meta strong{font-size:12px}.print-grid{gap:1.8mm}.print-coupon{min-height:43mm;padding:1.8mm;border-radius:2.6mm;gap:1.5mm}.print-coupon-logo{width:14mm;height:6.5mm}.print-coupon-number{font-size:8px}.print-qr-frame{padding:1mm;border-radius:1.8mm}.print-coupon-code{font-size:11px;letter-spacing:.06em}.print-sheet-page:last-child{break-after:auto;page-break-after:auto}}
