: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:not(:disabled):hover{background:#ececea;color:var(--punch-blue)}.icon-btn.confirmed{color:var(--punch-green)}.icon-btn:disabled{opacity:.4;cursor:default}.icon-btn svg{width:17px;height:17px;fill:currentColor}.trash-btn{color:#888780cc}.trash-btn:not(:disabled):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:6px;margin-top:10px;font-size:12px;color:var(--muted);flex-wrap:wrap}.zoom-connect .sep{color:var(--muted-soft);font-size:10px}.zoom-connect-stacked{display:flex;flex-direction:column;align-items:center;gap:6px}.zoom-connect-sub{font-size:12px}.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}.zoom-connect .zoom-link.subtle,.zoom-connect-sub .zoom-link.subtle{color:var(--muted);font-size:12px;font-weight:500;background:none;border:none;cursor:pointer}.zoom-connect .zoom-link.subtle:hover,.zoom-connect-sub .zoom-link.subtle:hover{color:var(--punch-blue);text-decoration:underline}.zoom-connect .zoom-link.primary{display:block;width:100%;padding:11px 16px;background:var(--punch-blue);color:#fff;border-radius:9px;font-size:15px;font-weight:600;text-align:center}.zoom-connect .zoom-link.primary:hover{text-decoration:none;opacity:.92}.zoom-connect .zoom-link.primary[aria-busy=true]{cursor:default;animation:connect-pulse 1.2s ease-in-out infinite}@keyframes connect-pulse{0%,to{opacity:1}50%{opacity:.6}}.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}.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)}.mode-selector-container{margin-bottom:4px}.mode-selector{display:flex;background:#0000000f;padding:3px;border-radius:9px;gap:3px}.mode-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6px 4px;border:none;background:transparent;border-radius:7px;cursor:pointer;transition:all .15s ease;color:var(--muted)}.mode-btn.active{background:var(--card);color:#1a1a1a;box-shadow:0 1px 4px #0000001f}.mode-title{font-size:13px;font-weight:600;line-height:1.2}.mode-subtitle{font-size:10px;opacity:.75;margin-top:1px}.manual-form{padding:10px 12px;display:flex;flex-direction:column;gap:8px}.manual-form-header{display:flex;align-items:center;justify-content:space-between}.manual-form-header .label{font-size:11px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.now-btn{background:none;border:none;padding:2px 6px;font-size:11px;font-weight:500;color:var(--punch-blue);cursor:pointer;border-radius:4px}.now-btn:hover{background:var(--punch-blue-bg)}.manual-form-body{display:flex;align-items:center;gap:8px}.type-toggle{display:flex;background:var(--surface);padding:2px;border-radius:6px;border:.5px solid var(--border)}.type-btn{border:none;background:transparent;padding:4px 10px;font-size:12px;font-weight:600;border-radius:4px;cursor:pointer;color:var(--muted)}.type-btn.in.active{background:var(--punch-green-bg);color:var(--punch-green-dark)}.type-btn.out.active{background:var(--punch-red-bg);color:var(--punch-red-dark)}.time-input-wrap{flex:1}.manual-time-input{width:100%;padding:5px 8px;font-size:13px;font-weight:500;font-family:inherit;border:.5px solid var(--border);border-radius:6px;background:var(--edit-bg);outline:none}.manual-time-input:focus{border-color:var(--punch-blue)}.add-entry-btn{padding:5px 12px;font-size:13px;font-weight:600;background:var(--punch-blue);color:#fff;border:none;border-radius:6px;cursor:pointer;transition:opacity .1s ease}.add-entry-btn:hover{opacity:.9}.manual-form-error{font-size:11px;color:var(--punch-red-dark);margin-top:-2px}.view-tabs{display:flex;background:var(--surface);padding:3px;border-radius:8px;border:.5px solid var(--border);margin-bottom:12px}.tab-btn{flex:1;border:none;background:transparent;padding:6px 12px;font-size:12px;font-weight:600;border-radius:6px;cursor:pointer;color:var(--muted);transition:all .15s ease}.tab-btn.active{background:var(--card-bg);color:var(--text);box-shadow:0 1px 3px #00000014}.meeting-row{padding:10px 14px;border-bottom:.5px solid var(--border)}.meeting-row:last-child{border-bottom:none}.meeting-main{display:flex;flex-direction:column;gap:4px}.meeting-topic-line{display:flex;align-items:center;justify-content:space-between;gap:8px}.meeting-topic{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.meeting-meta{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}.meeting-badge{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px;background:var(--surface);color:var(--muted);border:.5px solid var(--border)}.meeting-badge.recording{background:var(--punch-green-bg);color:var(--punch-green-dark);border-color:transparent}.meeting-badge.paused{background:#fff8e6;color:#b7791f;border-color:transparent}.meeting-badge.stopped{background:var(--punch-red-bg);color:var(--punch-red-dark);border-color:transparent}
