:root{color:#25221f;background:#f8f5ef;font-family:Inter,Noto Sans JP,Hiragino Sans,Yu Gothic,Meiryo,system-ui,sans-serif;font-synthesis:none;text-rendering:geometricPrecision;--gold: #bd8d2e;--gold-dark: #9f741f;--ink: #27231f;--muted: #736b61;--line: #e9e0d4;--panel: #fffdfa;--soft: #f4ead8;--green: #16845a;--red: #cf3f35;--shadow: 0 18px 50px rgba(38, 31, 21, .12)}*{box-sizing:border-box}html{scrollbar-gutter:stable;touch-action:manipulation}body{margin:0;min-width:320px;overflow-x:hidden;-webkit-text-size-adjust:100%}button,input{font:inherit}input,select,textarea{font-size:16px}button{cursor:pointer;touch-action:manipulation}.app-shell{min-height:100vh}.role-reset-button{position:fixed;right:12px;bottom:calc(76px + env(safe-area-inset-bottom));z-index:30;min-height:32px;padding:0 10px;color:#27231f9e;background:#fffdfac2;border:1px solid rgba(233,224,212,.86);border-radius:999px;box-shadow:0 8px 24px #261f1514;font-size:12px;font-weight:800}.role-reset-button:focus-visible{color:var(--ink);outline:2px solid var(--gold);outline-offset:2px}.app-launch{display:grid;min-height:100dvh;place-content:center;justify-items:center;gap:12px;padding:24px;background:var(--panel)}.app-launch img{width:86px;height:86px;border-radius:22px;box-shadow:0 14px 36px #261f1529}.app-launch strong{color:var(--gold-dark);font-size:20px;letter-spacing:0}.app-fallback{display:grid;min-height:100vh;place-items:center;padding:24px}.app-fallback section{display:grid;gap:12px;width:min(440px,100%);padding:24px;background:var(--panel);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.app-fallback span{color:var(--gold-dark);font-weight:900}.app-fallback h1{margin:0;font-size:24px;letter-spacing:0}.app-fallback p{margin:0;color:var(--muted);line-height:1.7}.app-fallback .fallback-error{padding:10px 12px;color:var(--red);background:#fff6f4;border:1px solid #f1c6c0;border-radius:8px;font-size:13px;word-break:break-word}.app-fallback button{min-height:44px;margin-top:4px;color:#fff;background:var(--gold);border:0;border-radius:999px;font-weight:900}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:16px clamp(16px,4vw,48px);background:#fffdfaeb;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.brand{display:flex;align-items:center;gap:14px}.brand.dark{color:#fff;margin-bottom:18px}.brand-mark{display:grid;place-items:center;width:52px;height:52px;border-radius:50%;color:#fff;font-weight:850;letter-spacing:0;background:radial-gradient(circle at 30% 20%,#3c3a37,#111);box-shadow:inset 0 0 0 1px #ffffff29}.brand-name{margin:0;font-size:28px;font-weight:780;letter-spacing:.08em}.brand-copy{margin:2px 0 0;color:var(--gold-dark);font-weight:700}.mode-switch{display:flex;gap:8px;padding:5px;background:#eee6da;border:1px solid var(--line);border-radius:999px}.mode-switch button{display:flex;align-items:center;gap:7px;min-height:42px;padding:0 18px;color:var(--muted);background:transparent;border:0;border-radius:999px}.mode-switch .active{color:#fff;background:var(--ink)}.account-switch{display:flex;align-items:center;gap:8px;padding:5px;background:#eee6da;border:1px solid var(--line);border-radius:999px}.account-switch span{padding:0 10px;color:var(--gold-dark);font-weight:800}.account-switch button{min-height:38px;padding:0 14px;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:999px;font-weight:800}.account-switch button:first-of-type{color:#fff;background:var(--ink);border-color:var(--ink)}.login-layout{display:flex;justify-content:center;padding:clamp(24px,4vw,56px) 16px 48px}.login-panel{width:min(760px,100%);padding:24px;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow)}.login-hero{display:grid;gap:8px;margin-bottom:18px}.login-kicker{width:fit-content;padding:5px 10px;color:var(--gold-dark);background:#fff8ec;border:1px solid #ead2a6;border-radius:999px;font-size:12px;font-weight:900}.login-hero h1{margin:0;font-size:28px;letter-spacing:0}.login-hero p{margin:0;color:var(--muted)}.login-role-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.login-role-grid button{display:grid;align-content:start;gap:8px;min-height:150px;padding:18px;text-align:left;background:#fff;border:1px solid var(--line);border-radius:8px}.login-role-grid button:hover,.login-role-grid button:focus-visible{border-color:var(--gold)}.login-role-grid svg{color:var(--gold-dark)}.login-role-grid strong{font-size:18px}.login-role-grid span{color:var(--muted);font-size:13px}.login-status{display:flex;justify-content:space-between;gap:12px;margin-top:14px;padding-top:14px;color:var(--muted);border-top:1px solid var(--line)}.login-status strong{color:var(--green)}.customer-layout{display:flex;justify-content:center;min-height:100vh;padding:0}.phone-panel{position:relative;display:none;overflow:hidden;width:min(430px,100%);min-height:720px;padding:0 0 70px;background:var(--panel);border:0;border-radius:0;box-shadow:none}.phone-panel.active{display:block}.phone-header{display:grid;grid-template-columns:36px 1fr 36px;align-items:center;min-height:56px;padding:0 12px;border-bottom:1px solid var(--line)}.phone-header strong{text-align:center}.phone-header button{width:32px;height:32px;color:var(--ink);background:transparent;border:0;font-size:28px}.hero{position:relative;display:flex;align-items:end;overflow:hidden;min-height:144px;padding:20px;color:#fff;background:linear-gradient(90deg,#21180ec7,#21180e2e),radial-gradient(circle at 72% 34%,rgba(255,255,255,.75) 0 6%,transparent 7%),radial-gradient(circle at 82% 55%,rgba(214,178,102,.68) 0 10%,transparent 11%),linear-gradient(135deg,#d3b574,#7a623e 48%,#201c18)}.hero-photo{position:absolute;top:0;right:0;bottom:0;left:0;background-position:center;background-size:cover}.hero-photo:after{position:absolute;top:0;right:0;bottom:0;left:0;content:"";background:linear-gradient(90deg,#1c1610d6,#1c161047),linear-gradient(180deg,#0000,#00000040)}.hero>div{position:relative;z-index:1}.hero h1{margin:0 0 8px;font-size:22px}.hero p{max-width:260px;margin:0;font-size:13px;line-height:1.7}.point-card{display:grid;grid-template-columns:1fr auto;gap:8px;margin:14px;padding:16px;background:linear-gradient(135deg,#fff8ec,#f2dfbd);border:1px solid #ead2a6;border-radius:8px}.point-card span{color:var(--muted);font-size:12px}.point-card strong{color:var(--gold-dark);font-size:34px;line-height:1}.point-card strong span{color:var(--gold-dark);font-size:18px}.point-card button{align-self:center;padding:8px 12px;color:var(--gold-dark);background:#fff;border:1px solid #d8bc82;border-radius:999px}.point-card.compact{margin-top:12px}.section-title{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:4px 16px 10px}.section-title h2{margin:0;font-size:15px}.section-title button{color:var(--gold-dark);background:transparent;border:0;font-size:12px}.category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:0 14px 16px}.category-grid button{display:grid;gap:6px;place-items:center;min-height:64px;color:var(--gold-dark);background:#fff;border:1px solid transparent;border-radius:8px;font-size:11px}.category-grid .selected{border-color:var(--gold);background:#fff7e8}.shop-strip{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 14px}.shop-strip button{overflow:hidden;padding:0;text-align:left;background:#fff;border:1px solid var(--line);border-radius:8px}.visual-thumb{display:block;width:100%;height:78px;border-radius:7px 7px 0 0;background-color:#f4eee5;background-repeat:no-repeat}.shop-row .visual-thumb{width:118px;height:92px;border-radius:6px}.visual-thumb.salon,.shop-hero.salon{background:radial-gradient(circle at 28% 28%,rgba(255,255,255,.8) 0 8%,transparent 9%),radial-gradient(circle at 70% 38%,rgba(196,146,50,.45) 0 14%,transparent 15%),linear-gradient(135deg,#efe4d2,#c39955 48%,#2b241c)}.visual-thumb.esthetic,.shop-hero.esthetic{background:radial-gradient(circle at 72% 25%,rgba(255,255,255,.78) 0 9%,transparent 10%),radial-gradient(circle at 32% 62%,rgba(91,141,128,.52) 0 16%,transparent 17%),linear-gradient(135deg,#f2d8cb,#c59a88 52%,#4d3b35)}.visual-thumb.care,.shop-hero.care{background:radial-gradient(circle at 28% 28%,rgba(255,255,255,.78) 0 9%,transparent 10%),radial-gradient(circle at 70% 62%,rgba(115,148,166,.55) 0 16%,transparent 17%),linear-gradient(135deg,#dde8e6,#9db5ad 52%,#37413e)}.visual-thumb.has-image,.shop-hero.has-image{background-position:center;background-repeat:no-repeat;background-size:cover}.shop-strip .visual-thumb{height:96px;padding:0}.shop-strip button>span:not(.visual-thumb){display:block;padding:8px;font-weight:700;font-size:12px}.shop-search-card{display:grid;gap:10px;margin:12px 12px 0;padding:12px;background:#fff;border:1px solid var(--line);border-radius:8px}.shop-search-card label{display:flex;gap:8px;align-items:center;min-height:40px;padding:0 12px;color:var(--gold-dark);background:#fffaf2;border:1px solid #ead2a6;border-radius:999px}.shop-search-card input{width:100%;min-width:0;border:0;outline:0;background:transparent;color:var(--ink);font-size:13px}.area-chip-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.area-chip-row::-webkit-scrollbar{display:none}.area-chip-row button{flex:0 0 auto;min-height:32px;padding:0 12px;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:999px;font-size:12px;font-weight:800}.area-chip-row button.active{color:#fff;background:var(--gold);border-color:var(--gold)}.tabs{display:grid;grid-template-columns:repeat(3,1fr);padding:12px 10px 4px}.tabs button{min-height:34px;color:var(--muted);background:transparent;border:0;border-bottom:2px solid transparent;font-size:12px}.tabs .active{color:var(--gold-dark);border-bottom-color:var(--gold)}.list-result-summary{margin:8px 14px 0;color:var(--muted);font-size:12px;font-weight:800}.shop-list{display:grid;gap:10px;padding:10px 12px}.shop-row{display:grid;grid-template-columns:118px minmax(0,1fr) auto;gap:12px;align-items:start;padding:12px;text-align:left;background:#fff;border:1px solid var(--line);border-radius:8px}.shop-row.active{border-color:var(--gold);box-shadow:0 8px 18px #bd8d2e2e}.shop-row img{width:82px;height:82px;object-fit:contain;border-radius:6px}.shop-row strong{display:block;font-size:14px;line-height:1.35}.shop-row p,.shop-row span:not(.visual-thumb){display:flex;align-items:center;gap:3px;margin:5px 0;color:var(--muted);font-size:11px}.shop-row em{padding:4px 8px;color:#fff;background:var(--gold);border-radius:999px;font-style:normal;font-weight:800;font-size:12px}.shop-hero{position:relative;display:flex;align-items:end;min-height:190px;padding:18px;color:#fff;background-color:#f4eee5;background-repeat:no-repeat}.shop-hero:before{position:absolute;top:0;right:0;bottom:0;left:0;content:"";background:linear-gradient(180deg,#0000000d,#00000094)}.shop-hero h2,.shop-hero button{position:relative;z-index:1}.shop-hero h2{margin:0;font-size:24px}.shop-hero button{position:absolute;top:16px;left:16px;display:grid;place-items:center;width:38px;height:38px;padding:0;color:#fff;background:#00000057;border:0;border-radius:50%;line-height:0}.detail-body{padding:14px}.scoreline{display:flex;justify-content:space-between;gap:12px;color:var(--gold-dark);font-weight:800}.scoreline span{display:inline-flex;align-items:center;gap:5px}.tag{display:inline-block;padding:5px 10px;background:#f3eadb;border-radius:999px;font-size:12px}.quick-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:14px 0}.quick-actions button{display:grid;gap:4px;place-items:center;min-height:54px;color:var(--gold-dark);background:#fff;border:1px solid var(--line);border-radius:8px;font-size:12px}.quick-actions button.active{color:#fff;background:var(--gold);border-color:var(--gold)}.menu-row{display:flex;justify-content:space-between;width:100%;min-height:44px;padding:0 6px;background:#fff;border:0;border-bottom:1px solid var(--line)}.menu-row.selected{color:var(--gold-dark)}.primary-button{width:calc(100% - 28px);min-height:48px;margin:18px 14px 0;color:#fff;background:linear-gradient(135deg,#c99b3c,#a97821);border:0;border-radius:999px;font-weight:800}.primary-button:disabled{cursor:not-allowed;opacity:.48}.secondary-button{width:calc(100% - 28px);min-height:44px;margin:10px 14px 0;color:var(--gold-dark);background:#fff;border:1px solid var(--line);border-radius:999px;font-weight:800}.danger-button{width:calc(100% - 28px);min-height:44px;margin:10px 14px 0;color:var(--red);background:#fff;border:1px solid #f0c8c2;border-radius:999px;font-weight:800}.booking-note{margin:10px 14px 0;padding:12px;color:var(--muted);background:#fff8ec;border:1px solid #ead2a6;border-radius:8px;font-size:12px;text-align:center}.calendar,.booking-summary,.reward-preview{margin:16px 14px;padding:14px;background:#fff;border:1px solid var(--line);border-radius:8px}.booking-shop-card{display:grid;grid-template-columns:72px minmax(0,1fr);gap:12px;align-items:center;margin:14px;padding:12px;background:#fff;border:1px solid var(--line);border-radius:8px}.booking-shop-card .visual-thumb{width:72px;height:60px}.booking-shop-card strong,.booking-shop-card p{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.booking-shop-card p{margin:5px 0 0;color:var(--muted);font-size:12px}.booking-section{margin:14px 0}.booking-step-title{display:flex;align-items:center;gap:8px;margin:0 14px 10px}.booking-step-title span{display:grid;place-items:center;width:24px;height:24px;color:#fff;background:var(--gold);border-radius:50%;font-size:12px;font-weight:900}.booking-step-title strong{font-size:15px}.booking-menu-list{display:grid;gap:8px;padding:0 14px}.booking-menu-option{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px;align-items:center;min-height:64px;padding:12px;text-align:left;background:#fff;border:1px solid var(--line);border-radius:8px}.booking-menu-option.selected{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold) inset}.booking-menu-option div{display:grid;gap:4px;min-width:0}.booking-menu-option strong,.booking-menu-option p{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.booking-menu-option p{margin:0;color:var(--muted);font-size:12px}.booking-menu-option span{font-weight:900}.booking-menu-option em{padding:4px 8px;color:#fff;background:var(--gold);border-radius:999px;font-size:12px;font-style:normal;font-weight:900}.booking-section .calendar{margin-top:0}.point-use-box{display:grid;gap:10px;margin:0 14px;padding:14px;background:#fff;border:1px solid var(--line);border-radius:8px}.point-use-box>div:first-child{display:flex;align-items:center;justify-content:space-between;gap:12px}.point-use-box span,.point-use-box label{color:var(--muted);font-size:12px}.point-use-box label{display:grid;gap:6px}.point-use-box input{min-height:42px;padding:0 12px;border:1px solid var(--line);border-radius:8px;font-size:18px;font-weight:900}.point-use-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.point-use-actions button{min-height:38px;color:var(--gold-dark);background:#fff8ec;border:1px solid #ead2a6;border-radius:999px;font-weight:800}.calendar-title,.date-label{text-align:center;font-weight:800}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-top:12px}.week-grid span,.day{display:grid;place-items:center;min-height:28px;border-radius:50%;font-size:12px}.day{background:transparent;border:0;cursor:pointer}.day:hover,.day:focus-visible{color:var(--gold-dark);background:#fff7e5}.day.selected{color:#fff;background:var(--gold)}.time-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;padding:0 14px}.time-grid button{min-height:38px;background:#fff;border:1px solid var(--line);border-radius:999px}.time-grid .selected{color:#fff;background:var(--gold);border-color:var(--gold)}.empty-slots{grid-column:1 / -1;padding:12px;color:var(--muted);background:#fff8ec;border:1px solid #ead2a6;border-radius:8px;font-size:12px;text-align:center}.availability-note{margin:8px 14px 0;color:var(--muted);font-size:11px;text-align:center}.booking-summary{display:flex;justify-content:space-between;gap:12px}.booking-checkout{display:grid;gap:10px}.booking-checkout div{display:flex;align-items:center;justify-content:space-between;gap:12px}.booking-checkout span{color:var(--muted);font-size:12px}.booking-checkout strong{text-align:right}.booking-checkout .booking-total{padding-top:10px;border-top:1px solid var(--line)}.booking-checkout .booking-total strong{color:var(--gold-dark);font-size:20px}.booking-detail-card{display:grid;gap:10px;margin:16px 14px;padding:14px;background:#fff;border:1px solid var(--line);border-radius:8px}.booking-detail-card div,.detail-summary{display:flex;align-items:center;justify-content:space-between;gap:12px}.booking-detail-card span,.detail-summary span{color:var(--muted);font-size:12px}.booking-detail-card strong,.detail-summary strong{text-align:right}.booking-detail-card mark{padding:4px 8px;color:var(--green);background:#e9f5ef;border-radius:999px;font-size:12px;font-weight:800}.reservation-list{display:grid;gap:10px;padding:14px}.booking-history-tabs{display:flex;gap:8px;overflow-x:auto;padding:12px 14px 0;scrollbar-width:none}.booking-history-tabs::-webkit-scrollbar{display:none}.booking-history-tabs button{display:inline-flex;flex:0 0 auto;gap:8px;align-items:center;min-height:34px;padding:0 12px;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:999px;font-size:12px;font-weight:800}.booking-history-tabs button strong{color:var(--gold-dark);font-size:11px}.booking-history-tabs button.active{color:#fff;background:var(--gold);border-color:var(--gold)}.booking-history-tabs button.active strong{color:#fff}.reservation-list button{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:10px;min-height:82px;padding:12px;text-align:left;background:#fff;border:1px solid var(--line);border-radius:8px}.reservation-list div{display:grid;gap:4px}.reservation-list span,.reservation-list em{color:var(--muted);font-size:12px;font-style:normal}.reservation-list mark{padding:4px 8px;color:var(--green);background:#e9f5ef;border-radius:999px;font-size:11px;font-weight:800}.favorite-list{display:grid;gap:10px;padding:14px}.favorite-row{display:grid;grid-template-columns:1fr 42px;gap:8px;align-items:stretch}.favorite-row>button:first-child{display:grid;grid-template-columns:58px 1fr auto;align-items:center;gap:10px;min-height:76px;padding:10px;text-align:left;background:#fff;border:1px solid var(--line);border-radius:8px}.favorite-row div{display:grid;gap:4px}.favorite-row span,.favorite-row em{color:var(--muted);font-size:12px;font-style:normal}.icon-action{display:grid;place-items:center;color:#fff;background:var(--gold);border:0;border-radius:8px}.empty-state{display:grid;place-items:center;gap:8px;margin:16px 14px;padding:28px 16px;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:8px;text-align:center}.empty-state strong{color:var(--ink)}.notice-summary{display:flex;align-items:center;gap:12px;margin:16px 14px 10px;padding:14px;color:var(--gold-dark);background:#fff8ec;border:1px solid #efd9ae;border-radius:8px}.notice-summary div{display:grid;gap:2px}.notice-summary span{color:var(--muted);font-size:12px}.notice-summary strong{font-size:18px}.notice-list{display:grid;gap:10px;padding:0 14px 80px}.notice-card{display:grid;gap:8px;padding:13px;background:#fff;border:1px solid var(--line);border-radius:8px}.notice-card.unread{border-color:#d8ad55;box-shadow:inset 3px 0 0 var(--gold)}.notice-card div{display:flex;align-items:center;justify-content:space-between;gap:8px}.notice-card span,.notice-card em,.notice-card time{color:var(--muted);font-size:11px;font-style:normal}.notice-card em{padding:3px 7px;color:#fff;background:var(--gold);border-radius:999px;font-weight:800}.notice-card p{margin:0;color:var(--muted);font-size:12px;line-height:1.6}.done-state{display:grid;place-items:center;min-height:610px;padding:30px 18px;text-align:center}.done-icon{display:grid;place-items:center;width:92px;height:92px;color:#fff;background:var(--gold);border-radius:50%;font-size:48px}.profile{display:flex;align-items:center;gap:12px;padding:18px 16px 8px}.avatar{display:grid;place-items:center;width:54px;height:54px;background:#d8d5d0;border-radius:50%;font-weight:800}.settings-list{display:grid;padding:4px 14px 12px}.settings-list button{display:flex;justify-content:space-between;min-height:46px;padding:0 4px;background:transparent;border:0;border-bottom:1px solid var(--line)}.history{padding-top:4px}.history-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 16px;border-top:1px solid var(--line);font-size:12px}.history-row strong.plus,.history-row strong[class=plus],.history-row .plus{color:var(--green)}.history-row strong.minus{color:var(--red)}.mobile-nav{position:absolute;right:0;bottom:0;left:0;display:grid;grid-template-columns:repeat(5,1fr);min-height:58px;background:#fffdfaf5;border-top:1px solid var(--line)}.mobile-nav button{display:grid;place-items:center;gap:2px;color:var(--muted);background:transparent;border:0;font-size:10px}.mobile-nav .active{color:var(--gold-dark)}.merchant-layout{display:grid;grid-template-columns:246px minmax(0,1fr);align-items:start;min-height:100vh;padding:18px;gap:18px}.sidebar{align-self:start;padding:22px 16px;background:linear-gradient(180deg,#272a28,#151716);border-radius:8px;box-shadow:var(--shadow)}.sidebar button{display:flex;align-items:center;gap:10px;width:100%;height:46px;min-height:46px;margin:4px 0;padding:0 12px;color:#f8f5ef;background:transparent;border:1px solid transparent;border-radius:8px;text-align:left;font-weight:800;white-space:nowrap}.sidebar .active{background:var(--gold);border-color:var(--gold)}.sidebar button:focus-visible{outline:2px solid #fff;outline-offset:-5px}.merchant-main{min-width:0}.merchant-top{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:18px;padding:6px 4px}.merchant-top h1{margin:0 0 6px;font-size:clamp(24px,3vw,38px)}.merchant-top p{margin:0;color:var(--muted)}.merchant-user{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#fff;border:1px solid var(--line);border-radius:999px}.merchant-avatar{display:block;width:34px;height:34px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#fff 0 18%,transparent 19%),linear-gradient(135deg,#c99b3c,#27231f)}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(170px,1fr));gap:14px}.metric,.panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;box-shadow:0 10px 30px #261f150f}.metric{position:relative;min-height:150px;padding:18px}.metric-icon{position:absolute;top:16px;right:16px;color:var(--gold)}.metric span{color:var(--muted);font-size:13px}.metric strong{display:block;margin:18px 0 10px;color:var(--gold-dark);font-size:30px}.metric.danger strong{color:var(--red)}.metric.success strong{color:var(--green)}.metric p{margin:0;color:var(--muted)}.dashboard-grid{display:grid;grid-template-columns:repeat(3,minmax(300px,1fr));align-items:start;gap:14px;margin-top:14px}.merchant-hidden,.merchant-view .merchant-panel{display:none}.merchant-view-dashboard .merchant-panel-dashboard,.merchant-view-bookings .merchant-panel-bookings,.merchant-view-availability .merchant-panel-availability,.merchant-view-points .merchant-panel-points,.merchant-view-score .merchant-panel-score,.merchant-view-menus .merchant-panel-menus,.merchant-view-store .merchant-panel-store,.merchant-view-settings .merchant-panel-settings{display:block}.merchant-view-bookings,.merchant-view-availability,.merchant-view-points,.merchant-view-score,.merchant-view-menus,.merchant-view-settings{grid-template-columns:minmax(0,1fr)}.merchant-view-bookings .merchant-panel-bookings,.merchant-view-availability .merchant-panel-availability,.merchant-view-points .merchant-panel-points,.merchant-view-score .merchant-panel-score,.merchant-view-menus .merchant-panel-menus,.merchant-view-settings .merchant-panel-settings{grid-column:1 / -1}.panel{min-width:0;min-height:260px;padding:18px}.panel.wide,.panel.availability-panel{grid-column:span 2}.panel h2{margin:0 0 14px;font-size:19px}.chart{display:grid;grid-template-columns:repeat(6,1fr);align-items:end;gap:18px;height:190px;padding:18px 12px 4px;border-bottom:1px solid var(--line)}.bar-wrap{display:grid;align-items:end;gap:5px;height:100%;text-align:center}.bar-wrap span{display:block;width:100%;max-width:44px;margin:0 auto;background:linear-gradient(180deg,#d8b66f,#ebd6ad);border-radius:6px 6px 0 0}.bar-wrap em{color:var(--muted);font-style:normal;font-size:12px}.bar-wrap strong{color:var(--gold-dark);font-size:12px;line-height:1}.bar-wrap small{color:var(--muted);font-size:11px;line-height:1}.notice-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;width:100%;min-height:48px;background:transparent;border:0;border-bottom:1px solid var(--line);text-align:left}.notice-row span{padding:2px 6px;color:#fff;background:#e5b12f;border-radius:4px;font-size:10px;font-weight:800}.table-list{display:grid;gap:8px}.booking-filter-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:14px}.booking-filter-tabs{display:flex;flex:1 1 420px;flex-wrap:wrap;gap:8px}.booking-filter-tabs button,.booking-filter-clear,.booking-date-filter{min-height:38px;border:1px solid var(--line);border-radius:999px;background:#fff}.booking-filter-tabs button{display:inline-flex;gap:8px;align-items:center;justify-content:center;padding:0 14px;color:var(--muted);font-weight:800}.booking-filter-tabs button strong{color:var(--gold-dark);font-size:12px}.booking-filter-tabs button.active{color:#fff;background:var(--gold);border-color:var(--gold)}.booking-filter-tabs button.active strong{color:#fff}.booking-date-filter{display:inline-flex;gap:8px;align-items:center;padding:0 12px;color:var(--muted);font-size:12px;font-weight:800}.booking-date-filter input{min-width:132px;border:0;background:transparent;color:var(--ink);font:inherit}.booking-filter-clear{padding:0 12px;color:var(--gold-dark);font-size:12px;font-weight:800}.table-row{display:grid;grid-template-columns:1.1fr 1fr 1fr auto;gap:10px;align-items:center;min-height:46px;padding:10px;background:#fff;border:1px solid var(--line);border-radius:8px;font-size:12px}.table-row>*{min-width:0}.table-row strong,.table-row em{overflow-wrap:anywhere}.compact-row{grid-template-columns:1.4fr auto auto auto}.booking-action-row{grid-template-columns:minmax(120px,.8fr) minmax(120px,.8fr) minmax(160px,1fr) max-content minmax(230px,auto) max-content;align-items:center;row-gap:10px}.booking-action-row.selected{border-color:var(--gold);box-shadow:0 0 0 2px #c6922524}.booking-action-row mark{width:fit-content}.booking-action-row .booking-actions{justify-content:flex-end}.booking-actions{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.booking-actions button{min-height:30px;padding:0 10px;color:var(--gold-dark);background:#fff;border:1px solid var(--line);border-radius:999px;font-size:12px;font-weight:800}.booking-actions button:disabled{cursor:not-allowed;color:#b6ada0;background:#f4f0ea;border-color:#eadfce;opacity:.82}.booking-actions button:nth-child(2){color:#fff;background:var(--gold);border-color:var(--gold)}.booking-actions button:nth-child(2):disabled{color:#b6ada0;background:#f4f0ea;border-color:#eadfce}.booking-detail-button{min-height:30px;padding:0 12px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:999px;font-size:12px;font-weight:800}.table-row em{color:var(--muted);font-style:normal}.table-row mark{padding:4px 8px;color:var(--green);background:#e9f5ef;border-radius:999px;font-weight:800}.empty-table{padding:12px;background:#fff8ec;border:1px solid #ead2a6;border-radius:8px}.empty-table{color:var(--muted);font-size:12px}.merchant-booking-detail-card{display:grid;gap:14px;margin-top:14px;padding:16px;background:#fffaf2;border:1px solid #ead2a6;border-radius:8px}.merchant-booking-detail-head{display:flex;gap:12px;align-items:flex-start;justify-content:space-between}.merchant-booking-detail-head span{display:inline-flex;width:fit-content;margin-bottom:6px;padding:4px 8px;color:var(--green);background:#e9f5ef;border-radius:999px;font-size:12px;font-weight:800}.merchant-booking-detail-head h3{margin:0;font-size:20px}.merchant-booking-detail-head button{min-height:32px;padding:0 12px;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:999px;font-weight:800}.merchant-booking-detail-list{display:grid;grid-template-columns:repeat(5,minmax(120px,1fr));gap:10px;margin:0}.merchant-booking-detail-list div{min-width:0;padding:10px;background:#fff;border:1px solid var(--line);border-radius:8px}.merchant-booking-detail-list dt{margin-bottom:4px;color:var(--muted);font-size:12px;font-weight:800}.merchant-booking-detail-list dd{margin:0;font-weight:900;overflow-wrap:anywhere}.merchant-booking-detail-card .booking-actions{justify-content:flex-start}.availability-editor-list{display:grid;gap:8px}.availability-rule-row{display:grid;grid-template-columns:48px repeat(4,minmax(82px,1fr));gap:8px;align-items:end;min-width:0;padding:10px;background:#fff;border:1px solid var(--line);border-radius:8px}.availability-rule-row.closed{background:#f8f4ed}.availability-rule-row strong{display:grid;place-items:center;min-width:0;min-height:40px;color:var(--gold-dark);background:#fff8ec;border-radius:8px}.availability-rule-row label{display:grid;gap:4px;min-width:0;color:var(--muted);font-size:11px}.availability-rule-row input,.availability-rule-row select{min-width:0;width:100%;min-height:36px;padding:0 8px;background:#fff;border:1px solid var(--line);border-radius:8px}.availability-rule-row button{grid-column:2 / -1;min-width:0;min-height:36px;color:#fff;background:var(--gold);border:0;border-radius:999px;font-weight:800}@media(max-width:1600px){.dashboard-grid{grid-template-columns:repeat(2,minmax(300px,1fr))}}.point-breakdown{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}.point-breakdown div{padding:12px;background:#fff8ec;border:1px solid #ead2a6;border-radius:8px}.point-breakdown span{display:block;color:var(--muted);font-size:12px}.point-breakdown strong{color:var(--gold-dark)}.point-breakdown .danger{color:var(--red)}.settlement-summary{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;padding:12px;background:#fff;border:1px solid var(--line);border-radius:8px}.settlement-summary span{color:var(--muted);font-size:12px}.settlement-summary strong{color:var(--gold-dark);text-align:right}.score-card{padding:16px;background:#fff8ec;border:1px solid #ead2a6;border-radius:8px}.score-card strong{display:block;margin:8px 0;color:var(--gold-dark);font-size:34px}.score-row{display:grid;grid-template-columns:72px auto;gap:4px 12px;align-items:center;padding:12px 0;border-bottom:1px solid var(--line);color:var(--text);font-weight:700}.score-row span,.score-row em{color:var(--muted);font-size:12px;font-style:normal;font-weight:500}.score-row strong{color:var(--green);text-align:right}.score-row em{grid-column:1 / -1}.menu-editor-form{display:grid;gap:10px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--line)}.menu-editor-form label{display:grid;gap:5px;color:var(--muted);font-size:12px}.menu-editor-form input{min-height:40px;padding:0 12px;border:1px solid var(--line);border-radius:8px}.menu-editor-grid,.menu-editor-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.menu-editor-actions button,.menu-row-actions button{min-height:36px;color:var(--gold-dark);background:#fff;border:1px solid #ead2a6;border-radius:999px;font-weight:800}.menu-editor-actions button:first-child{color:#fff;background:var(--gold);border-color:var(--gold)}.merchant-menu-list{display:grid;gap:10px}.merchant-menu-item{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px;align-items:center;padding:12px;background:#fff;border:1px solid var(--line);border-radius:8px}.merchant-menu-item.paused{background:#f8f4ed;opacity:.72}.merchant-menu-item div:first-child{display:grid;gap:3px;min-width:0}.merchant-menu-item strong,.merchant-menu-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.merchant-menu-item span{color:var(--muted);font-size:12px}.merchant-menu-item em{color:var(--ink);font-style:normal;font-weight:800}.merchant-menu-item mark{padding:4px 8px;color:#fff;background:var(--gold);border-radius:999px}.menu-row-actions{display:grid;grid-column:1 / -1;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.store-form{display:grid;gap:10px}.store-image-editor{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.store-image-editor div{display:grid;gap:6px}.store-image-editor img{width:100%;aspect-ratio:16 / 9;object-fit:contain;background:#f4eee5;border:1px solid var(--line);border-radius:8px}.store-image-editor span{width:fit-content;padding:4px 10px;color:var(--gold-dark);background:#fff8ec;border:1px solid #ead2a6;border-radius:999px;font-size:12px;font-weight:800}.store-form label{display:grid;gap:5px;color:var(--muted);font-size:12px}.store-form input{min-height:40px;padding:0 12px;border:1px solid var(--line);border-radius:8px}.store-form button,.gallery-form button{min-height:42px;color:#fff;background:var(--gold);border:0;border-radius:999px;font-weight:800}.merchant-gallery-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.merchant-gallery-item{display:grid;gap:6px;margin:0}.merchant-gallery-item img{width:100%;aspect-ratio:4 / 3;object-fit:cover;background:#f4eee5;border:1px solid var(--line);border-radius:8px}.merchant-gallery-item span{color:var(--gold-dark);font-size:12px;font-weight:800}.gallery-role-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.gallery-role-actions button{min-height:34px;padding:0 8px;color:var(--gold-dark);background:#fff;border:1px solid #ead2a6;border-radius:999px;font-size:12px;font-weight:800}.gallery-role-actions button.active{color:#fff;background:var(--gold);border-color:var(--gold)}.gallery-form{display:grid;gap:10px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}.gallery-form label{display:grid;gap:5px;color:var(--muted);font-size:12px}.gallery-form input{min-height:40px;padding:0 12px;border:1px solid var(--line);border-radius:8px}.settings-list{display:grid;gap:10px}.settings-list button{display:flex;align-items:center;justify-content:space-between;min-height:54px;padding:0 14px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:8px;font-weight:800}.form-status{margin:0;color:var(--green);font-size:12px;font-weight:800}@media(max-width:1280px){.customer-layout{grid-template-columns:repeat(2,minmax(260px,1fr))}.merchant-layout{grid-template-columns:1fr}.sidebar{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-template-rows:72px repeat(2,72px);align-content:start;gap:10px 16px;padding:18px 24px 22px}.sidebar .brand{grid-column:1 / -1;height:72px;margin-bottom:0}.sidebar button{height:72px;min-height:72px;margin:0;padding:0 18px;background:#ffffff08;border-color:#ffffff14}.sidebar .active{background:var(--gold);border-color:var(--gold)}.metric-grid,.dashboard-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}}@media(max-width:760px){.topbar,.merchant-top{align-items:flex-start;flex-direction:column}.brand-name{font-size:23px}.mode-switch,.mode-switch button,.account-switch,.account-switch button{width:100%}.mode-switch button,.account-switch button{justify-content:center}.account-switch{flex-wrap:wrap}.account-switch span{width:100%;text-align:center}.login-panel{padding:18px;border-radius:8px}.login-role-grid{grid-template-columns:1fr}.customer-layout{display:block;min-height:100dvh;padding:0}.phone-panel{width:100%;max-width:none;min-height:100dvh;margin:0;padding-bottom:calc(70px + env(safe-area-inset-bottom));border:0;border-radius:0;box-shadow:none}.mobile-nav{position:fixed;min-height:calc(58px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom)}.sidebar,.metric-grid,.dashboard-grid{grid-template-columns:1fr}.sidebar{grid-template-rows:auto}.sidebar button{height:56px;min-height:56px}.panel.wide,.panel.availability-panel{grid-column:auto}.metric-grid{gap:10px}.table-row,.compact-row,.booking-action-row{grid-template-columns:1fr}.booking-filter-tabs,.booking-date-filter,.booking-filter-clear{flex:1 1 100%}.booking-filter-tabs button{flex:1 1 96px}.booking-actions,.booking-action-row .booking-actions{justify-content:flex-start}.merchant-booking-detail-list{grid-template-columns:1fr}.availability-rule-row{grid-template-columns:42px 1fr 1fr}.availability-rule-row button{grid-column:1 / -1}.point-breakdown{grid-template-columns:1fr}}
