:root{--bg: #e7eaed;--panel: #f3f5f7;--surface: #ffffff;--line: #d4d9de;--line-2: #e6e9ec;--ink: #0c1118;--ink-2: #39434d;--muted: #6e7a85;--accent: #079b8a;--accent-deep: #057468;--accent-soft: #e2f4f1;--danger: #df2f2f;--warn: #d97706;--ok: #0c9b73;--info: #1c7ed6;--radius: 12px;--maxw: 600px;--mono: "Space Mono", ui-monospace, "SFMono-Regular", monospace;--sans: "Pretendard", system-ui, -apple-system, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background-color:var(--bg);background-image:linear-gradient(rgba(12,17,24,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(12,17,24,.04) 1px,transparent 1px);background-size:22px 22px;color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font-family:inherit;cursor:pointer}a{color:var(--accent-deep)}::selection{background:var(--accent);color:#fff}.app-shell{max-width:var(--maxw);margin:0 auto;min-height:100%;display:flex;flex-direction:column;padding-bottom:76px;background:var(--panel);border-inline:1px solid var(--line)}.app-main{flex:1}.center-screen{display:grid;place-items:center;height:100vh;color:var(--muted);font-family:var(--mono);font-size:13px;letter-spacing:.04em}.mock-banner{background:#fff7e6;color:var(--warn);font-size:11px;font-family:var(--mono);letter-spacing:.02em;text-align:center;padding:8px 12px;border-bottom:1px solid var(--line)}.mock-banner.inline{border:1px solid #f0d9a8;border-radius:8px;margin:12px 0}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:var(--maxw);display:grid;grid-template-columns:repeat(4,1fr);background:var(--surface);border-top:1px solid var(--line);box-shadow:0 -1px 0 var(--line-2),0 -8px 24px #0c11180d;padding-bottom:env(safe-area-inset-bottom);z-index:20}.nav-tab{position:relative;display:flex;flex-direction:column;align-items:center;gap:3px;padding:11px 0 9px;text-decoration:none;color:var(--muted);font-size:10px;font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;transition:color .18s ease}.nav-tab.active{color:var(--accent-deep)}.nav-tab.active:before{content:"";position:absolute;top:-1px;left:22%;right:22%;height:2px;background:var(--accent);border-radius:2px}.nav-icon{font-size:17px}.page{padding:18px 16px}.page-head{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--line)}.page-head h2{margin:0;font-size:23px;font-weight:800;letter-spacing:-.02em}.page-sub,.page-head .muted{color:var(--muted);font-size:12px;font-family:var(--mono);letter-spacing:.02em;margin-top:3px}.muted{color:var(--muted)}.small{font-size:12px}.mono{font-family:var(--mono);font-size:12px;letter-spacing:.01em}.btn{border:1px solid var(--line);background:var(--surface);color:var(--ink);border-radius:9px;padding:11px 15px;font-size:14px;font-weight:700;letter-spacing:-.01em;transition:transform .12s ease,box-shadow .18s ease,background .18s ease}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent-deep);box-shadow:0 1px 0 var(--accent-deep),0 6px 16px #079b8a38}.btn-primary:hover:not(:disabled){background:var(--accent-deep)}.btn-ghost{background:transparent;width:100%;margin-top:10px}.btn-danger{background:transparent;border-color:#f0bcbc;color:var(--danger);width:100%;margin-top:12px}.btn-sm{padding:7px 11px;font-size:13px}.badge{display:inline-block;font-size:10px;font-weight:700;font-family:var(--mono);letter-spacing:.05em;text-transform:uppercase;padding:3px 8px;border-radius:5px;line-height:1.5;border:1px solid transparent}.badge-ok{background:#e3f6ef;color:var(--ok);border-color:#bfe9d8}.badge-warn{background:#fdf2e0;color:var(--warn);border-color:#f4dcb0}.badge-danger{background:#fbe6e6;color:var(--danger);border-color:#f3c4c4}.badge-info{background:#e4f0fb;color:var(--info);border-color:#bedaf3}.badge-muted{background:var(--line-2);color:var(--muted);border-color:var(--line)}.login-screen{display:grid;place-items:center;min-height:100vh;padding:20px}.login-card{position:relative;width:100%;max-width:372px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:32px 26px 26px;box-shadow:0 1px #fff inset,0 18px 50px #0c11181a;overflow:hidden}.login-card:before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-deep))}.login-title{margin:0;font-size:26px;font-weight:800;letter-spacing:-.03em}.login-sub{color:var(--muted);font-size:11px;font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;margin-top:5px}.login-form{display:flex;flex-direction:column;gap:13px;margin:22px 0 12px}.form-error{color:var(--danger);font-size:12px;font-family:var(--mono);margin:0}label{display:flex;flex-direction:column;gap:6px;font-size:11px;font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}input,select,textarea{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:11px 12px;color:var(--ink);font-size:15px;font-family:var(--sans);transition:border-color .16s ease,box-shadow .16s ease}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.device-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.device-card{position:relative;text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:13px 13px 12px;color:var(--ink);overflow:hidden;transition:transform .14s ease,box-shadow .18s ease,border-color .18s ease}.device-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--line);transition:background .18s ease}.device-card:hover{transform:translateY(-2px);box-shadow:0 10px 28px #0c111814}.device-card.selected{border-color:var(--accent)}.device-card.selected:before{background:var(--accent)}.device-card-top{display:flex;justify-content:space-between;align-items:center;gap:6px}.device-name{font-weight:700;font-size:14px;letter-spacing:-.01em}.device-dbfs{font-family:var(--mono);font-size:30px;font-weight:700;letter-spacing:-.03em;margin:10px 0 5px;font-variant-numeric:tabular-nums}.device-dbfs .unit,.gauge-unit{font-size:11px;font-weight:400;font-family:var(--mono);color:var(--muted);margin-left:5px;letter-spacing:0}.device-meta{display:flex;align-items:center;gap:8px;font-size:11px;font-family:var(--mono);color:var(--muted);flex-wrap:wrap}.device-meta .serial{margin-left:auto;font-family:var(--mono);color:var(--ink-2)}.live-panel{margin-top:18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:0 1px #fff inset}.live-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px}.live-head h3{margin:0;font-size:16px;font-weight:700;letter-spacing:-.01em}.gauge{min-width:132px}.gauge-value{font-family:var(--mono);font-size:24px;font-weight:700;text-align:right;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.gauge-track{height:6px;background:var(--line-2);border-radius:999px;overflow:hidden;margin-top:5px}.gauge-fill{height:100%;background:var(--accent);transition:width .3s ease}.chart-wrap{margin:8px 0}.chart-title{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-top:8px}.big-dbfs{text-align:center;font-family:var(--mono);font-size:40px;font-weight:800;letter-spacing:-.03em;font-variant-numeric:tabular-nums;color:#0d9488;margin:2px 0}.big-dbfs .unit{font-size:15px;font-weight:500;color:var(--muted);margin-left:6px}.control-row{display:flex;align-items:center;gap:12px;margin-top:12px;padding-top:12px;border-top:1px dashed var(--line)}.control-phase{font-size:11px;font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.device-select{margin-top:8px;width:100%}.cal-head{display:flex;align-items:center;justify-content:space-between;margin:12px 0 8px;font-weight:700;font-family:var(--mono);letter-spacing:.02em}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-weekday{text-align:center;font-size:10px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:4px 0}.cal-cell{aspect-ratio:1;border:1px solid var(--line);background:var(--surface);border-radius:7px;color:var(--ink);font-size:13px;font-family:var(--mono);font-variant-numeric:tabular-nums;transition:border-color .14s ease,background .14s ease}.cal-cell:hover:not(.empty){border-color:var(--accent)}.cal-cell.empty{border:none;background:transparent}.cal-cell.selected{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-deep);font-weight:700}.day-events{margin-top:18px}.day-events h3{font-size:14px;font-family:var(--mono);letter-spacing:.02em}.event-row{border:1px solid var(--line);border-radius:9px;margin-bottom:8px;overflow:hidden;background:var(--surface);transition:border-color .16s ease}.event-row:hover{border-color:var(--line)}.event-summary{width:100%;display:flex;align-items:center;gap:10px;padding:11px 13px;background:transparent;color:var(--ink);text-align:left}.event-time{font-weight:700;font-size:13px;font-family:var(--mono);font-variant-numeric:tabular-nums;color:var(--ink-2)}.event-peak{color:var(--accent-deep);font-size:13px;font-weight:700;font-family:var(--mono);font-variant-numeric:tabular-nums}.event-tag{font-size:14px}.event-detail{padding:13px;border-top:1px solid var(--line);background:var(--panel)}.ai-tag-editor .row,.my-card .row,.ai-tag-editor+.notes h4{display:flex}.ai-tag-editor .row,.my-card .row{align-items:center;justify-content:space-between;gap:10px;padding:7px 0}.ai-tag-editor .label,.my-card .label{color:var(--muted);font-size:11px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.04em}.ai-tag-editor .value.readonly{font-weight:700}.notes{margin-top:12px}.notes h4{margin:8px 0;font-size:13px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.04em;color:var(--ink-2)}.note-item{border-left:2px solid var(--accent);padding:4px 0 4px 11px;margin-bottom:8px}.note-item p{margin:0;font-size:14px}.note-item time{font-size:10px;font-family:var(--mono);color:var(--muted)}.note-form{display:flex;gap:8px}.note-form input{flex:1}.report-form{display:flex;flex-direction:column;gap:13px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.report-list{margin-top:24px}.report-list h3{font-size:14px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.03em}.report-item{border:1px solid var(--line);border-radius:9px;padding:13px;margin-bottom:8px;background:var(--surface)}.report-item-top{display:flex;justify-content:space-between;align-items:center;gap:8px}.report-purpose{font-weight:700;font-size:14px}.report-meta{display:flex;justify-content:space-between;margin-top:7px;font-size:11px;font-family:var(--mono);color:var(--muted)}.my-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:6px 15px;margin-bottom:16px}.clip-section{margin:12px 0}.clip-player{display:flex;flex-direction:column;gap:6px}.clip-audio{width:100%;height:38px}.clip-path{word-break:break-all;opacity:.65;font-family:var(--mono);font-size:10px}.consent-row{flex-direction:row!important;align-items:center;gap:8px}.consent-row input{width:auto}.cal-edit{display:flex;align-items:center;gap:6px}.cal-offset-input{width:76px;font-family:var(--mono)}@media (hover: none){.device-card:hover{transform:none;box-shadow:none}}@media (prefers-reduced-motion: reduce){*{transition:none!important}}
