:root{--bg:#f6f7f4;--fg:#17211b;--accent:#088843;--accent-dark:#056b35;--accent-light:#e8f6ed;--border:#dfe5df;--muted:#647067;--danger:#c62828;--warning:#f9a825;--info:#1565c0;--card-bg:#fff;--surface-soft:#f0f7f2;--shadow:0 14px 34px #17211b14}*{box-sizing:border-box}html,body{background:var(--bg);color:var(--fg);margin:0;padding:0;font-family:-apple-system,Hiragino Sans,Yu Gothic,Noto Sans JP,sans-serif;line-height:1.5}a{color:inherit;text-decoration:none}h1{letter-spacing:0;margin:0;font-size:28px}h2{margin:24px 0 12px;font-size:18px}p{margin:0}.header{border-bottom:1px solid var(--border);z-index:10;background:#fff;position:sticky;top:0}.header-inner{align-items:center;gap:28px;max-width:1200px;margin:0 auto;padding:12px 24px;display:flex}.header-spacer{flex:1}.version{color:var(--muted);font-size:11px}.logo{border-radius:10px;justify-content:center;align-items:center;padding:2px;transition:background-color .15s,transform .15s;display:inline-flex}.logo:hover{background:var(--accent-light);transform:translateY(-1px)}.logo-mark{filter:drop-shadow(0 6px 12px #056b352e);width:40px;height:40px;display:block}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.nav{gap:6px;font-size:14px;display:flex}.nav a{border-radius:6px;padding:7px 10px}.nav a:hover{background:var(--accent-light);color:var(--accent-dark)}.main{max-width:1200px;margin:0 auto;padding:32px 24px}.page-head{justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:24px;display:flex}.page-title{gap:6px;display:grid}.page-title p{color:var(--muted);font-size:14px}.page-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.card,.panel{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:20px;box-shadow:0 1px #17211b08}.card{margin-bottom:16px}.panel-soft{background:var(--surface-soft);border-color:#d4eadb}.hero-band{background:linear-gradient(135deg,#0888432e 0%,#1565c014 60%,#fff0 100%),linear-gradient(#fff 0%,#f5fbf6 100%);border:1px solid #c8e3d2;border-radius:14px;grid-template-columns:minmax(0,1.4fr) minmax(280px,.8fr);align-items:center;gap:24px;margin-bottom:28px;padding:28px;display:grid;position:relative;overflow:hidden;box-shadow:0 14px 34px #08884314,inset 0 1px #0888430a}.hero-band:before{content:"";pointer-events:none;background:radial-gradient(circle,#0888432e 0%,#0000 70%);width:220px;height:220px;position:absolute;top:-40px;right:-40px}.hero-copy{z-index:1;gap:12px;display:grid;position:relative}.hero-copy h1{background:linear-gradient(135deg,#056b35 0%,#088843 60%,#1565c0 130%);color:#0000;letter-spacing:.01em;-webkit-background-clip:text;background-clip:text;font-size:30px}.hero-copy p{color:#334139;font-size:15px}.hero-actions{flex-wrap:wrap;gap:10px;margin-top:4px;display:flex}.runbook{gap:10px;display:grid}.runbook-step{z-index:1;background:#ffffffeb;border:1px solid #0888432e;border-radius:10px;grid-template-columns:32px 1fr auto;align-items:center;gap:12px;padding:12px;transition:transform .15s,box-shadow .15s;display:grid;position:relative}.runbook-step:hover{transform:translateY(-1px);box-shadow:0 6px 16px #0888431a}.step-no{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);color:#fff;border-radius:50%;place-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:inline-grid;box-shadow:0 4px 10px #0888434d}.step-title{font-weight:700}.step-note{color:var(--muted);font-size:12px}.btn{background:var(--accent);color:#fff;cursor:pointer;text-align:center;border:none;border-radius:6px;padding:9px 16px;font-family:inherit;font-size:14px;display:inline-block}.btn:hover{background:var(--accent-dark)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.secondary{color:var(--fg);border:1px solid var(--border);background:#fff}.btn.secondary:hover{background:#f4f7f5}.btn.danger{background:var(--danger)}.btn.small{padding:4px 10px;font-size:12px}table{border-collapse:collapse;background:var(--card-bg);width:100%;font-size:14px}th,td{text-align:left;border-bottom:1px solid var(--border);vertical-align:top;padding:12px}th{color:#435047;background:#f4f7f5;font-size:13px;font-weight:600}td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}.table-wrap{overflow-x:auto}.cell-main{font-weight:700}.cell-sub{color:var(--muted);margin-top:2px;font-size:12px}input,select,textarea{border:1px solid var(--border);background:#fff;border-radius:4px;width:100%;padding:8px 10px;font-family:inherit;font-size:14px}label{color:var(--muted);margin-bottom:4px;font-size:13px;display:block}.field{margin-bottom:12px}.row{flex-wrap:wrap;gap:12px;display:flex}.row>.field{flex:1;min-width:160px}form .actions{gap:8px;margin-top:16px;display:flex}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px;display:grid}.kpi{background:linear-gradient(180deg, #fff 0%, var(--surface-soft) 130%);border:1px solid var(--border);border-radius:12px;min-height:140px;padding:20px;transition:transform .18s,box-shadow .18s,border-color .18s;position:relative;overflow:hidden}.kpi:after{content:"";pointer-events:none;background:radial-gradient(circle at 100% 0,#08884326 0%,#0000 70%);width:100px;height:100px;position:absolute;top:0;right:0}.kpi:hover{border-color:#08884340;transform:translateY(-2px);box-shadow:0 10px 24px #0888431a}.kpi-icon{filter:drop-shadow(0 2px 4px #00000014);margin-bottom:10px;font-size:22px;line-height:1;display:inline-block}.kpi-label{color:var(--muted);font-size:12px}.kpi-value{font-variant-numeric:tabular-nums;background:linear-gradient(135deg, var(--accent-dark) 0%, var(--accent) 100%);color:#0000;-webkit-background-clip:text;background-clip:text;margin-top:6px;font-size:28px;font-weight:700}.kpi-caption{color:var(--muted);margin-top:8px;font-size:12px}.kpi.alert{background:linear-gradient(#fff 0%,#fff5f5 130%);border-color:#ffd5d5}.kpi.alert:after{background:radial-gradient(circle at 100% 0,#c6282826 0%,#0000 70%)}.kpi.alert .kpi-value{background:linear-gradient(135deg, #b71c1c 0%, var(--danger) 100%);color:#0000;-webkit-background-clip:text;background-clip:text}.panel-icon{vertical-align:-2px;filter:drop-shadow(0 2px 3px #00000014);margin-right:6px;font-size:18px;display:inline-block}.user-chip{background:linear-gradient(135deg, var(--accent-light) 0%, #fff 100%);border:1px solid #cce5d4;border-radius:999px;align-items:center;gap:10px;padding:6px 10px;display:inline-flex;box-shadow:0 2px 6px #0888430f}.user-icon{font-size:16px}.user-meta{line-height:1.1;display:grid}.user-name{color:var(--accent-dark);font-size:13px;font-weight:700}.user-role{color:var(--muted);font-size:10px}.user-role.role-admin{color:#b71c1c}.user-role.role-staff{color:var(--accent-dark)}.user-role.role-viewer{color:var(--muted)}.logout-btn{border-radius:999px!important;padding:4px 12px!important;font-size:11px!important}.login-shell{background:radial-gradient(circle at 20% 30%,#0888431f 0%,#0000 60%),radial-gradient(circle at 80% 70%,#1565c014 0%,#0000 55%);place-items:center;min-height:calc(100vh - 100px);padding:32px 16px;display:grid}.login-card{background:linear-gradient(#fff 0%,#f8fbf9 100%);border:1px solid #d0e4d6;border-radius:16px;width:100%;max-width:420px;padding:32px;box-shadow:0 24px 60px #0888431f}.login-card h1{background:linear-gradient(135deg,#056b35 0%,#088843 60%,#1565c0 130%);color:#0000;-webkit-background-clip:text;background-clip:text;margin:0 0 6px;font-size:22px}.login-brand{border-bottom:1px solid #e0e9e3;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:16px;display:flex}.login-logo{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);color:#fff;border-radius:12px;place-items:center;width:44px;height:44px;font-size:22px;display:inline-grid;box-shadow:0 6px 14px #0888434d}.login-title{color:var(--fg);font-size:16px;font-weight:700}.login-subtitle{color:var(--muted);font-size:11px}.login-form{margin-top:16px}.login-btn{width:100%;margin-top:8px;box-shadow:0 6px 16px #08884340;background:linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%)!important;padding:12px!important;font-size:14px!important}.login-footer{text-align:center;border-top:1px solid #e0e9e3;margin-top:20px;padding-top:16px;font-size:12px}.manual-list{border:1px solid var(--border);background:#fff;border-radius:8px;max-height:320px;overflow-y:auto}.manual-row{text-align:left;border:none;border-bottom:1px solid var(--border);cursor:pointer;background:#fff;width:100%;padding:10px 12px;font-family:inherit;font-size:13px;transition:background .12s;display:block}.manual-row:last-child{border-bottom:none}.manual-row:hover{background:var(--accent-light)}.manual-row.is-active{background:linear-gradient(90deg, var(--accent-light), #fff);border-left:3px solid var(--accent);padding-left:9px}.manual-row-main{justify-content:space-between;align-items:center;font-weight:600;display:flex}.manual-row-main strong{color:var(--accent-dark);font-variant-numeric:tabular-nums}.manual-row-sub{color:var(--muted);margin-top:3px;font-size:11px}.status{white-space:nowrap;border-radius:999px;padding:3px 9px;font-size:12px;font-weight:700;display:inline-block}.status-unpaid{color:#c62828;background:#ffebee}.status-partial{color:#f57c00;background:#fff8e1}.status-paid{color:#2e7d32;background:#e8f5e9}.status-cancelled{color:#757575;background:#f5f5f5}.status-unmatched{color:#c62828;background:#ffebee}.status-matched{color:#2e7d32;background:#e8f5e9}.source-manual{color:#435047;background:#eef2f6}.source-csv_import{color:var(--info);background:#e3f2fd}.alert{border-radius:6px;margin-bottom:16px;padding:12px;font-size:14px}.alert-info{color:var(--info);background:#e3f2fd}.alert-warn{color:#e65100;background:#fff3e0}.alert-error{color:var(--danger);background:#ffebee}.toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.toolbar-spacer{flex:1}.import-panel{gap:14px;margin-bottom:16px;display:grid}.import-controls{grid-template-columns:minmax(220px,1fr) auto auto;align-items:center;gap:8px;display:grid}.muted{color:var(--muted);font-size:12px}.section-grid{grid-template-columns:minmax(0,1fr) 360px;align-items:start;gap:16px;display:grid}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:16px;display:grid}.mini-stat{border:1px solid var(--border);background:#fff;border-radius:8px;padding:14px}.mini-stat strong{font-variant-numeric:tabular-nums;margin-top:4px;font-size:20px;display:block}.mini-stat.is-danger strong{color:var(--danger)}.work-card{gap:12px;display:grid}.work-card h2{margin:0}.work-card p{color:var(--muted);font-size:13px}.check-list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.check-list li{grid-template-columns:22px 1fr;align-items:start;gap:8px;display:grid}.check{color:var(--accent);font-weight:800}.confidence{color:var(--muted);align-items:center;gap:6px;font-size:12px;display:inline-flex}.confidence-bar{background:#e7ece8;border-radius:999px;width:58px;height:8px;overflow:hidden}.confidence-bar span{background:var(--accent);height:100%;display:block}.empty{text-align:center;color:var(--muted);padding:40px}@media (max-width:900px){.hero-band,.section-grid{grid-template-columns:1fr}.page-head{flex-direction:column;align-items:flex-start}.import-controls{grid-template-columns:1fr}}@media (max-width:640px){.header-inner{flex-wrap:wrap;gap:12px}.nav{gap:4px;font-size:13px}.main{padding:16px}.hero-band{padding:18px}.hero-copy h1{font-size:24px}.runbook-step{grid-template-columns:28px 1fr}.runbook-step .btn{grid-column:1/-1}}
