:root{--bg: #0f1115;--surface: #171a21;--surface-2: #1f232c;--border: #2a2f3a;--text: #e7e9ee;--text-dim: #9aa3b2;--accent: #6366f1;--danger: #f87171;--action: #fbbf24;--client: #38bdf8;--schedule: #c084fc;--ok: #34d399;--radius: 12px;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Noto Sans JP,system-ui,sans-serif;font-size:14px;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;min-height:100%}.topbar{display:flex;align-items:center;gap:16px;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:10;padding-top:max(10px,env(safe-area-inset-top))}.brand{display:flex;align-items:center;gap:8px;font-weight:700}.brand-sub{color:var(--text-dim);font-weight:500;font-size:12px}.topnav{display:flex;gap:4px;margin-left:8px}.topnav button,.viewer-switch select{background:transparent;color:var(--text-dim);border:1px solid transparent;padding:6px 12px;border-radius:8px;cursor:pointer;font-size:14px}.topnav button:hover{color:var(--text)}.topnav button.active{color:var(--text);background:var(--surface-2);border-color:var(--border)}.viewer-switch{margin-left:auto;display:flex;align-items:center;gap:6px;color:var(--text-dim);font-size:12px}.viewer-switch select{background:var(--surface-2);border:1px solid var(--border);color:var(--text)}.content{padding:16px;max-width:1180px;width:100%;margin:0 auto}.stack{display:flex;flex-direction:column;gap:16px}.section-title{font-size:13px;text-transform:none;color:var(--text-dim);margin:0 0 10px;font-weight:600}.sub-head{font-size:12px;color:var(--text-dim);margin:14px 0 6px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px}.kpi-warn{border-color:color-mix(in srgb,var(--action) 50%,var(--border))}.kpi-value{font-size:22px;font-weight:700}.kpi-label{color:var(--text-dim);font-size:12px;margin-top:2px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.banner{display:flex;flex-direction:column;gap:2px}.list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.list-row{display:flex;align-items:center;gap:10px;padding:10px 4px;border-bottom:1px solid var(--border)}.list-row:last-child{border-bottom:none}.list-col{display:flex;flex-direction:column;gap:6px;padding:10px 4px;border-bottom:1px solid var(--border)}.clickable{cursor:pointer;border-radius:8px}.clickable:hover{background:var(--surface-2)}.grow{flex:1;min-width:0}.row-title{font-weight:600}.row-sub{color:var(--text-dim);font-size:12px}.chev{color:var(--text-dim);font-size:18px}.ver{color:var(--text-dim);font-size:11px;font-weight:500}.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap;border:1px solid var(--border)}.chip-glyph{font-size:12px}.att-danger{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 45%,transparent);background:color-mix(in srgb,var(--danger) 12%,transparent)}.att-action{color:var(--action);border-color:color-mix(in srgb,var(--action) 45%,transparent);background:color-mix(in srgb,var(--action) 12%,transparent)}.att-client{color:var(--client);border-color:color-mix(in srgb,var(--client) 45%,transparent);background:color-mix(in srgb,var(--client) 12%,transparent)}.att-schedule{color:var(--schedule)}.att-ok{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 40%,transparent);background:color-mix(in srgb,var(--ok) 10%,transparent)}.status-badge{font-size:11px;color:var(--text-dim);background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:2px 7px;white-space:nowrap}.st-fixed{color:var(--ok)}.st-ownerReview,.st-submitted{color:var(--action)}.st-clientReview{color:var(--client)}.progress{position:relative;height:7px;background:var(--surface-2);border-radius:999px;overflow:hidden}.progress-fill{position:absolute;inset:0 auto 0 0;background:var(--accent);border-radius:999px}.progress-expected{position:absolute;top:-2px;bottom:-2px;width:2px;background:var(--text-dim)}.projects-layout{display:grid;grid-template-columns:240px 1fr;gap:16px;align-items:start}.project-list{display:flex;flex-direction:column;gap:4px}.project-list-item{display:flex;align-items:center;gap:8px;text-align:left;background:var(--surface);border:1px solid var(--border);color:var(--text);padding:10px;border-radius:10px;cursor:pointer}.project-list-item.active{border-color:var(--accent)}.detail-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px}.detail-title{margin:0;font-size:18px}.detail-progress{width:180px}.big-pct{font-size:20px;font-weight:700}.timeline{position:relative}.timeline-row{display:grid;grid-template-columns:220px 1fr 210px;align-items:center;gap:8px;padding:5px 0}.timeline-label{display:flex;align-items:center;gap:6px;min-width:0}.t-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.t-assignee{color:var(--text-dim);font-size:11px;white-space:nowrap}.gate-dot{color:var(--action)}.timeline-track{position:relative;height:22px;background:var(--surface-2);border-radius:6px}.bar{position:absolute;top:2px;bottom:2px;border-radius:5px;background:var(--surface);border:1px solid var(--border);overflow:hidden;display:flex;align-items:center}.bar-fill{position:absolute;left:0;top:0;bottom:0;background:color-mix(in srgb,var(--accent) 55%,transparent)}.bar-text{position:relative;font-size:10px;color:var(--text-dim);padding:0 5px;white-space:nowrap}.bar-gate{border-style:dashed}.att-bar-danger{border-color:var(--danger)}.att-bar-action{border-color:var(--action)}.att-bar-clientWait{border-color:var(--client)}.timeline-meta{display:flex;align-items:center;gap:6px;justify-content:flex-end;flex-wrap:wrap}.timeline-today{position:absolute;top:0;bottom:22px;width:2px;background:var(--danger);z-index:2}.timeline-today-label{position:absolute;top:-16px;left:-12px;font-size:10px;color:var(--danger)}.legend{display:flex;gap:16px;flex-wrap:wrap;color:var(--text-dim);font-size:11px;margin-top:10px}.btn,.btn-sm{background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer}.btn{padding:8px 14px;font-size:14px}.btn-sm{padding:4px 10px;font-size:12px}.report-form{display:flex;flex-direction:column;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:12px;margin-top:4px}.report-form label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-dim)}.report-form input,.report-form select,.report-form textarea{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:6px 8px;font:inherit}.inbox-bar{flex-direction:row;align-items:center;gap:12px}.mail-subj{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.mail-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;align-items:center}.mail-body{white-space:pre-wrap;line-height:1.6;margin:0}.reply-area{width:100%;background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:10px;font:inherit;margin-bottom:10px;resize:vertical}.sent-box{margin-top:12px;padding:10px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px}.field{display:flex;flex-direction:column;gap:4px;margin:8px 0}.field label{font-size:12px;color:var(--text-dim)}.field input{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 10px;font:inherit}.setup-steps{color:var(--text-dim);font-size:13px;line-height:1.7;margin:8px 0 0;padding-left:20px}.setup-steps code{background:var(--surface-2);padding:1px 5px;border-radius:4px;color:var(--text)}a.btn{text-decoration:none}@media (max-width: 720px){.two-col,.projects-layout{grid-template-columns:1fr}.project-list{flex-direction:row;overflow-x:auto}.project-list-item{white-space:nowrap}.timeline-row{grid-template-columns:130px 1fr}.timeline-meta{display:none}.detail-head{flex-direction:column;align-items:stretch}.detail-progress{width:100%}}.revision-round{margin-top:10px;border-top:1px solid var(--border);padding-top:8px}.revision-item .rev-check{width:22px;height:22px;flex:none;border:1px solid var(--border);border-radius:6px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;color:var(--ok, #4ade80);background:var(--surface-2)}.rev-check-done{border-color:var(--ok, #4ade80)}.rev-done-text{text-decoration:line-through;color:var(--text-dim)}.btn-ghost{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.inline-input{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:5px 8px;font:inherit;flex:1;min-width:200px}.sub-head{font-size:13px;color:var(--text-dim);margin:14px 0 6px}.xgantt{position:relative}.xgantt-axis{position:relative;height:18px;margin-left:180px;margin-right:40px}.xgantt-month{position:absolute;font-size:10px;color:var(--text-dim);border-left:1px solid var(--border);padding-left:4px}.xgantt-body{position:relative}.xgantt-row{display:grid;grid-template-columns:180px 1fr 40px;align-items:center;gap:0;padding:6px 0}.xgantt-label{background:none;border:none;color:var(--text);text-align:left;cursor:pointer;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:8px}.xgantt-label:hover{color:var(--accent)}.xgantt-track{position:relative;height:20px;background:var(--surface-2);border-radius:5px}.xgantt-bar{position:absolute;top:3px;bottom:3px;border-radius:3px;background:color-mix(in srgb,var(--accent) 45%,transparent);border:1px solid var(--border)}.xgantt-done{opacity:.35}.xgantt-gate{position:absolute;top:0;transform:translate(-50%);font-size:13px;color:var(--action);z-index:1}.att-g-danger{color:var(--danger)}.xgantt-today{position:absolute;top:0;bottom:0;width:2px;background:var(--danger);margin-left:180px;z-index:2;opacity:.8}.xgantt-att{display:flex;justify-content:flex-end}.heatmap{display:flex;flex-direction:column;gap:3px;overflow-x:auto}.heatmap-row{display:flex;gap:3px;align-items:center}.heatmap-name{width:130px;flex:none;font-size:12px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.heatmap-week{width:44px;flex:none;font-size:10px;color:var(--text-dim);text-align:center}.heatmap-cell{width:44px;height:26px;flex:none;border-radius:5px;background:var(--surface-2);display:inline-flex;align-items:center;justify-content:center;font-size:12px}.heat-1{background:color-mix(in srgb,var(--accent) 25%,var(--surface-2))}.heat-2{background:color-mix(in srgb,var(--accent) 50%,var(--surface-2))}.heat-3{background:color-mix(in srgb,#f59e0b 60%,var(--surface-2))}.heat-4{background:color-mix(in srgb,#ef4444 65%,var(--surface-2));color:#fff}.template-row{flex-wrap:wrap}.template-row .inline-input{min-width:140px}.template-row select{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:4px 6px;font-size:12px}.lang-toggle{display:flex;gap:4px}.lang-toggle button{background:var(--surface-2);border:1px solid var(--border);color:var(--text-dim);border-radius:8px;padding:4px 10px;font-size:12px;cursor:pointer}.lang-toggle button.active{color:var(--text);border-color:var(--accent)}@media (max-width: 720px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.xgantt-row{grid-template-columns:110px 1fr 30px}.xgantt-axis,.xgantt-today{margin-left:110px}.heatmap-name{width:90px}.mail-actions{gap:6px}.topbar{flex-wrap:wrap;gap:6px}.decision-card .mail-actions .btn-sm{flex:1 1 auto}}.google-login-btn{display:flex;align-items:center;justify-content:center;gap:10px;background:#fff;color:#1f1f1f;text-decoration:none;font-weight:600}.login-divider{display:flex;align-items:center;gap:10px;color:var(--text-dim);font-size:11px;margin:4px 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}
