:root{--punch-green: #1D9E75;--punch-green-dark: #0F6E56;--punch-green-bg: #E1F5EE;--punch-red: #D85A30;--punch-red-dark: #993C1D;--punch-red-bg: #FAEBE7;--punch-blue: #185FA5;--punch-blue-bg: #E6F1FB;--surface: #f5f5f3;--card: #ffffff;--muted: #888780;--muted-soft: #B4B2A9;--border: rgba(0, 0, 0, .12);--edit-bg: #F1EFE8}*{box-sizing:border-box}[hidden]{display:none!important}html,body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,Roboto,sans-serif;background:#e9e9e3;color:#1a1a1a;-webkit-font-smoothing:antialiased}body{display:flex;align-items:flex-start;justify-content:center;min-height:100vh;min-height:100dvh;padding:clamp(12px,4vw,32px)}#root{display:contents}.app{width:100%;max-width:360px;background:var(--surface);border-radius:14px;box-shadow:0 12px 36px #0000002e;overflow:hidden;display:flex;flex-direction:column}@media(max-width:480px){body{padding:0;align-items:stretch}.app{max-width:none;min-height:100vh;min-height:100dvh;border-radius:0;box-shadow:none}.entries{max-height:none!important}}@media(min-width:768px){.app{max-width:380px}}.app.app--panel{max-width:none;width:100%;min-height:100vh;min-height:100dvh;border-radius:0;box-shadow:none}.app--panel .entries{max-height:none!important}.app-body{padding:14px 14px 0;display:flex;flex-direction:column;gap:8px;flex:1 1 auto;min-height:0}.card{background:var(--card);border:.5px solid var(--border);border-radius:10px}.total{display:flex;align-items:center;padding:10px 14px}.total .label{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.total .value{margin-left:auto;font-size:20px;font-weight:500;color:var(--punch-blue);font-variant-numeric:tabular-nums;font-family:-apple-system,SF Pro Rounded,system-ui,sans-serif}.pulse-dot{width:7px;height:7px;border-radius:50%;background:var(--punch-green);animation:pulse 1.2s ease-in-out infinite alternate}@keyframes pulse{0%{opacity:1}to{opacity:.3}}.log{display:flex;flex-direction:column;overflow:hidden;flex:1 1 auto;min-height:0}.log-header{display:flex;align-items:center;flex-wrap:wrap;gap:6px 8px;padding:10px 10px 8px;border-bottom:.5px solid var(--border)}.log-header .label{font-size:11px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.log-actions{margin-left:auto;display:flex;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:2px}.icon-btn{background:none;border:none;margin:0;padding:6px 8px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;font-size:12px;color:#888780f2;font-family:inherit;transition:background .1s ease,color .1s ease}.icon-btn:hover{background:#ececea;color:var(--punch-blue)}.icon-btn.confirmed{color:var(--punch-green)}.icon-btn svg{width:17px;height:17px;fill:currentColor}.icon-btn.icon-only{padding:6px}.trash-btn{color:#888780cc}.trash-btn:hover{background:#f7e9e9;color:var(--punch-red)}.entries{max-height:min(240px,45vh);overflow-y:auto;flex:1 1 auto;min-height:0;-webkit-overflow-scrolling:touch}.empty{text-align:center;color:var(--muted-soft);font-size:13px;padding:28px 0}.entry{display:flex;align-items:center;gap:8px;padding:9px 12px;border-bottom:.5px solid var(--border)}.entry:last-of-type{border-bottom:none}.entry.has-duration{border-bottom:none}.dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.dot.in{background:var(--punch-green)}.dot.out{background:var(--punch-red)}.time{font-size:14px;font-weight:500;padding:2px 4px;border-radius:5px;cursor:text;-webkit-user-select:none;user-select:none}.time:hover{background:#0000000a}.time-edit{font-size:14px;font-weight:500;width:100px;padding:2px 6px;background:var(--edit-bg);border:.5px solid var(--border);border-radius:5px;font-family:inherit;outline:none}.time-edit:focus{border-color:var(--punch-blue)}.commit-btn,.cancel-btn{background:none;border:none;padding:2px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.commit-btn svg{color:var(--punch-green)}.cancel-btn svg{color:var(--punch-red)}.commit-btn svg,.cancel-btn svg{width:11px;height:11px;fill:currentColor}.badge{margin-left:auto;font-size:11px;font-weight:500;padding:2px 8px;border-radius:999px}.badge.in{background:var(--punch-green-bg);color:var(--punch-green-dark)}.badge.out{background:var(--punch-red-bg);color:var(--punch-red-dark)}.duration-row{display:flex;justify-content:center;height:0;align-items:center;position:relative;z-index:1;pointer-events:none}.duration-row:before{content:"";position:absolute;left:0;right:0;top:0;border-top:.5px solid var(--border)}.duration{font-size:11px;font-weight:500;color:var(--punch-blue);background:var(--punch-blue-bg);padding:2px 10px;border-radius:999px}.footer{margin-top:8px;padding:12px 14px;padding-bottom:max(12px,env(safe-area-inset-bottom));background:var(--surface);box-shadow:0 -2px 4px #0000000f;flex-shrink:0}.punch-btn{width:100%;min-height:44px;border:none;border-radius:9px;font-size:16px;font-weight:500;letter-spacing:.3px;color:#fff;cursor:pointer;transition:transform .1s ease,opacity .1s ease;font-family:inherit}.punch-btn.in{background:var(--punch-green)}.punch-btn.out{background:var(--punch-red)}.punch-btn:active{transform:scale(.98);opacity:.85}.connect-prompt{padding:28px 20px;text-align:center}.connect-prompt p{margin:0;font-size:14px;color:var(--muted);line-height:1.4}.zoom-connect{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:10px;font-size:12px;color:var(--muted)}.zoom-connect .zoom-status strong{font-weight:600;color:#1a1a1a}.zoom-connect .zoom-link{color:var(--punch-blue);text-decoration:none;font-weight:500;cursor:pointer;background:none;border:none;padding:0;font:inherit}.zoom-connect .zoom-link:hover{text-decoration:underline}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;padding:16px;z-index:100;animation:fade-in .12s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--card);border-radius:12px;box-shadow:0 20px 50px #00000040;width:100%;max-width:320px;padding:18px 18px 14px}.modal-title{font-size:15px;font-weight:600;margin:0 0 4px}.modal-body{font-size:13px;color:var(--muted);margin:0 0 14px;line-height:1.4}.modal-error{color:#c0392b}.modal-note{font-size:12px;margin:-6px 0 12px}.import-fields{display:flex;gap:12px;margin:0 0 14px}.import-fields label{display:flex;flex:1;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}.import-fields input[type=date],.import-fields select{font:inherit;font-size:13px;padding:7px 8px;border:.5px solid var(--border);border-radius:8px;background:#fff;color:#1a1a1a}.report-summary{margin:0 0 14px}.report-total{font-size:14px;color:#1a1a1a;margin-bottom:8px}.report-total strong{font-size:18px;font-weight:600}.report-rows{display:flex;flex-direction:column;gap:2px;max-height:200px;overflow-y:auto;border:.5px solid var(--border);border-radius:8px;padding:4px}.report-row{display:flex;justify-content:space-between;gap:8px;font-size:13px;padding:5px 8px;color:var(--muted)}.report-row span:last-child{color:#1a1a1a;font-variant-numeric:tabular-nums;white-space:nowrap}.report-row-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#1a1a1a}.report-row-date{color:var(--muted-soft);font-size:11px}.import-fields input:disabled{opacity:.6}.modal-btn:disabled{opacity:.6;cursor:default}.import-list{display:flex;flex-direction:column;gap:2px;max-height:240px;overflow-y:auto;margin:0 0 14px;border:.5px solid var(--border);border-radius:8px;padding:4px}.import-row{display:flex;align-items:flex-start;gap:8px;padding:8px;border-radius:6px;cursor:pointer}.import-row:hover{background:#ececea}.import-row input{margin-top:2px}.import-row-main{display:flex;flex-direction:column;gap:2px;min-width:0}.import-row-topic{font-size:13px;font-weight:500;color:#1a1a1a}.import-row-meta{font-size:12px;color:var(--muted)}.meeting-banner{font-size:13px;font-weight:600;color:#1a1a1a;text-align:center;padding:7px 12px;background:var(--surface);border:.5px solid var(--border);border-radius:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-actions{display:flex;flex-direction:column;gap:6px}.modal-btn{width:100%;padding:9px 12px;border-radius:8px;border:.5px solid var(--border);background:var(--surface);color:#1a1a1a;font:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:background .1s ease}.modal-btn:hover{background:#ececea}.modal-btn.primary{background:var(--punch-blue);border-color:var(--punch-blue);color:#fff}.modal-btn.primary:hover{background:#134a82}.modal-btn.cancel{color:var(--muted)}
