:root{color:#201812;background:radial-gradient(circle at top left,rgba(250,185,79,.26),transparent 28%),linear-gradient(180deg,#fffaf1,#efe2ca);font-family:IBM Plex Sans,Hiragino Sans,sans-serif;line-height:1.5;font-weight:400}*{box-sizing:border-box}body{margin:0}button,input,select,table{font:inherit}.page-shell{min-height:100vh;padding:32px 20px 56px}.hero,.section,.panel{max-width:1180px;margin:0 auto 24px}.hero{display:grid;gap:24px;grid-template-columns:minmax(0,1.8fr) minmax(260px,.8fr);align-items:end}.eyebrow{margin:0 0 8px;text-transform:uppercase;letter-spacing:.18em;font-size:12px}.hero h1,.section h2,.panel h2,.status-card h3{font-family:Avenir Next,IBM Plex Sans,sans-serif}.hero h1{margin:0 0 12px;font-size:clamp(2.4rem,5vw,4.5rem);line-height:.95}.lead{max-width:72ch;margin:0}.hero-note{margin:12px 0 0;max-width:60ch;color:#76553a;font-size:.95rem}.hero-meta,.status-meta{margin:0}.hero-meta{display:grid;gap:12px;padding:20px;border-radius:24px;background:#ffffffd1;box-shadow:0 18px 60px #311f1017}.hero-meta div,.status-meta div{display:grid;gap:4px}.hero-meta dt,.status-meta dt{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:#76553a}.hero-meta dd,.status-meta dd{margin:0}.locale-select{width:100%;min-height:44px;padding:10px 12px;border:1px solid rgba(118,85,58,.24);border-radius:14px;background:#fffaf1bf}.panel,.status-card,.matrix-scroll,.punch-panel{border-radius:24px;background:#ffffffe0;box-shadow:0 18px 60px #311f1017}.panel{padding:24px}.panel.error{border:1px solid rgba(170,63,37,.28)}.panel.empty{text-align:center}.section-head{margin-bottom:16px}.section-head h2{margin:0 0 4px;font-size:1.6rem}.section-head p,.panel p{margin:0}.punch-panel{display:grid;gap:16px;padding:24px}.field{display:grid;gap:8px}.field span{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:#76553a}.field input,.field select{width:100%;min-height:52px;padding:12px 14px;border:1px solid rgba(118,85,58,.24);border-radius:14px;background:#fffaf1bf}.punch-actions{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.punch-button{min-height:56px;border:0;border-radius:18px;font-weight:700;cursor:pointer;transition:transform .12s ease,opacity .12s ease}.punch-button:disabled{opacity:.68;cursor:wait}.punch-button:not(:disabled):active{transform:translateY(1px)}.punch-button.in{background:#0f7d42;color:#fffef7}.punch-button.out{background:#b24b28;color:#fffef7}.punch-hint{color:#6b584a;font-size:.95rem}.feedback{display:grid;gap:6px;padding:14px 16px;border-radius:16px}.feedback-success{background:#e8fff1;color:#0d6d3a}.feedback-warning{background:#fff5d7;color:#875300}.feedback-error{background:#fff0ec;color:#a24324}.summary-card{display:grid;gap:10px;padding:16px;border-radius:18px;background:#fff7e8e6}.summary-card h3,.summary-card p{margin:0}.summary-meta{display:grid;gap:10px;margin:0}.summary-meta div{display:grid;gap:4px}.summary-meta dt{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:#76553a}.summary-meta dd{margin:0}.status-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.status-card{padding:20px}.status-header{display:flex;justify-content:space-between;align-items:start;gap:16px;margin-bottom:18px}.status-header h3{margin:0;font-size:1.2rem}.status-header p{margin:4px 0 0;color:#6b584a}.status-meta{display:grid;gap:12px}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:72px;padding:8px 14px;border-radius:999px;font-weight:700}.badge-on{background:#e5ffef;color:#0f7d42}.badge-off{background:#fff0ec;color:#a24324}.badge-unknown{background:#f1ece6;color:#655346}.matrix-scroll{overflow-x:auto;padding:12px}.matrix{width:100%;min-width:720px;border-collapse:collapse}.matrix th,.matrix td{padding:14px 16px;border-bottom:1px solid rgba(118,85,58,.15);text-align:left;vertical-align:top}.matrix thead th{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:#76553a}.matrix tbody th{min-width:180px}.matrix td strong,.matrix td span,.matrix td small{display:block}.matrix td span{margin-top:4px}.matrix td small{margin-top:6px;color:#6b584a}@media(max-width:760px){.hero{grid-template-columns:1fr}.page-shell{padding-inline:16px}.punch-actions{grid-template-columns:1fr}}.add-member-toggle{margin-top:8px;padding:6px 14px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#1e293b;font-size:.88rem;cursor:pointer}.add-member-toggle:hover{background:#f1f5f9}.add-member-form{background:#f8fafc;border:1px solid #cbd5e1;border-radius:10px;padding:18px 20px;margin:12px 0 20px}.add-member-form h3{margin:0 0 6px;font-size:1rem}.add-member-form p{margin:0 0 14px;color:#64748b;font-size:.88rem}.add-member-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:14px}.add-member-actions{display:flex;gap:10px}@media(max-width:600px){.add-member-grid{grid-template-columns:1fr}}.month-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:18px}.month-summary__cell{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:12px 14px}.month-summary__cell dt{color:#64748b;font-size:.78rem;margin-bottom:4px}.month-summary__cell dd{margin:0;font-size:1.15rem;font-weight:700;color:#0f172a}.month-table-wrap{overflow-x:auto;border:1px solid #e2e8f0;border-radius:10px}.month-table{width:100%;border-collapse:collapse;background:#fff}.month-table th,.month-table td{padding:10px 14px;text-align:left;border-bottom:1px solid #e2e8f0}.month-table thead th{background:#f8fafc;font-size:.85rem;font-weight:700;color:#475569}.month-table tbody tr:last-child td{border-bottom:none}.month-table tbody tr:hover{background:#f8fafc}.empty-note{text-align:center;color:#64748b;padding:20px;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:10px}.request-toggle-row{margin-top:12px}.request-toggle{width:100%;padding:10px;border:1px dashed #f59e0b;border-radius:8px;background:#fffbeb;color:#92400e;cursor:pointer;font-weight:600;font-size:.92rem}.request-toggle:hover{background:#fef3c7}.request-form{background:#fef3c7;border:1px solid #f59e0b;border-radius:10px;padding:18px 20px;margin:12px 0 16px}.request-form h4{margin:0 0 6px;font-size:1rem;color:#78350f}.request-note{margin:0 0 14px;color:#78350f;font-size:.88rem}.request-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}.request-note-field{grid-column:1 / -1}.request-actions{display:flex;gap:10px}@media(max-width:600px){.request-grid{grid-template-columns:1fr}}.admin-section{background:#f8fafc}.admin-toggle{padding:8px 14px;border:1px solid #6366f1;border-radius:8px;background:#eef2ff;color:#3730a3;cursor:pointer;font-weight:600;font-size:.9rem}.admin-toggle:hover{background:#c7d2fe}.admin-login{padding:18px 20px;background:#fff;border:1px solid #cbd5e1;border-radius:10px}.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}@media(max-width:600px){.admin-grid{grid-template-columns:1fr}}.admin-panel{padding:18px 20px;background:#fff;border:1px solid #cbd5e1;border-radius:10px}.admin-status{margin:0 0 12px;color:#3730a3}.admin-error{margin-top:12px;padding:10px 14px;background:#fef2f2;border:1px solid #fca5a5;border-radius:6px;color:#991b1b;font-size:.9rem}.status-badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.78rem;font-weight:700}.status-pending{background:#fef3c7;color:#92400e}.status-rejected{background:#fee2e2;color:#991b1b}.admin-login-section{max-width:480px;margin:24px auto}.approval-banner{margin:20px 0;padding:18px 22px;border-radius:14px;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;box-shadow:0 6px 20px -6px #f59e0b59}.approval-banner--empty{background:#ecfdf5;border-color:#34d399;box-shadow:none;padding:14px 22px;display:flex;justify-content:space-between;align-items:center;color:#065f46;font-weight:600}.approval-banner__head{display:flex;align-items:center;gap:10px;margin-bottom:12px}.approval-banner__icon{font-size:1.4rem}.approval-banner__title{font-size:1.05rem;font-weight:800;color:#78350f;flex:1}.approval-banner__refresh{background:#fff;border:1px solid #f59e0b;color:#92400e;padding:4px 12px;border-radius:8px;cursor:pointer;font-weight:600;font-size:.85rem}.approval-banner__refresh:hover{background:#fef3c7}.approval-list{display:flex;flex-direction:column;gap:10px}.approval-item{background:#fff;border:1px solid rgba(245,158,11,.3);border-radius:10px;padding:12px 14px;display:grid;grid-template-columns:1fr auto;gap:14px;align-items:center}@media(max-width:540px){.approval-item{grid-template-columns:1fr}.approval-item__actions{justify-self:stretch;display:flex;gap:8px}.approval-item__actions .approval-btn{flex:1}}.approval-item__top{display:flex;align-items:baseline;gap:10px;margin-bottom:4px}.approval-item__top strong{font-size:1rem}.approval-item__type{font-size:.8rem;font-weight:700;padding:2px 10px;border-radius:999px}.approval-item__type.in{background:#ecfdf5;color:#065f46}.approval-item__type.out{background:#fee2e2;color:#991b1b}.approval-item__time{font-family:ui-monospace,JetBrains Mono,monospace;font-size:.92rem;color:#1e293b;font-weight:700}.approval-item__note{font-size:.85rem;color:#475569;margin-top:4px}.approval-item__submitted{font-size:.75rem;color:#94a3b8;margin-top:4px}.approval-item__actions{display:flex;flex-direction:column;gap:6px}.approval-btn{padding:10px 18px;border:none;border-radius:8px;font-weight:700;font-size:.92rem;cursor:pointer;font-family:inherit;min-width:90px;transition:transform .08s}.approval-btn:active:not(:disabled){transform:translateY(1px)}.approval-btn:disabled{opacity:.5;cursor:not-allowed}.approval-btn.approve{background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;box-shadow:0 4px 10px -4px #16a34a66}.approval-btn.reject{background:#fff;color:#991b1b;border:1px solid #fca5a5}.approval-btn.reject:hover{background:#fef2f2}@media(max-width:760px){.page-shell{padding:18px 14px 48px}.hero{grid-template-columns:1fr;gap:16px}.hero h1{font-size:clamp(1.8rem,8vw,2.6rem)}.hero-meta{padding:14px 16px}.approval-banner{padding:14px 16px;margin:16px 0}.approval-item{grid-template-columns:1fr}.approval-item__actions{flex-direction:row;gap:8px}.approval-item__actions .approval-btn{flex:1}.month-summary__cards{grid-template-columns:1fr}.month-table th,.month-table td{padding:8px 10px;font-size:.85rem}.admin-grid{grid-template-columns:1fr}.section,.panel{padding:14px 16px;border-radius:18px}.section h2,.panel h2{font-size:1.1rem}}@media(max-width:480px){.hero-meta{grid-template-columns:1fr 1fr}.hero-meta div:last-child{grid-column:span 2}.approval-banner__title{font-size:.95rem}.approval-item__top{flex-wrap:wrap;gap:6px}.month-table-wrap{margin:0 -16px;border-radius:0}}
