:root{--bg: #f3f9f6;--surface: #ffffff;--surface-2: #f3f9f6;--surface-3: #e5f2ec;--ink: #1b2b24;--muted: #61766c;--line: #d7e9df;--green: #328e65;--green-dark: #236848;--green-soft: #dff0e8;--green-pale: #f7fbf9;--shadow: 0 18px 54px rgba(35, 104, 72, .13);color:var(--ink);font-family:Hiragino Sans,Yu Gothic,Noto Sans JP,system-ui,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#ffffff 0,var(--bg) 280px),var(--bg)}button,input,select{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.48}input,select{min-height:42px;min-width:0;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--ink);padding:0 12px}input:focus,select:focus,button:focus-visible{outline:3px solid rgba(50,142,101,.22);outline-offset:2px}table{width:100%;border-collapse:collapse;font-size:14px}th,td{padding:13px 12px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap}th{color:var(--muted);font-size:12px}.app-shell{min-height:100vh;padding:22px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;max-width:1280px;margin:0 auto 18px}.brand{display:flex;align-items:center;gap:0}.brand p,.admin-title p,.sidebar-title p{margin:0 0 3px;color:var(--muted);font-size:13px;font-weight:700}.brand h1,.admin-title h2,.sidebar-title h2{margin:0;font-size:22px;line-height:1.25}.view-switch{display:flex;gap:5px;padding:5px;border:1px solid var(--line);border-radius:999px;background:var(--surface)}.view-switch button{min-width:96px;min-height:38px;border-radius:999px;background:transparent;color:var(--muted);font-size:14px;font-weight:800}.view-switch button.active{background:var(--green);color:#fff}.employee-shell,.admin-layout{max-width:1280px;margin:0 auto}.employee-shell{display:grid;grid-template-columns:260px minmax(0,410px);gap:24px;align-items:start;justify-content:center;min-height:calc(100vh - 112px)}.mock-controls{width:100%;margin-top:22px;padding:16px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:0 8px 22px #2368480d}.mock-controls label{display:grid;gap:8px;color:var(--muted);font-size:13px;font-weight:800}.phone{position:relative;width:min(100%,410px);height:820px;overflow:hidden;border:10px solid var(--green-dark);border-radius:40px;background:var(--surface);box-shadow:var(--shadow)}.phone-status{display:flex;justify-content:space-between;gap:10px;padding:14px 20px 7px;color:var(--muted);font-size:12px;font-weight:800}.mobile-datebar{display:grid;grid-template-columns:42px 1fr 42px;align-items:center;padding:0 16px 10px}.mobile-datebar button{width:34px;height:34px;border-radius:999px;background:var(--surface-2);color:var(--green);font-size:26px;line-height:1}.mobile-datebar strong{text-align:center;font-size:20px}.employee-user{display:grid;grid-template-columns:1fr;gap:12px;padding:0 18px 14px}.employee-user p,.employee-user h2{margin:0}.employee-user p{color:var(--muted);font-size:13px;font-weight:700}.employee-user h2{font-size:22px}.mobile-nav{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:0 16px 14px}.mobile-nav button{min-height:38px;border-radius:999px;background:var(--surface-2);color:var(--muted);font-size:13px;font-weight:800}.mobile-nav button.active{background:var(--green);color:#fff}.phone-content{display:grid;gap:12px;height:610px;overflow-y:auto;padding:0 16px 96px;scrollbar-width:none}.phone-content::-webkit-scrollbar{display:none}.mobile-footer{position:absolute;left:0;right:0;bottom:0;display:grid;grid-template-columns:repeat(5,1fr);gap:2px;padding:8px 12px 12px;border-top:1px solid var(--line);background:#fffffff5;box-shadow:0 -8px 24px #23684814}.mobile-footer button{display:grid;justify-items:center;gap:4px;min-height:54px;border-radius:12px;background:transparent;color:var(--muted);font-weight:800}.mobile-footer button.active{color:var(--green)}.mobile-footer small{font-size:10px;line-height:1}.nav-icon{position:relative;width:24px;height:24px}.nav-icon:before,.nav-icon:after{content:"";position:absolute;border-color:currentColor}.nav-icon.timeline:before{left:4px;top:5px;width:16px;height:14px;border:2px solid currentColor;border-radius:5px}.nav-icon.timeline:after{left:7px;top:9px;width:10px;height:2px;background:currentColor;box-shadow:0 5px 0 currentColor}.nav-icon.steps:before{left:5px;bottom:3px;width:6px;height:14px;border-radius:999px 999px 5px 5px;background:currentColor}.nav-icon.steps:after{right:4px;bottom:4px;width:7px;height:11px;border-radius:999px 999px 5px 5px;background:currentColor}.nav-icon.meal:before{left:4px;top:3px;width:14px;height:14px;border:2px solid currentColor;border-radius:999px}.nav-icon.meal:after{right:3px;top:2px;width:2px;height:19px;background:currentColor}.nav-icon.gift:before{left:4px;top:8px;width:16px;height:13px;border:2px solid currentColor;border-radius:4px}.nav-icon.gift:after{left:11px;top:4px;width:2px;height:18px;background:currentColor}.nav-icon.user:before{left:8px;top:4px;width:8px;height:8px;border:2px solid currentColor;border-radius:999px}.nav-icon.user:after{left:4px;bottom:3px;width:16px;height:9px;border:2px solid currentColor;border-radius:999px 999px 4px 4px}.point-hero{padding:26px;border-radius:26px;background:radial-gradient(circle at top right,rgba(255,255,255,.2),transparent 180px),var(--green);color:#fff}.daily-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.daily-summary div{padding:14px;border-radius:18px;background:var(--surface-2)}.daily-summary span{display:block;color:var(--muted);font-size:11px;font-weight:800}.daily-summary strong{display:block;margin-top:5px;color:var(--green);font-size:18px}.step-hero-card{display:grid;grid-template-columns:150px 1fr;gap:14px;align-items:center;padding:18px;border-radius:24px;background:linear-gradient(180deg,#ffffff,var(--surface-2));border:1px solid var(--line)}.step-hero-card.compact{grid-template-columns:138px 1fr}.step-ring{display:grid;place-items:center;width:136px;aspect-ratio:1;border-radius:999px;background:radial-gradient(circle at center,#fff 0 58%,transparent 59%),conic-gradient(var(--green) 0 var(--progress),#e8eee9 var(--progress) 100%);color:var(--green)}.step-ring span,.step-ring small{color:var(--muted);font-size:11px;font-weight:900}.step-ring strong{font-size:30px;line-height:1}.metric-row{display:grid;gap:10px}.metric-row div{padding:10px;border-radius:12px;background:var(--surface)}.metric-row span{display:block;color:var(--muted);font-size:11px;font-weight:800}.metric-row strong{display:block;margin-top:4px;font-size:16px}.timeline-card{display:grid;grid-template-columns:38px 1fr;gap:10px;align-items:start}.timeline-speaker{display:grid;place-items:center;width:34px;height:34px;border-radius:999px;background:var(--green);color:#fff;font-weight:900}.timeline-bubble{padding:14px;border-radius:18px;background:#fff4cf;color:var(--ink)}.timeline-bubble span,.timeline-bubble p{color:var(--muted);font-size:12px}.timeline-bubble strong{display:block;margin:4px 0 6px;font-size:15px}.timeline-bubble p{margin:0;line-height:1.5}.point-hero span,.point-hero p{color:#ffffffb8;font-size:13px;font-weight:800}.point-hero strong{display:block;margin:8px 0;font-size:48px;line-height:1}.point-hero p{margin:0}.quick-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.quick-actions button,.action-button,.mobile-list-row button{min-height:44px;border-radius:12px;background:var(--green);color:#fff;font-size:13px;font-weight:900}.quick-actions button:nth-child(2){background:var(--green-dark)}.quick-actions button:nth-child(3){background:#5aa77e}.mobile-card,.admin-card,.stat-card,.item-card{border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:0 8px 22px #1d302b0d}.mobile-card{padding:16px;border-radius:18px}.mobile-card h3,.admin-card h3,.item-card h3{margin:0 0 12px;font-size:17px}.card-copy{margin:-4px 0 12px;color:var(--muted);font-size:12px;line-height:1.6}.mobile-form{display:grid;gap:10px}.mobile-form label{display:grid;gap:7px;color:var(--muted);font-size:12px;font-weight:800}.mobile-form textarea{width:100%;resize:vertical;border:1px solid var(--line);border-radius:8px;padding:10px 12px;color:var(--ink);font:inherit;font-size:13px}.primary-button{min-height:42px;border-radius:10px;background:var(--green);color:#fff;font-weight:900}.step-rule{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.step-rule span{padding:7px 8px;border-radius:8px;background:var(--surface-2);color:var(--green-dark);font-size:11px;font-weight:800;text-align:center}.upload-box{min-height:54px;place-items:center;border:1px dashed rgba(50,142,101,.48);border-radius:10px;background:var(--green-pale);color:var(--green)}.camera-box{position:relative;display:flex;width:100%;min-height:112px;align-items:center;justify-content:center;flex-direction:column;gap:10px;border:1px dashed rgba(50,142,101,.5);border-radius:16px;background:var(--green-pale);color:var(--green);text-align:center}.camera-box strong{color:var(--green);font-size:14px}.camera-fullscreen{position:absolute;top:0;right:0;bottom:0;left:0;z-index:30;overflow:hidden;background:#111;color:#fff}.camera-fullscreen[hidden]{display:none}.camera-fullscreen video{width:100%;height:100%;object-fit:cover;background:#111}.camera-topbar{position:absolute;top:0;left:0;right:0;z-index:2;display:grid;grid-template-columns:44px 1fr 44px;align-items:center;min-height:68px;padding:14px 16px 8px;background:linear-gradient(180deg,rgba(0,0,0,.62),transparent)}.camera-topbar button{width:36px;height:36px;border-radius:999px;background:#ffffff2e;color:#fff;font-size:28px;line-height:1}.camera-topbar strong{text-align:center;font-size:14px}.camera-guide{position:absolute;left:50%;top:50%;width:min(78vw,312px);aspect-ratio:1;transform:translate(-50%,-50%);border:3px solid rgba(255,255,255,.95);border-radius:18px;background:linear-gradient(90deg,transparent 33.333%,rgba(255,255,255,.45) 33.333% 33.9%,transparent 33.9% 66.666%,rgba(255,255,255,.45) 66.666% 67.2%,transparent 67.2%),linear-gradient(180deg,transparent 33.333%,rgba(255,255,255,.45) 33.333% 33.9%,transparent 33.9% 66.666%,rgba(255,255,255,.45) 66.666% 67.2%,transparent 67.2%);box-shadow:0 0 0 999px #00000057,inset 0 0 0 1px #328e65e6}.camera-fullscreen p{position:absolute;left:22px;right:22px;bottom:112px;z-index:2;margin:0;color:#fff;font-size:12px;line-height:1.5;text-align:center}.camera-shutter{position:absolute;left:0;right:0;bottom:22px;z-index:2;display:grid;place-items:center}.camera-shutter button{width:70px;height:70px;border:5px solid rgba(255,255,255,.9);border-radius:999px;background:#fff;box-shadow:0 0 0 5px #ffffff38}.file-box{position:relative;display:grid;min-height:40px;place-items:center;border:1px solid var(--line);border-radius:10px;background:var(--surface);color:var(--muted);text-align:center}.file-box input{display:none}.file-box span{max-width:100%;overflow:hidden;padding:0 12px;font-size:12px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.camera-icon{position:relative;width:30px;height:24px;border:2px solid currentColor;border-radius:7px}.camera-icon:before{content:"";position:absolute;left:9px;top:5px;width:8px;height:8px;border:2px solid currentColor;border-radius:999px}.camera-icon:after{content:"";position:absolute;left:6px;top:-7px;width:10px;height:6px;border-radius:4px 4px 0 0;background:currentColor}.meal-tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.meal-tabs button{min-height:34px;border-radius:999px;background:var(--surface-2);color:var(--muted);font-size:12px;font-weight:900}.meal-tabs button.active{background:var(--green);color:#fff}.upload-box input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.upload-box span{font-size:13px}.meal-preview{width:100%;aspect-ratio:16 / 9;object-fit:cover;border-radius:10px;border:1px solid var(--line)}.action-button{display:flex;align-items:center;justify-content:space-between;width:100%;margin-top:8px;padding:0 14px;text-align:left}.mobile-list-row,.mobile-log{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}.section-line{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.section-line h3{margin:0}.section-line button,.promo-feed button{min-height:32px;padding:0 12px;border-radius:999px;background:var(--green);color:#fff;font-size:12px;font-weight:900}.meal-progress{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;padding:12px;border-radius:16px;background:var(--surface-2)}.meal-progress span,.meal-progress p{color:var(--muted);font-size:11px;font-weight:800}.meal-progress strong{display:block;margin-top:3px;color:var(--green);font-size:20px}.meal-progress p{max-width:178px;margin:0;line-height:1.45;text-align:right}.meal-slot-list{display:grid;gap:10px}.meal-slot{display:grid;grid-template-columns:72px 1fr auto;gap:12px;align-items:center;width:100%;min-height:88px;padding:10px;border:1px solid rgba(50,142,101,.16);border-radius:18px;background:#fff;color:var(--ink);text-align:left}.meal-slot.registered{grid-template-columns:72px auto minmax(0,1fr) auto;background:linear-gradient(90deg,#fff,var(--surface-2))}.meal-slot>div{min-width:0}.meal-slot.registered img{width:72px;height:72px;object-fit:cover;border-radius:14px}.meal-slot:after{content:">";color:var(--green);font-size:20px;font-weight:900}.meal-slot span{display:inline-flex;width:fit-content;min-width:62px;justify-content:center;padding:5px 9px;border-radius:999px;background:#328e651a;color:var(--green-dark);font-size:11px;font-weight:900}.meal-slot small,.meal-slot strong,.meal-slot em{display:block;font-style:normal}.meal-slot small{color:var(--green-dark);font-size:13px;font-weight:900}.meal-slot strong{overflow:hidden;margin-top:3px;color:var(--ink);font-size:15px;line-height:1.35;text-overflow:ellipsis;white-space:nowrap}.meal-slot em{margin-top:3px;color:var(--muted);font-size:11px;font-weight:800}.meal-slot.empty-slot{border:1px dashed rgba(50,142,101,.36);background:var(--surface-2)}.meal-slot.empty-slot>span{display:grid;place-items:center;width:72px;height:72px;min-width:0;padding:0;border:1px dashed rgba(50,142,101,.36);border-radius:14px;background:var(--surface);color:var(--green);font-size:28px;font-weight:900}.meal-slot.empty-slot strong{color:var(--green)}.snack-slot{display:grid;grid-template-columns:56px 1fr;gap:12px;align-items:center;width:100%;min-height:76px;margin-top:10px;padding:12px;border-radius:18px;background:var(--green-pale);color:var(--ink);text-align:left}.snack-slot>span{display:grid;place-items:center;width:56px;height:56px;border:1px dashed rgba(50,142,101,.4);border-radius:16px;background:var(--surface);color:var(--green);font-size:28px;font-weight:900}.snack-slot img{width:56px;height:56px;object-fit:cover;border-radius:16px}.snack-slot strong,.snack-slot small{display:block}.snack-slot strong{color:var(--green-dark);font-size:15px}.snack-slot small{margin-top:3px;color:var(--muted);font-size:12px;line-height:1.4}.meal-row{display:grid;grid-template-columns:76px 1fr;gap:4px;align-items:center;padding:12px 0;border-bottom:1px solid var(--line)}.meal-row:last-child{border-bottom:0}.meal-row span{width:fit-content;padding:4px 8px;border-radius:999px;background:var(--surface-2);color:var(--green);font-size:11px;font-weight:900}.meal-row img{width:64px;aspect-ratio:1;object-fit:cover;border:1px solid var(--line);border-radius:12px;background:var(--surface-2)}.meal-row small{color:var(--muted)}.promo-feed{display:grid;grid-template-columns:1fr;gap:10px}.promo-feed article{padding:15px;border-radius:18px;background:#fff;border:1px solid var(--line)}.promo-feed span{color:var(--green);font-size:11px;font-weight:900}.promo-feed strong{display:block;margin-top:4px}.promo-feed p{margin:5px 0 10px;color:var(--muted);font-size:12px}.mobile-list-row:last-child,.mobile-log:last-child{border-bottom:0}.mobile-list-row strong,.mobile-list-row span,.mobile-log strong,.mobile-log span{display:block}.mobile-list-row span,.mobile-log span,.empty{color:var(--muted);font-size:12px}.mobile-list-row button{flex:0 0 auto;min-height:36px;padding:0 12px}.mobile-log em{color:var(--green);font-style:normal;font-weight:900}.history-groups{display:grid;gap:14px}.history-groups h4{margin:0 0 4px;color:var(--muted);font-size:12px}.exchange-log em{color:var(--green-dark)}.balance-card span{color:var(--muted);font-size:13px;font-weight:800}.balance-card strong{display:block;margin-top:6px;font-size:34px}.profile-card{display:grid;justify-items:center;gap:6px;padding:22px;border-radius:22px;background:var(--surface);border:1px solid var(--line)}.avatar{display:grid;place-items:center;width:64px;height:64px;border-radius:999px;background:var(--green);color:#fff;font-size:26px;font-weight:900}.profile-card h3,.profile-card p{margin:0}.profile-card p{color:var(--muted);font-size:13px}.status-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.status-grid div,.meal-summary,.coupon-row{border-radius:8px;background:var(--surface-2);padding:11px}.status-grid span,.meal-summary span{display:block;color:var(--muted);font-size:11px;font-weight:800}.status-grid strong,.meal-summary strong{display:block;margin-top:5px;font-size:15px}.meal-summary{margin-top:8px}.coupon-row{display:grid;gap:6px;margin-top:8px}.coupon-row code{width:fit-content;padding:5px 8px;border-radius:6px;background:var(--surface);color:var(--green-dark);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;font-weight:900}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;padding:20px;background:#1b2b246b}.phone .modal-backdrop{position:absolute;z-index:40;padding:16px}.phone .confirm-dialog{padding:18px}.phone .confirm-dialog h2{font-size:18px}.confirm-dialog{width:min(100%,390px);border-radius:12px;background:var(--surface);padding:22px;box-shadow:var(--shadow)}.confirm-dialog h2{margin:0;font-size:22px}.confirm-dialog p{margin:12px 0 16px;color:var(--muted);font-size:14px;line-height:1.7}.dialog-summary{display:grid;grid-template-columns:1fr auto;gap:8px 14px;padding:14px;border-radius:8px;background:var(--surface-2)}.dialog-summary span{color:var(--muted);font-size:13px;font-weight:800}.dialog-summary strong{color:var(--green-dark)}.dialog-actions{display:grid;grid-template-columns:.8fr 1.2fr;gap:10px;margin-top:16px}.dialog-actions button{min-height:42px;border-radius:8px;font-weight:900}.dialog-actions button:first-child{background:var(--surface-2);color:var(--green-dark)}.dialog-actions button:last-child{background:var(--green);color:#fff}.form-dialog{width:min(100%,460px)}.form-dialog .stack-form{margin-top:18px}.form-dialog .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.admin-layout{display:grid;grid-template-columns:240px minmax(0,1fr);gap:20px}.admin-sidebar{min-height:760px;border-radius:18px;background:var(--surface);border:1px solid var(--line);color:#fff;padding:22px}.sidebar-title{margin-bottom:22px}.sidebar-title p{color:var(--muted)}.sidebar-title h2{color:var(--ink)}.sidebar-button{width:100%;min-height:44px;margin-bottom:8px;padding:0 12px;border-radius:8px;background:transparent;color:var(--muted);text-align:left;font-weight:800}.sidebar-button.active,.sidebar-button:hover{background:var(--green);color:#fff}.admin-main{min-width:0}.admin-title,.section-heading{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.admin-title h2{font-size:30px}.admin-title button,.section-heading button,.stack-form button{min-height:42px;padding:0 16px;border-radius:8px;background:var(--green);color:#fff;font-weight:900}.section-heading{margin-bottom:12px}.section-heading h3{margin:0;font-size:18px}.section-heading span{color:var(--muted);font-size:13px;font-weight:800}.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}.dashboard-grid{display:grid;grid-template-columns:1.2fr 1fr .8fr;gap:14px;margin-bottom:16px}.chart-card{min-height:260px}.line-chart{display:grid;grid-template-columns:repeat(7,1fr);align-items:end;gap:12px;height:176px;padding:16px 8px 0;border-radius:8px;background:linear-gradient(180deg,transparent 24%,rgba(50,142,101,.08) 25%,transparent 26%),linear-gradient(180deg,transparent 49%,rgba(50,142,101,.08) 50%,transparent 51%),linear-gradient(180deg,transparent 74%,rgba(50,142,101,.08) 75%,transparent 76%)}.line-bar{display:grid;align-items:end;justify-items:center;gap:8px;height:100%}.line-bar span{width:14px;min-height:10px;border-radius:999px 999px 4px 4px;background:var(--green)}.line-bar small{color:var(--muted);font-size:11px;font-weight:800}.department-bars{display:grid;gap:14px}.department-bars>div{display:grid;grid-template-columns:82px 1fr 64px;gap:10px;align-items:center;font-size:13px}.department-bars span{color:var(--muted);font-weight:800}.department-bars div div{height:10px;overflow:hidden;border-radius:999px;background:var(--surface-2)}.department-bars i{display:block;height:100%;border-radius:inherit;background:var(--green)}.department-bars strong{color:var(--green-dark);text-align:right}.activity-donut{display:grid;grid-template-columns:126px 1fr;gap:16px;align-items:center}.donut-visual{width:126px;aspect-ratio:1;border-radius:999px;background:radial-gradient(circle at center,#fff 0 48%,transparent 49%),conic-gradient(var(--green) 0 42%,#8fc7ad 42% 72%,#d4eadf 72% 100%)}.activity-donut p{display:flex;align-items:center;gap:8px;margin:9px 0;color:var(--muted);font-size:13px;font-weight:800}.activity-donut span{width:10px;height:10px;border-radius:999px;background:var(--green)}.activity-donut p:nth-child(2) span{background:#8fc7ad}.activity-donut p:nth-child(3) span{background:#d4eadf}.stat-card{padding:18px;background:var(--green-pale)}.stat-card span,.item-card span{display:block;color:var(--muted);font-size:12px;font-weight:800}.stat-card strong{display:block;margin-top:8px;color:var(--green-dark);font-size:25px}.stat-card p{margin:8px 0 0;color:var(--muted);font-size:13px}.admin-card{padding:18px}.admin-content-grid{display:grid;grid-template-columns:minmax(300px,.75fr) minmax(420px,1fr);gap:16px}.stack-form{display:grid;gap:13px}.stack-form label{display:grid;gap:7px;color:var(--muted);font-size:13px;font-weight:800}.table-wrap{overflow-x:auto}.card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.item-card{display:flex;justify-content:space-between;gap:14px;min-height:128px;padding:16px}.item-card h3{margin-top:8px}.item-card p{margin:0;color:var(--muted);font-size:13px}.item-card strong{flex:0 0 auto;color:var(--green)}@media(max-width:980px){.topbar,.admin-title{align-items:stretch;flex-direction:column}.view-switch{width:100%}.view-switch button{flex:1}.employee-shell,.admin-layout,.admin-content-grid{grid-template-columns:1fr}.employee-shell{justify-items:center}.mock-controls{max-width:410px;margin-top:0}.admin-sidebar{min-height:auto}.stat-grid,.dashboard-grid,.card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:620px){.app-shell{padding:14px}.brand h1{font-size:18px}.phone{min-height:720px;border-width:7px;border-radius:32px}.point-hero strong{font-size:40px}.stat-grid,.dashboard-grid,.card-grid{grid-template-columns:1fr}}button.ghost-button{min-height:42px;padding:0 16px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--green-dark);font-weight:900}button.ghost-button:hover{background:var(--surface-2)}button.ghost-button.danger{border-color:#d6454566;color:#c0392b}.mini-button{min-height:34px;padding:0 12px;border:1px solid var(--line);border-radius:7px;background:var(--surface);color:var(--green-dark);font-size:12px;font-weight:900}.mini-button:hover{background:var(--surface-2)}.mini-button.danger{border-color:#d6454559;color:#c0392b}.mini-button.danger:hover{background:#d6454514}.row-actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}td .row-actions{justify-content:flex-start;white-space:nowrap}.dialog-actions button.danger{background:#d64545;color:#fff}.row-active,.row-active td{background:var(--green-pale)}.card-active{border-color:var(--green);box-shadow:0 0 0 2px #328e652e}.item-card{flex-direction:column}.item-meta{display:block;margin-top:10px;color:var(--green);font-weight:900}.engagement-summary{display:grid;grid-template-columns:200px minmax(0,1fr);gap:20px;align-items:center}.engagement-rate{padding:18px;border-radius:14px;background:var(--green-pale);text-align:center}.engagement-rate span{display:block;color:var(--muted);font-size:12px;font-weight:800}.engagement-rate strong{display:block;margin:6px 0 4px;color:var(--green-dark);font-size:38px;line-height:1}.engagement-rate small{color:var(--muted);font-size:12px;font-weight:800}.privacy-note{margin:14px 0 0;padding:10px 12px;border-radius:10px;background:var(--surface-2);color:var(--muted);font-size:12px;line-height:1.6}@media(max-width:700px){.engagement-summary{grid-template-columns:1fr}}.detail-topbar{display:flex;align-items:center;gap:10px;padding:2px 0 4px}.detail-topbar button{min-height:36px;padding:0 12px 0 8px;border-radius:999px;background:var(--surface-2);color:var(--green-dark);font-size:14px;font-weight:900}.detail-topbar strong{font-size:16px}.meal-detail-photo{width:100%;aspect-ratio:4 / 3;object-fit:cover;border-radius:14px}.meal-detail-card h3{margin:16px 0 8px;font-size:14px}.meal-detail-head{display:flex;align-items:center;justify-content:space-between;margin-top:14px}.meal-detail-badge{display:inline-flex;padding:5px 12px;border-radius:999px;background:#328e651f;color:var(--green-dark);font-size:12px;font-weight:900}.meal-detail-head time{color:var(--muted);font-size:13px;font-weight:800}.meal-chip-list{display:flex;flex-wrap:wrap;gap:8px}.meal-chip{display:inline-flex;padding:7px 12px;border-radius:999px;background:var(--surface-2);color:var(--green-dark);font-size:13px;font-weight:800}.meal-detail-memo{margin:0;padding:12px;border-radius:12px;background:var(--surface-2);color:var(--ink);font-size:13px;line-height:1.6}.detail-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:18px}.detail-actions button{min-height:44px}.cheer-card{display:grid;gap:12px;padding:14px 16px;border-radius:18px;border:1px solid var(--line);background:linear-gradient(135deg,var(--green-pale),#fff)}.cheer-streak{display:flex;align-items:center;gap:10px}.cheer-flame{font-size:26px;line-height:1}.cheer-streak strong{display:block;font-size:17px;color:var(--green-dark)}.cheer-streak small{color:var(--muted);font-size:11px;font-weight:700}.cheer-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding-top:10px;border-top:1px solid var(--line)}.cheer-metrics span{display:block;color:var(--muted);font-size:11px;font-weight:700}.cheer-metrics strong{display:block;margin-top:3px;color:var(--green-dark);font-size:15px}.goal-name{display:block;font-size:15px;color:var(--ink)}.goal-bar{height:10px;margin:10px 0 8px;border-radius:999px;background:var(--surface-2);overflow:hidden}.goal-bar i{display:block;height:100%;border-radius:inherit;background:var(--green)}.goal-card p{margin:0;color:var(--muted);font-size:12px;font-weight:700}.goal-card p b{color:var(--green-dark)}.exercise-menu{display:grid;gap:10px}.exercise-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--line);border-radius:14px;background:#fff}.exercise-item.done{background:var(--green-pale)}.exercise-item strong{display:block;font-size:14px}.exercise-item span{color:var(--muted);font-size:11px;font-weight:700}.exercise-item button{flex:0 0 auto;min-height:38px;padding:0 14px;border-radius:999px;background:var(--green);color:#fff;font-size:12px;font-weight:900}.exercise-item button:disabled{background:var(--green-soft);color:var(--green-dark)}.activity-log-list{display:grid;gap:8px}.activity-log-row{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:12px;background:var(--surface-2)}.activity-log-row strong{display:block;font-size:14px}.activity-log-row span{color:var(--muted);font-size:11px;font-weight:700}.activity-log-row em{color:var(--green-dark);font-style:normal;font-weight:900}.nutrition-cal{display:grid;gap:6px;margin-bottom:14px}.nutrition-cal-bar{height:12px;border-radius:999px;background:var(--surface-2);overflow:hidden}.nutrition-cal-bar i{display:block;height:100%;border-radius:inherit;background:var(--green)}.nutrition-cal-text{display:flex;align-items:baseline;gap:6px}.nutrition-cal-text strong{font-size:22px;color:var(--green-dark)}.nutrition-cal-text span{color:var(--muted);font-size:12px;font-weight:800}.pfc-bar{display:flex;height:12px;margin-bottom:8px;border-radius:999px;overflow:hidden;background:var(--surface-2)}.pfc-bar span{display:block;height:100%}.pfc-p,.dot-p{background:var(--green)}.pfc-f,.dot-f{background:#e6a23c}.pfc-c,.dot-c{background:#8fc7ad}.pfc-legend{display:flex;flex-wrap:wrap;gap:10px 14px}.pfc-legend span{display:inline-flex;align-items:center;gap:5px;color:var(--muted);font-size:11px;font-weight:800}.pfc-legend i{width:9px;height:9px;border-radius:999px}.nutrition-veg{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding:10px 12px;border-radius:12px;background:var(--surface-2)}.nutrition-veg span{color:var(--muted);font-size:12px;font-weight:800}.nutrition-veg strong{color:var(--green-dark);font-size:15px}.nutrition-advice{margin:12px 0 0;padding:10px 12px;border-radius:12px;background:var(--green-pale);color:var(--green-dark);font-size:12px;font-weight:700;line-height:1.6}.meal-nutrition-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.meal-nutrition-grid div{padding:10px 6px;border-radius:12px;background:var(--surface-2);text-align:center}.meal-nutrition-grid span{display:block;color:var(--muted);font-size:10px;font-weight:800}.meal-nutrition-grid strong{display:block;margin-top:4px;color:var(--green-dark);font-size:16px}.meal-nutrition-grid strong i{font-size:10px;font-style:normal;margin-left:1px;color:var(--muted)}.body-card .section-line button{min-height:34px;padding:0 14px;border-radius:999px;background:var(--green-soft);color:var(--green-dark);font-size:12px;font-weight:900}.body-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.body-grid div{padding:12px 8px;border-radius:12px;background:var(--surface-2);text-align:center}.body-grid span{display:block;color:var(--muted);font-size:11px;font-weight:800}.body-grid strong{display:block;margin-top:4px;color:var(--green-dark);font-size:18px}.body-grid strong i{margin-left:2px;font-size:11px;font-style:normal;color:var(--muted)}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.checkin-card{display:grid;gap:12px;padding:14px;border:1px solid rgba(50,142,101,.4);border-radius:18px;background:linear-gradient(120deg,var(--green-pale),var(--green-soft));box-shadow:0 8px 22px #1d302b0d}.checkin-card.done{border-color:var(--line);background:var(--surface)}.checkin-head{display:flex;align-items:center;gap:12px}.checkin-head>div:not(.checkin-icon){flex:1;min-width:0}.checkin-icon{display:grid;place-items:center;flex:0 0 auto;width:40px;height:40px;border-radius:12px;background:#fff;font-size:20px}.checkin-card strong{display:block;font-size:14px}.checkin-card small{display:block;margin-top:2px;color:var(--muted);font-size:11px;font-weight:700;line-height:1.5}.qr-scan-button{min-height:42px;border-radius:999px;background:var(--green);color:#fff;font-size:13px;font-weight:900}.checkin-head em{flex:0 0 auto;display:grid;place-items:center;width:28px;height:28px;border-radius:999px;background:var(--green);color:#fff;font-style:normal;font-weight:900}.mission-progress{padding:4px 10px;border-radius:999px;background:var(--green-soft);color:var(--green-dark);font-size:11px;font-weight:900}.mission-list{display:grid;gap:8px}.mission-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:#fff;font-size:13px;font-weight:700}.mission-row i{display:grid;place-items:center;flex:0 0 auto;width:22px;height:22px;border:2px solid var(--line);border-radius:999px;background:#fff;color:#fff;font-size:12px;font-style:normal;font-weight:900}.mission-row.done{background:var(--green-pale);color:var(--green-dark)}.mission-row.done i{border-color:var(--green);background:var(--green)}.mission-note{margin:12px 0 0;color:var(--muted);font-size:11px;font-weight:700;line-height:1.6}.mission-card .primary-button{width:100%;margin-top:12px}.notice-list{display:grid;gap:10px}.notice-row{padding:12px;border:1px solid var(--line);border-radius:12px;background:#fff}.notice-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}.notice-head time{color:var(--muted);font-size:11px;font-weight:700}.notice-badge{padding:3px 9px;border-radius:999px;background:var(--surface-2);color:var(--muted);font-size:10px;font-weight:900}.notice-badge.event{background:var(--green-soft);color:var(--green-dark)}.notice-badge.important{background:#fdecec;color:#c0392b}.notice-row strong{display:block;font-size:13px}.notice-row p{margin:4px 0 0;color:var(--muted);font-size:12px;line-height:1.6}.notice-admin-list{display:grid;gap:12px}.notice-admin-row{display:grid;gap:8px;padding:14px;border:1px solid var(--line);border-radius:12px;background:#fff}.notice-admin-row.card-active{border-color:var(--green)}.notice-admin-body strong{display:block;font-size:14px}.notice-admin-body p{margin:4px 0 0;color:var(--muted);font-size:12px;line-height:1.6}.notice-admin-row .row-actions{justify-content:flex-end}.stack-form textarea{width:100%;resize:vertical;border:1px solid var(--line);border-radius:8px;padding:10px 12px;color:var(--ink);font:inherit;font-size:13px}.weight-chart{display:flex;align-items:flex-end;gap:8px;height:130px;padding:8px 4px 0}.weight-bar{display:flex;flex:1;flex-direction:column;align-items:center;justify-content:flex-end;gap:4px;height:100%;min-width:0}.weight-bar em{color:var(--green-dark);font-size:10px;font-style:normal;font-weight:900}.weight-bar span{width:100%;max-width:26px;min-height:6px;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--green),var(--green-dark))}.weight-bar small{color:var(--muted);font-size:10px;font-weight:700}.weight-goal p{margin:0;color:var(--muted);font-size:12px;font-weight:700}.weight-goal p b{color:var(--green-dark)}.weight-form{display:flex;align-items:flex-end;gap:10px;margin-top:14px;padding-top:14px;border-top:1px dashed var(--line)}.weight-form label{flex:1;display:grid;gap:7px;color:var(--muted);font-size:12px;font-weight:800}.weight-form .primary-button{flex:0 0 auto;padding:0 18px}.checkin-table{flex:1;min-width:0}.sync-badge{padding:4px 10px;border-radius:999px;background:var(--green-soft);color:var(--green-dark);font-size:11px;font-weight:900}.sync-note{margin:12px 0 0;padding:10px 12px;border-radius:10px;background:var(--green-pale);color:var(--green-dark);font-size:11px;font-weight:700;line-height:1.6}.mock-sim{display:grid;gap:8px;margin-top:16px;padding-top:16px;border-top:1px dashed var(--line)}.mock-sim label{display:grid;gap:8px;color:var(--muted);font-size:13px;font-weight:800}.mock-sim-title{color:var(--muted);font-size:13px;font-weight:800}.mock-sim button{min-height:38px;border-radius:8px;background:var(--green-soft);color:var(--green-dark);font-size:12px;font-weight:900}.mock-sim p{margin:0;color:var(--muted);font-size:11px;font-weight:600;line-height:1.6}.admin-datebar{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:16px}.admin-datebar button{width:34px;height:34px;border-radius:999px;background:var(--surface-2);color:var(--green);font-size:22px;line-height:1}.admin-datebar strong{min-width:120px;text-align:center;font-size:18px}.attendance-status{display:inline-block;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:900}.attendance-status.ok{background:var(--green-soft);color:var(--green-dark)}.attendance-status.none{background:#f2f2ee;color:var(--muted)}.dialog-note{margin:0;padding:10px 12px;border-radius:10px;background:var(--green-pale);color:var(--muted);font-size:12px;font-weight:700;line-height:1.6}.rules-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.rules-steps{display:grid;gap:8px;padding:12px;border:1px dashed var(--line);border-radius:10px;background:var(--green-pale)}.rules-steps-title{color:var(--muted);font-size:12px;font-weight:800}.rules-step-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.rules-form button[type=submit]{justify-self:start;min-height:42px;padding:0 22px;border-radius:10px;background:var(--green);color:#fff;font-weight:900}@media(max-width:960px){.rules-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
