:root{color:#2f241f;background:#f8efe4;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0;min-width:320px;background:#f8efe4}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.52}.app-shell{width:min(100%,720px);min-height:100vh;margin:0 auto;padding-bottom:98px;background:#f8efe4}.topbar{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;color:#f9e2a7;background:#6f1712;font-weight:750}.topbar small{font-weight:500;opacity:.88}.content{padding:18px 16px 28px}.hero{position:relative;overflow:hidden;margin:-18px -16px 18px;padding:42px 22px 26px;color:#fff4d8;background:linear-gradient(180deg,#490c09b8,#60120deb),url(/promo-ai-health-banner.png) center / cover}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#370907d6,#5c140e8f 58%,#370907d1);pointer-events:none}.hero>*{position:relative}.hero h1{max-width:520px;margin:8px 0 12px;font-size:42px;line-height:1.12;letter-spacing:0}.hero p{max-width:480px;margin:0;line-height:1.7;opacity:.94}.hero-button{margin-top:18px;background:#f8d889;color:#5a1711;box-shadow:0 10px 24px #25070533}.hero-info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;max-width:500px;margin-top:18px}.hero-info-grid div{min-height:64px;padding:10px;border:1px solid rgba(244,201,128,.48);border-radius:8px;background:#400c0985;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.hero-info-grid span{display:block;margin-bottom:4px;color:#e5bd74;font-size:12px}.hero-info-grid strong{display:block;color:#fff7de;font-size:16px;line-height:1.25}.card{margin:0 0 14px;padding:18px;border:1px solid #ead7bc;border-radius:8px;background:#fffaf2;box-shadow:0 8px 20px #5b21140f}.stack{display:grid;gap:12px}.card h1,.card h2{margin:0;font-size:20px}.card p{margin:0;line-height:1.65}.eyebrow{margin:0;color:#a66e2d;font-size:12px;font-weight:750;letter-spacing:.08em}.hero .eyebrow{color:#f2cf8a}.muted{color:#78675a;font-size:14px}.hint{padding:10px 12px;border-radius:8px;color:#6e2419;background:#f8e4d5;font-size:14px}.booking-summary{display:grid;gap:8px;width:100%;padding:14px;border:1px solid #dfb36e;border-radius:8px;color:#3b2923;background:linear-gradient(180deg,#fff4da,#f7dfb2);text-align:left}.booking-summary>span{color:#8e2419;font-size:13px;font-weight:750}.booking-summary strong{color:#5e1d16;font-size:24px;line-height:1.15}.booking-summary-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-weight:750}.booking-summary-status{padding:5px 8px;border-radius:999px;color:#fff8e5;background:#8e2419;font-size:13px}.primary,.secondary{min-height:44px;padding:10px 15px;border:0;border-radius:10px;font-weight:750}.primary{color:#fff8e5;background:#8e2419}.secondary{color:#6a2018;background:#f3dfbf}.danger-secondary{min-height:44px;padding:10px 15px;border:1px solid #d6a08f;border-radius:10px;color:#9b3023;background:#fff3ed;font-weight:750}.text-button{padding:4px;border:0;color:#8e2419;background:transparent;font-size:14px}.inverse{color:#fff}label{display:grid;gap:6px;color:#55362e;font-size:14px;font-weight:650}input{width:100%;min-height:44px;padding:10px 12px;border:1px solid #d9c0a1;border-radius:8px;color:#2f241f;background:#fffdf9}input:focus{outline:3px solid #f1d1a5;border-color:#a86b2e}.account-card{display:flex;align-items:center;justify-content:space-between;gap:12px}.account-card h2{margin-top:3px}.account-card p{margin:4px 0 0;color:#78675a}.schedule-card{border-color:#d7a85f;background:linear-gradient(180deg,#fffaf2,#fff2dd)}.detail-list{display:grid;gap:10px}.detail-list p{display:grid;grid-template-columns:72px minmax(0,1fr);gap:10px;align-items:start}.detail-list strong{color:#8e2419}.promo-strip{margin:0 0 14px;padding:18px;border:1px solid #ead7bc;border-radius:8px;color:#3b2923;background:linear-gradient(180deg,#fff8ee,#fff3e5)}.promo-strip h2{margin:0;font-size:21px}.promo-strip p{margin:0;line-height:1.55}.promo-tags{display:flex;flex-wrap:wrap;gap:8px}.promo-tags span{padding:7px 10px;border:1px solid #e3c08b;border-radius:8px;color:#8e2419;background:#fffaf2;font-size:13px;font-weight:750}.qr{display:block;width:min(100%,360px);margin:0 auto;border-radius:8px}.compact{max-width:220px}.flash{margin-bottom:12px;padding:11px 13px;border-radius:10px;font-size:14px}.flash.error{color:#9b3023;background:#fbe1d9}.flash.success{color:#5c3d11;background:#f7e5bc}.date-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:3px}.date-option{display:grid;flex:0 0 92px;gap:4px;min-height:62px;padding:11px 8px;border:1px solid #ead2ac;border-radius:8px;color:#56342c;background:#fffaf2;text-align:left}.date-option span,.slot span{color:#826f60;font-size:12px}.date-option.selected,.slot.selected{border-color:#8e2419;color:#fff8e5;background:#8e2419}.date-option.selected span,.slot.selected span{color:#f4d9a1}.date-option.sold-out{opacity:.62}.slot-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:8px}.slot{display:grid;gap:4px;min-height:66px;padding:10px;border:1px solid #ead2ac;border-radius:8px;color:#56342c;background:#fffaf2;text-align:left}.slot.disabled{color:#9a8f86;background:#f0e6d8}.row{display:flex;align-items:center;justify-content:space-between;gap:12px}.tag{flex:0 0 auto;padding:5px 8px;border-radius:999px;color:#7a241a;background:#f5ddbd;font-size:12px}code{display:block;overflow-wrap:anywhere;padding:11px;border-radius:8px;color:#622018;background:#f4e2c5;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:16px;font-weight:700}.code-card{display:grid;grid-template-columns:1fr;gap:12px;justify-items:center;align-items:center}.code-card code{width:min(100%,360px);text-align:center;font-size:18px}.qr-box{display:grid;place-items:center;width:min(100%,240px);aspect-ratio:1 / 1;padding:10px;border:1px solid #ead2ac;border-radius:8px;background:#fffdf8}.qr-svg{display:block;width:100%;height:auto;fill:#201713}.empty{text-align:center}.bottom-nav{position:fixed;bottom:0;left:50%;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px;width:min(100%,720px);padding:8px 10px calc(8px + env(safe-area-inset-bottom));border-top:1px solid #e6cda8;background:#fffaf1fa;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transform:translate(-50%)}.bottom-nav button{display:grid;justify-items:center;gap:3px;min-width:0;min-height:62px;padding:6px 4px;border:0;border-radius:8px;color:#7b6c62;background:transparent;font-size:13px;font-weight:700}.bottom-nav button.active{color:#8e2419;background:#f6e7ca}.nav-icon{display:grid;place-items:center;width:30px;height:30px;border-radius:999px;color:inherit}.nav-icon svg{width:23px;height:23px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.bottom-nav button.active .nav-icon{color:#f6d58d;background:#8e2419}.staff-shell .topbar{background:#293843}.inline-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.action-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.check{display:flex;align-items:center;gap:9px}.check input{width:18px;min-height:18px}.scan-panel{display:grid;gap:8px}.scanner{width:100%;max-height:340px;border-radius:8px;background:#18221c;object-fit:cover}@media(max-width:390px){.hero h1{font-size:36px}.hero-info-grid{grid-template-columns:1fr 1fr}.inline-form{grid-template-columns:1fr}.qr-box{width:min(100%,220px)}}
