:root{--ink:#17343b;--muted:#678087;--mint:#2f9b83;--mint-dark:#19735f;--pale:#eef8f4;--cream:#fbfaf6;--line:#dce8e4;--coral:#e97968}
*{box-sizing:border-box}body{margin:0;background:var(--cream);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,"Hiragino Sans","Yu Gothic",sans-serif}
button,input,select{font:inherit}.patient-shell{max-width:540px;min-height:100vh;margin:auto;padding:24px 18px 32px;background:#fff;box-shadow:0 0 40px #16343b10}
header{display:flex;align-items:center;gap:12px;padding:4px 2px 22px}.brand-mark{display:grid;place-items:center;width:46px;height:46px;border-radius:14px;background:var(--mint);color:#fff;font-size:27px;font-weight:300}h1,h2,p{margin:0}h1{font-size:22px;letter-spacing:.02em}.eyebrow{font-size:11px;font-weight:700;letter-spacing:.12em;color:var(--mint);text-transform:uppercase;margin-bottom:2px}
.step{display:flex;align-items:center;gap:11px;margin:4px 0 14px}.step>span{display:grid;place-items:center;width:29px;height:29px;border-radius:50%;background:var(--ink);color:#fff;font-weight:700}.step b,.step small{display:block}.step small{color:var(--muted);margin-top:2px}.step.compact{margin-bottom:18px}
.days{display:grid;grid-template-columns:1fr 1fr;gap:10px}.day{border:1px solid var(--line);border-radius:15px;background:#fff;padding:13px 10px;text-align:left;color:var(--ink)}.day small,.day b,.day span{display:block}.day small{color:var(--muted)}.day b{margin:3px 0 7px}.day span{color:var(--mint-dark);font-size:12px;font-weight:700}.day.active{border:2px solid var(--mint);background:var(--pale)}.day:disabled{opacity:.52}
.slot-group{margin-top:22px}.slot-group h3{font-size:14px;margin:0 0 9px}.slot-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.slot{border:1px solid var(--line);border-radius:9px;background:#fff;padding:10px 2px;color:var(--ink);font-weight:600}.slot.active{background:var(--mint);border-color:var(--mint);color:#fff}.slot small{display:block;margin-top:2px;font-size:9px;color:#50758a}.slot.active small{color:#fff}.slot.noninfectious{border-color:#9abcc8;background:#f3f9fb}
.card,.panel{margin-top:24px;padding:20px;border:1px solid var(--line);border-radius:18px;background:#fff;box-shadow:0 8px 24px #244b4210}.card label,.panel label{display:block;font-size:13px;font-weight:700;margin:12px 0}.card input,.panel input,.panel select{display:block;width:100%;margin-top:6px;padding:12px;border:1px solid #cbdcd6;border-radius:10px;background:#fff;color:var(--ink)}fieldset{border:0;padding:0;margin:14px 0}legend{font-size:13px;font-weight:700}.radio{display:inline-flex!important;align-items:center;margin:8px 18px 0 0!important}.radio input{width:auto!important;margin:0 6px 0 0!important}.privacy{font-size:11px;color:var(--muted);margin:16px 0}
.primary,.secondary{width:100%;border:0;border-radius:12px;padding:14px;font-weight:700}.primary{background:var(--mint);color:#fff}.primary:hover{background:var(--mint-dark)}.secondary{background:#fff;color:var(--coral);border:1px solid #f0b7af}
.notice{margin-top:22px;padding:18px;border-radius:14px;background:var(--pale)}.notice p{font-size:13px;line-height:1.7;color:var(--muted);margin-top:5px}.loading,.empty{padding:18px;text-align:center;color:var(--muted)}
.notice a{color:var(--mint-dark);font-weight:700}.medical-notice{margin:0 0 15px;padding:14px;border-left:4px solid #5b8fa3;border-radius:4px 12px 12px 4px;background:#eff7fa}.medical-notice b{font-size:13px}.medical-notice p{margin-top:4px;color:#49666f;font-size:12px;line-height:1.65}.warning{margin:12px 0;padding:11px 13px;border-radius:9px;background:#fff2df;color:#8b5000;font-size:12px;line-height:1.6}
.booking-rule{margin:0 0 12px;padding:14px;border-radius:12px;background:#fff5e7;border:1px solid #f0d29f}.booking-rule b{font-size:13px;color:#8b5000}.booking-rule p{margin-top:4px;font-size:13px;font-weight:700;line-height:1.6;color:#65400d}
.change-cancel-notice{margin-top:24px;padding:17px;border:2px solid #efaaa0;border-radius:14px;background:#fff7f5}.change-cancel-notice b{display:block;color:#9b4035;font-size:20px}.change-cancel-notice p{margin:7px 0 0;font-size:14px;line-height:1.7}.change-cancel-notice a,.change-cancel-guide a{color:#9b4035;font-size:1.08em;font-weight:800;white-space:nowrap}.change-cancel-guide{margin:20px 0 12px;padding:16px;border-radius:14px;background:#fff7f5;text-align:left}.change-cancel-guide h3{margin:0 0 8px;color:#9b4035;font-size:22px}.change-cancel-guide p{margin:5px 0;font-size:14px;line-height:1.65}.change-cancel-guide .phone-help{font-weight:700}.cancel-button{min-height:58px;font-size:18px}
.complete{text-align:center;padding:58px 12px}.check{display:grid;place-items:center;width:72px;height:72px;border-radius:50%;background:var(--pale);color:var(--mint);font-size:40px;margin:0 auto 18px}.complete h2{font-size:24px}.complete>p:not(.eyebrow){color:var(--muted);margin:10px 0 26px}.complete .appointment{padding:17px;border-radius:13px;background:var(--pale);color:var(--ink)!important;font-size:20px;font-weight:700}
footer{display:flex;justify-content:space-between;gap:8px;margin-top:34px;padding-top:18px;border-top:1px solid var(--line);font-size:10px;color:var(--muted)}footer a{color:var(--muted)}
.hidden{display:none!important}#toast{position:fixed;left:50%;bottom:20px;transform:translate(-50%,20px);max-width:420px;width:calc(100% - 36px);padding:13px 16px;border-radius:10px;background:var(--ink);color:#fff;opacity:0;pointer-events:none;transition:.2s}#toast.show{opacity:1;transform:translate(-50%,0)}
.admin-body{padding:20px;touch-action:manipulation}.admin-shell{max-width:1280px;margin:auto}.admin-shell header{padding-bottom:8px}.panel{margin-top:16px}.panel h2{font-size:20px}.narrow{max-width:430px}.hint{font-size:12px;color:var(--muted);margin-top:12px}.closure-form{display:grid;grid-template-columns:1fr 1fr 1fr 1.5fr auto;align-items:end;gap:10px}.closure-form label{margin:0}.closure-form .primary{width:auto;min-height:52px}.list-row{display:flex;align-items:center;justify-content:space-between;padding:13px 3px;border-bottom:1px solid var(--line)}.list-row:last-child{border:0}.list-row b,.list-row small,.list-row span{display:block}.list-row small{color:var(--muted);margin-top:3px}.danger{min-height:44px;border:0;border-radius:9px;padding:9px 14px;background:#fff0ee;color:#b54435}.reservation-row{justify-content:flex-start}
.panel-title{display:flex;align-items:center;justify-content:space-between;gap:12px}.phone-form{display:grid;grid-template-columns:repeat(3,1fr);gap:0 12px}.phone-form fieldset{align-self:end}.phone-form .primary{align-self:end;min-height:54px;margin-bottom:12px}.badge{display:inline-block!important;width:max-content;padding:3px 7px;border-radius:99px;font-size:10px;font-style:normal}.badge.phone{background:#fff0dc;color:#a25a00}.badge.line{background:#e7f7ee;color:#14704a}.badge.noninfectious{background:#e6f2f7;color:#356b80}.text-button{min-height:44px;border:0;background:none;color:var(--mint-dark);font-weight:700}.reservation-row{justify-content:space-between}.schedule-panel{padding:22px}.schedule-toolbar{display:grid;grid-template-columns:auto minmax(180px,260px) auto auto;align-items:end;gap:10px;margin-top:14px}.schedule-date-label{margin:0!important}.schedule-date-label input{min-height:56px;margin-top:4px!important;font-size:17px}.touch-button{min-width:86px;min-height:56px;border:1px solid #bdd3cc;border-radius:12px;background:#fff;color:var(--mint-dark);font-size:16px;font-weight:700}.touch-button.today{background:var(--mint);border-color:var(--mint);color:#fff}.slot-legend{display:flex;flex-wrap:nowrap;align-items:flex-start;align-content:flex-start;height:32px!important;min-height:32px;max-height:32px;gap:8px;margin:14px 0}.slot-legend span{align-self:flex-start;height:29px!important;max-height:29px;padding:6px 10px;border-radius:7px;font-size:12px;white-space:nowrap}.slot-legend .available{background:#e8f7ef}.slot-legend .reserved{background:#fff0ee}.slot-legend .phone{background:#fff0dc}.slot-legend .noninfectious{background:#e6f2f7}.slot-legend .blocked{background:#edf0ef}.schedule-periods{display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:max-content;align-items:start;gap:16px}.admin-slot-group{height:max-content;padding:14px;border:1px solid var(--line);border-radius:14px;background:#fbfdfc}.period-heading{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.period-heading h3{margin:0;font-size:20px}.period-heading span{color:var(--muted);font-size:12px}.admin-slot-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:92px;align-items:stretch;gap:8px}.admin-slot{position:relative;height:92px;min-height:92px;overflow:hidden;padding:9px;border:1px solid var(--line);border-radius:11px;background:#fff;text-align:left;color:var(--ink)}button.admin-slot{cursor:pointer;-webkit-tap-highlight-color:transparent}.admin-slot b{font-size:17px}.admin-slot b,.admin-slot span{display:block}.admin-slot span{margin-top:4px;font-size:11px;line-height:1.3}.admin-slot.available{background:#f2fbf6;border-color:#93cfb3}.admin-slot.available:active{transform:scale(.98);background:#dff4e9}.admin-slot.reserved{padding-right:72px;background:#fff4f2;border-color:#efaaa0}.admin-slot.reserved>span{max-height:30px;overflow:hidden}.admin-slot.blocked,.admin-slot.past{background:#f2f4f3;color:#7c8b87}.mini-cancel{position:absolute;right:7px;bottom:7px;display:block!important;width:60px;min-width:60px;height:34px;min-height:34px;margin:0;border:1px solid #dc8478;border-radius:8px;background:#fff;color:#a33f31;font-size:12px;font-weight:700}
@media(max-width:900px){.admin-body{padding:14px}.schedule-periods{grid-template-columns:1fr}.admin-slot-grid{grid-template-columns:repeat(4,1fr)}.closure-form,.phone-form{grid-template-columns:1fr 1fr}.closure-form label:nth-of-type(4),.closure-form .primary,.phone-form .primary{grid-column:1/-1}.slot-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.schedule-toolbar{grid-template-columns:1fr 1fr}.schedule-date-label{grid-column:1/-1;grid-row:1}.admin-slot-grid{grid-template-columns:repeat(3,1fr)}.touch-button{min-width:0}.schedule-panel{padding:14px}}
.card-number-field{font-size:16px!important}.card-number-field span{margin-left:5px;padding:3px 7px;border-radius:6px;background:#fff0ee;color:#a33f31;font-size:10px}.card-number-field input{font-size:19px!important}.optional-fields{grid-column:1/-1;border:1px solid var(--line);border-radius:12px;background:#fafcfb}.optional-fields>summary,.admin-tools>summary{min-height:54px;padding:15px 16px;cursor:pointer;color:var(--mint-dark);font-weight:700;-webkit-tap-highlight-color:transparent}.optional-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0 12px;padding:0 16px 14px}.admin-booking-form{}.admin-tools{padding:0!important;overflow:hidden}.admin-tools[open]>summary{border-bottom:1px solid var(--line);background:var(--pale)}.admin-tools>form,.admin-tools>#closures,.admin-tools>#reservations{padding:18px}.tool-actions{display:flex;justify-content:flex-end;padding:8px 18px 0}.touch-button:disabled{opacity:.4;background:#eef1f0;color:#7c8b87}.phone-form>.primary{grid-column:1/-1;max-width:420px}
@media(max-width:900px){.optional-grid{grid-template-columns:1fr 1fr}}
.patient-name-field{font-size:16px!important}.patient-name-field input{font-size:18px!important}.roster-panel{overflow:hidden}.roster-date{margin:12px 0 10px!important;text-align:center}.roster-tables{display:grid;grid-template-columns:1fr 1fr;gap:18px}.roster-period h3{margin:0 0 7px}.roster-period table{width:100%;border-collapse:collapse;table-layout:fixed}.roster-period th,.roster-period td{height:30px;padding:4px 7px;border:1px solid #9eb8b1;text-align:left;font-size:12px}.roster-period th{background:var(--pale)}.roster-period th:first-child,.roster-period td:first-child{width:20%}.roster-period th:nth-child(2),.roster-period td:nth-child(2){width:30%}
@media(max-width:900px){.roster-tables{grid-template-columns:1fr}}
.print-actions{display:flex;gap:8px}
@page{size:A4 portrait;margin:10mm}
@media print{body *{visibility:hidden!important}#print-section,#print-section *{visibility:visible!important}.no-print{display:none!important}#print-section{position:absolute;left:0;top:0;width:100%;margin:0!important;padding:0!important;border:0!important;box-shadow:none!important}.roster-date{font-size:14pt!important;margin:0 0 3mm!important}.roster-tables{display:block!important}.roster-period{display:none!important}body[data-print-period="morning"] .roster-morning,body[data-print-period="afternoon"] .roster-afternoon{display:block!important}.roster-period h3{font-size:12pt;margin:0 0 1mm}.roster-period th,.roster-period td{height:6.3mm;padding:.7mm 2mm;font-size:9pt;border-color:#555}.roster-period th{background:#eee!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}}
