@import"https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@400;500;700;900&display=swap";:root{--navy-900: #0B1B33;--navy-800: #12294A;--navy-700: #1B3A63;--navy-600: #244B7E;--navy-500: #2F6BB0;--accent: #3D8BFD;--accent-soft: #E8F1FF;--teal: #2BB3A3;--bg: #F5F8FC;--surface: #FFFFFF;--text: #0B1B33;--text-muted: #5B6B82;--border: #E2E8F2;--high: #E5483D;--high-bg: #FCEBE9;--medium: #E8902B;--medium-bg:#FDF1E2;--low: #2BB3A3;--low-bg: #E4F6F3;--success: #2EA86A;--r-sm: 10px;--r: 16px;--r-lg: 22px;--shadow: 0 6px 24px rgba(11, 27, 51, .08);--shadow-lg: 0 14px 40px rgba(11, 27, 51, .14);--font: "Noto Sans TC", -apple-system, "PingFang TC", "Microsoft JhengHei", sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}.app-shell{min-height:100%;display:flex;flex-direction:column}.topbar{background:var(--navy-900);color:#fff;padding:0 24px;height:60px;display:flex;align-items:center;gap:24px;position:sticky;top:0;z-index:20}.topbar .brand{font-weight:900;font-size:18px;letter-spacing:.02em;display:flex;align-items:center;gap:8px}.topbar .brand .dot{width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent)}.topbar nav{display:flex;gap:4px;margin-left:8px}.topbar nav a{padding:8px 14px;border-radius:999px;font-size:14px;font-weight:500;color:#b9c7dc;transition:all .15s}.topbar nav a:hover{background:#ffffff14;color:#fff}.topbar nav a.active{background:var(--accent);color:#fff}.topbar .spacer{flex:1}.topbar .user{font-size:13px;color:#b9c7dc;display:flex;align-items:center;gap:12px}.topbar .user button{background:#ffffff1a;color:#fff;border:none;padding:6px 14px;border-radius:999px;font-size:13px}.topbar .user button:hover{background:#fff3}.page{flex:1;max-width:880px;width:100%;margin:0 auto;padding:32px 24px 64px}.page-wide{max-width:1100px}h1.title{font-size:28px;font-weight:900;letter-spacing:.01em}.subtitle{color:var(--text-muted);margin-top:6px;font-size:15px}h2.section{font-size:19px;font-weight:700;margin:0 0 4px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);padding:24px}.card+.card{margin-top:18px}.field{margin-bottom:16px}.field label{display:block;font-size:13px;font-weight:700;color:var(--navy-700);margin-bottom:6px}.field input,.field textarea,.field select{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:15px;background:#fff;color:var(--text);transition:border-color .15s,box-shadow .15s}.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.field .hint{font-size:12px;color:var(--text-muted);margin-top:4px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}.fieldset-title{font-size:13px;font-weight:900;color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin:4px 0 14px;display:flex;align-items:center;gap:8px}.fieldset-title:before{content:"";width:18px;height:3px;background:var(--accent);border-radius:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 26px;border-radius:var(--r-sm);border:none;font-size:15px;font-weight:700;background:var(--navy-900);color:#fff;transition:transform .12s,background .2s,box-shadow .2s}.btn:hover{background:var(--navy-800);transform:translateY(-1px);box-shadow:var(--shadow)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn--accent{background:var(--accent)}.btn--accent:hover{background:var(--navy-500)}.btn--ghost{background:transparent;color:var(--navy-700);border:1.5px solid var(--border)}.btn--ghost:hover{background:var(--bg)}.btn--block{width:100%}.badge{display:inline-flex;align-items:center;padding:3px 11px;border-radius:999px;font-size:12px;font-weight:700}.badge--high{background:var(--high-bg);color:var(--high)}.badge--medium{background:var(--medium-bg);color:var(--medium)}.badge--low{background:var(--low-bg);color:var(--low)}.badge--admin{background:var(--accent-soft);color:var(--accent)}.finding{border:1px solid var(--border);border-radius:var(--r-sm);padding:16px 18px}.finding+.finding{margin-top:12px}.finding-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}.finding-head h3{font-size:16px;font-weight:700}.finding p{color:var(--text-muted);font-size:14px}.rec{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}.rec:last-child{border-bottom:none}.rec .cat{flex-shrink:0}.rec .body .action{font-weight:700;font-size:15px}.rec .body .why{color:var(--text-muted);font-size:13px;margin-top:3px}.tcm-box{background:linear-gradient(135deg,var(--navy-900),var(--navy-700));color:#fff;border-radius:var(--r);padding:24px}.tcm-box .pattern{font-size:22px;font-weight:900;margin-bottom:4px}.tcm-box .clock{color:#9fc2f5;font-size:14px;margin-bottom:12px}.tcm-box .explain{color:#dce6f5;font-size:14px}.pill-list{display:flex;flex-direction:column;gap:8px}.pill-list .item{display:flex;gap:10px;align-items:flex-start;font-size:14px}.pill-list .item .num{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:var(--accent-soft);color:var(--accent);font-weight:700;font-size:12px;display:flex;align-items:center;justify-content:center}.session-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;border:1px solid var(--border);border-radius:var(--r);background:#fff;transition:all .15s;cursor:pointer}.session-row:hover{border-color:var(--accent);box-shadow:var(--shadow);transform:translateY(-1px)}.session-row+.session-row{margin-top:12px}.session-row .meta .date{font-weight:700;font-size:16px}.session-row .meta .preview{color:var(--text-muted);font-size:13px;margin-top:2px;max-width:560px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-wrap{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(1200px 600px at 50% -10%,var(--navy-700),var(--bg) 60%)}.auth-card{width:100%;max-width:400px;background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:36px 32px}.auth-card .logo{text-align:center;margin-bottom:24px}.auth-card .logo .name{font-size:24px;font-weight:900;color:var(--navy-900)}.auth-card .logo .tag{font-size:13px;color:var(--text-muted);margin-top:4px}.auth-toggle{display:flex;background:var(--bg);border-radius:999px;padding:4px;margin-bottom:20px}.auth-toggle button{flex:1;border:none;background:transparent;padding:8px;border-radius:999px;font-weight:700;font-size:14px;color:var(--text-muted)}.auth-toggle button.active{background:#fff;color:var(--navy-900);box-shadow:var(--shadow)}.empty{text-align:center;padding:64px 24px;color:var(--text-muted)}.empty .icon{font-size:40px;margin-bottom:12px}.error-msg{background:var(--high-bg);color:var(--high);padding:11px 14px;border-radius:var(--r-sm);font-size:14px;margin-bottom:14px}.loading-overlay{text-align:center;padding:48px}.spinner{width:36px;height:36px;border:3px solid var(--accent-soft);border-top-color:var(--accent);border-radius:50%;margin:0 auto 16px;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.muted{color:var(--text-muted)}.row-between{display:flex;align-items:center;justify-content:space-between;gap:16px}.mt-24{margin-top:24px}.mt-16{margin-top:16px}@media (max-width: 640px){.grid-2{grid-template-columns:1fr}.topbar nav a{padding:8px 10px}.page{padding:24px 16px 48px}}
