:root{
  --bg:#f4f6fb; --panel:#ffffff; --ink:#1f2733; --muted:#6b7686; --line:#e6eaf2;
  --blue:#1f4e96; --blue-2:#2f6fd0; --blue-soft:#eaf1fb;
  --green:#2bb46a; --green-soft:#e3f6ec;
  --orange:#ff6a3d; --orange-soft:#fff1ec;
  --yellow:#e0a90a; --yellow-soft:#fdf4dc;
  --red:#d8453c; --red-soft:#fdecec;
  --gray-soft:#eef1f5;
  --shadow:0 6px 24px rgba(31,78,150,.08);
  --radius:16px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:"Noto Sans JP",system-ui,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;}
.hidden{display:none !important}
.muted{color:var(--muted)} .small{font-size:12px}
code{background:#f0f3f8;padding:2px 6px;border-radius:6px;font-size:12px}
hr{border:none;border-top:1px solid var(--line);margin:18px 0}
.flex-1{flex:1}
.link{color:var(--blue);text-decoration:underline;font-size:13px}
.mvp-note{background:var(--yellow-soft);border-left:4px solid var(--yellow);padding:8px 12px;border-radius:8px;margin:0 0 14px;color:#8a6500;font-weight:700}

.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(1200px 600px at 50% -10%, #e8effb 0%, var(--bg) 60%);padding:24px;}
.auth-card{width:100%;max-width:380px;background:var(--panel);border-radius:20px;padding:32px 28px;box-shadow:var(--shadow);}
.auth-logo{font-size:24px;font-weight:900;color:var(--blue);margin:0;letter-spacing:.5px}
.auth-logo span{color:var(--blue-2);font-weight:700}
.auth-sub{color:var(--muted);margin:4px 0 22px;font-size:13px}
.auth-tabs{display:flex;background:var(--blue-soft);border-radius:12px;padding:4px;margin-bottom:18px}
.auth-tab{flex:1;border:none;background:transparent;padding:9px;border-radius:9px;font:inherit;font-weight:700;color:var(--muted);cursor:pointer}
.auth-tab.active{background:#fff;color:var(--blue);box-shadow:0 2px 8px rgba(31,78,150,.12)}
.auth-error{color:var(--red);font-size:13px;min-height:18px;margin:6px 0 0}

.field{display:block;margin-bottom:14px}
.field span{display:block;font-size:13px;font-weight:700;color:var(--muted);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:11px;padding:11px 13px;font:inherit;background:#fbfcfe;color:var(--ink);}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue-2);background:#fff}
.field textarea{resize:vertical;min-height:64px}

.btn-primary{border:none;border-radius:11px;background:var(--blue);color:#fff;font:inherit;font-weight:700;padding:11px 18px;cursor:pointer;transition:filter .15s;white-space:nowrap}
.btn-primary:hover{filter:brightness(1.08)}
.btn-primary:disabled{opacity:.4;cursor:not-allowed}
.btn-primary.full{width:100%;margin-top:6px;padding:12px}
.btn-primary.small{padding:6px 12px;font-size:13px}
.btn-ghost{border:1.5px solid var(--line);background:#fff;color:var(--muted);border-radius:11px;padding:11px 18px;font:inherit;font-weight:700;cursor:pointer;white-space:nowrap}
.btn-ghost:hover{border-color:var(--blue-2);color:var(--blue)}
.btn-ghost.small{padding:7px 12px;font-size:13px}
.btn-ai{border:none;border-radius:11px;background:linear-gradient(135deg,#7c5cff,#5a3fd0);color:#fff;font:inherit;font-weight:700;padding:11px 18px;cursor:pointer;transition:filter .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}
.btn-ai::before{content:"✦";font-size:13px}
.btn-ai:hover{filter:brightness(1.1)}
.btn-ai:disabled{opacity:.4;cursor:not-allowed}
.file-label{display:inline-block;cursor:pointer}

/* AI読取モーダル */
.ai-preview-box{margin:10px 0;text-align:center;background:var(--gray-soft);border-radius:11px;padding:10px;max-height:260px;overflow:hidden}
.ai-preview-box img{max-width:100%;max-height:240px;border-radius:8px}
.ai-status{margin:10px 0;padding:12px 14px;border-radius:11px;background:var(--blue-soft);color:var(--blue);font-size:13px;font-weight:700;display:flex;align-items:center;gap:10px}
.ai-status .spinner{width:16px;height:16px;border:2px solid rgba(31,78,150,.25);border-top-color:var(--blue);border-radius:50%;animation:ai-spin .7s linear infinite;flex-shrink:0}
@keyframes ai-spin{to{transform:rotate(360deg)}}
.ai-result{margin:10px 0}
.ai-conf{display:inline-block;padding:2px 10px;border-radius:999px;font-size:11px;font-weight:700;margin-bottom:8px}
.ai-conf.high{background:var(--green-soft);color:var(--green)}
.ai-conf.medium{background:var(--yellow-soft);color:var(--yellow)}
.ai-conf.low{background:var(--red-soft);color:var(--red)}
.ai-items-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:6px}
.ai-items-table th,.ai-items-table td{padding:5px 6px;border-bottom:1px solid var(--line)}
.ai-items-table th{font-size:11px;color:var(--muted);text-align:left}
.ai-items-table .num{text-align:right;font-variant-numeric:tabular-nums}

.modal-wrap{position:fixed;inset:0;background:rgba(22,33,54,.42);display:flex;align-items:center;justify-content:center;padding:20px;z-index:50}
.modal-card{width:100%;max-width:460px;background:#fff;border-radius:18px;padding:26px 24px;box-shadow:0 20px 60px rgba(0,0,0,.25);max-height:90vh;overflow:auto}
.modal-card h2{margin:0 0 12px;font-size:18px}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}

.app-shell{display:flex;min-height:100vh}
.sidebar{width:252px;flex-shrink:0;background:#fff;border-right:1px solid var(--line);padding:20px 16px;display:flex;flex-direction:column;gap:14px;position:sticky;top:0;height:100vh;}
.brand{font-size:20px;font-weight:900;color:var(--blue);letter-spacing:.4px}
.brand span{color:var(--blue-2);font-weight:700}
.brand-logo{display:block;width:100%;max-width:200px;height:auto}
.auth-logo-img{display:block;width:100%;max-width:280px;height:auto;margin:0 auto}
.clock-card{background:var(--blue-soft);border-radius:14px;padding:12px 14px}
.clock-time{font-size:22px;font-weight:900;color:var(--blue);font-variant-numeric:tabular-nums}
.clock-date{font-size:12px;color:var(--muted);margin-top:2px}

.nav{display:flex;flex-direction:column;gap:1px;flex:1;overflow:auto;margin:0 -4px;padding:0 4px}
.nav-item{display:flex;align-items:center;gap:10px;text-align:left;border:none;background:transparent;font:inherit;font-weight:600;color:#3a4453;padding:9px 12px;border-radius:10px;cursor:pointer;transition:background .12s,color .12s;font-size:13.5px;position:relative}
.nav-item:hover{background:#eef2fb}
.nav-item.active{background:var(--blue);color:#fff;font-weight:700}
.nav-item.active .nav-ico svg{color:#fff}
.nav-ico{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0;color:#8a94a6}
.nav-ico svg{width:18px;height:18px}
.nav-item:hover .nav-ico{color:var(--blue-2)}
.nav-label{flex:1;min-width:0}
/* 上位（トップレベル）の項目は少し強調 */
.nav-top{font-weight:700;color:#26303f}
/* グループ見出し（クリックで開閉）— 項目と同じ見た目で統一 */
.nav-group-toggle{display:flex;align-items:center;gap:10px;width:100%;text-align:left;border:none;background:transparent;font:inherit;font-weight:700;color:#26303f;padding:9px 12px;border-radius:10px;cursor:pointer;font-size:13.5px;margin-top:6px;transition:background .12s,color .12s}
.nav-group-toggle:hover{background:#eef2fb}
.nav-group-toggle:hover .nav-ico{color:var(--blue-2)}
.nav-chevron{font-size:11px;transition:transform .2s;color:#aab2bf;margin-left:auto}
.nav-group-toggle.collapsed .nav-chevron{transform:rotate(-90deg)}
.nav-group-toggle.collapsed{color:#3a4453}
/* グループ内の子項目：インデント＋ガイド線 */
.nav-group{display:flex;flex-direction:column;gap:1px;margin:2px 0 2px 17px;padding-left:8px;border-left:2px solid var(--line)}
.nav-group.collapsed{display:none}
.nav-group .nav-item{font-size:13px;font-weight:500;padding:8px 10px;color:#566173}
.nav-group .nav-item.active{color:#fff;font-weight:700}
.nav-divider{height:1px;background:var(--line);margin:10px 6px}
.logout{border:1.5px solid var(--line);background:#fff;color:var(--muted);border-radius:11px;padding:10px;font:inherit;font-weight:700;cursor:pointer}
.logout:hover{border-color:var(--red);color:var(--red)}

.main{flex:1;min-width:0;padding:22px 28px 60px}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px;flex-wrap:wrap}
.page-title{font-size:15px;color:var(--muted);font-weight:700}
.topbar-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.topbar-badge{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:7px 12px;font-size:12.5px;font-weight:700;color:#566173;box-shadow:var(--shadow)}
.topbar-badge svg{width:15px;height:15px;color:var(--blue-2)}
.topbar-badge.plan{background:var(--blue-soft);border-color:transparent;color:var(--blue)}
.company-menu-wrap{position:relative}
.company-chip{background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 16px;font-weight:700;font-size:13px;box-shadow:var(--shadow)}
.company-chip-btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);font:inherit;cursor:pointer;color:#26303f;transition:background .12s}
.company-chip-btn svg{width:16px;height:16px;color:var(--blue)}
.company-chip-btn:hover{background:#f3f6fc}
.company-chip-caret{font-size:10px;color:var(--muted)}
.company-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:290px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 12px 36px rgba(0,0,0,.16);z-index:60;overflow:hidden}
.cd-section{padding:14px 16px}
.cd-company-name{font-size:15px;font-weight:900;color:#26303f;margin-bottom:4px}
.cd-row{font-size:12.5px;color:#566173;margin-bottom:6px}
.cd-email{word-break:break-all}
.cd-head{font-size:11px;font-weight:800;color:#aab2bf;letter-spacing:.4px;margin-bottom:6px}
.cd-muted{font-size:12.5px;color:var(--muted);margin-bottom:8px}
.cd-link{display:block;width:100%;text-align:left;border:none;background:transparent;font:inherit;font-size:13px;font-weight:700;color:var(--blue);padding:6px 0;cursor:pointer}
.cd-link:hover{text-decoration:underline}
.cd-divider{height:1px;background:var(--line)}

.view-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}
.view-head h2{margin:0;font-size:22px;font-weight:900}
.head-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.search-input,.month-input{border:1.5px solid var(--line);border-radius:11px;padding:9px 12px;font:inherit;background:#fff;min-width:160px}

.kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:18px}
.kpi-row-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1100px){.kpi-row-4{grid-template-columns:repeat(2,1fr)}}
.kpi-card{border-radius:var(--radius);padding:20px;color:#fff;box-shadow:var(--shadow);min-height:120px}
.grad-orange{background:linear-gradient(135deg,#ff9a4d,#ff6a3d)}
.grad-red{background:linear-gradient(135deg,#ff6a6a,#ef3e6e)}
.grad-teal{background:linear-gradient(135deg,#2bb9a3,#1f8fb0)}
.grad-blue{background:linear-gradient(135deg,#4a90d9,#2f6fd0)}
.kpi-label{font-size:13px;font-weight:700;opacity:.95}
.kpi-value{font-size:30px;font-weight:900;margin:8px 0 6px;font-variant-numeric:tabular-nums}
.kpi-sub{font-size:12px;opacity:.95;background:rgba(255,255,255,.18);display:inline-block;padding:3px 10px;border-radius:999px}

.grid-2{display:grid;grid-template-columns:1.6fr 1fr;gap:16px}

.panel{background:var(--panel);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px}
.panel.narrow{max-width:560px}
.panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.panel-head h3{margin:0;font-size:15px}
.chart-box{height:300px}

.data-table{width:100%;border-collapse:collapse;font-size:14px}
.data-table th{text-align:left;color:var(--muted);font-weight:700;font-size:12px;border-bottom:2px solid var(--line);padding:10px 8px}
.data-table td{border-bottom:1px solid var(--line);padding:11px 8px;vertical-align:middle}
.data-table .num{text-align:right;font-variant-numeric:tabular-nums}
.data-table .act{text-align:right;white-space:nowrap}
.data-table .empty{text-align:center;color:var(--muted);padding:26px}
.row-btn{border:none;background:#f3f6fc;color:var(--blue);border-radius:8px;padding:6px 10px;font:inherit;font-size:12px;font-weight:700;cursor:pointer;margin-left:6px}
.row-btn.del{background:var(--red-soft);color:var(--red)}
.row-btn.pdf{background:var(--green-soft);color:var(--green)}
.row-btn.pay{background:var(--orange-soft);color:var(--orange)}

.ar-summary{display:flex;flex-direction:column;gap:6px;padding:8px 0 14px;border-bottom:1px solid var(--line);margin-bottom:10px}
.ar-line{display:flex;justify-content:space-between;font-size:14px}
.ar-line strong{font-variant-numeric:tabular-nums}
.ar-line.warn strong{color:var(--red)}
.ar-list{max-height:200px;overflow:auto;font-size:13px}
.ar-list .ar-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px dashed var(--line)}
.ar-list .ar-row:last-child{border-bottom:none}
.ar-list .ar-row .due-over{color:var(--red);font-weight:700}

.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700}
.badge.draft{background:var(--gray-soft);color:#65707f}
.badge.issued{background:var(--blue-soft);color:var(--blue)}
.badge.partial{background:var(--yellow-soft);color:var(--yellow)}
.badge.paid{background:var(--green-soft);color:var(--green)}
.badge.overdue{background:var(--red-soft);color:var(--red)}
.tag{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700;background:var(--gray-soft);color:#65707f}
.tag.customer{background:var(--blue-soft);color:var(--blue)}
.tag.vendor{background:var(--orange-soft);color:var(--orange)}
.tag.both{background:var(--green-soft);color:var(--green)}

.form-row{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-start}
.form-row > .field{flex:1 1 200px;min-width:0;margin-bottom:14px}
.form-row > .field.flex-1{flex:2 1 240px}
.sub-h{font-size:14px;margin:16px 0 8px;color:var(--muted)}
.items-table{width:100%;border-collapse:collapse;font-size:14px}
.items-table th{text-align:left;color:var(--muted);font-size:12px;border-bottom:2px solid var(--line);padding:8px}
.items-table td{padding:6px 4px;border-bottom:1px solid var(--line)}
.items-table input{width:100%;border:1.5px solid transparent;border-radius:8px;padding:8px;font:inherit;background:#fbfcfe}
.items-table input:focus{outline:none;border-color:var(--blue-2);background:#fff}
.items-table .num input{text-align:right}
.items-table .w-num{width:90px}
.items-table .w-amount{width:120px}
.items-table .w-act{width:40px;text-align:center}
.del-row-btn{background:transparent;border:none;color:var(--red);cursor:pointer;font-size:16px;padding:4px 8px}
.totals{display:flex;flex-direction:column;align-items:flex-end;gap:6px;margin-top:16px;padding:12px 16px;background:var(--blue-soft);border-radius:12px}
.total-line{display:flex;justify-content:space-between;gap:24px;min-width:300px;font-size:14px}
.total-line.grand{font-size:18px;font-weight:900;color:var(--blue);border-top:1px solid #d3def0;padding-top:8px;margin-top:4px}
.total-line select{border:1px solid var(--line);border-radius:6px;padding:2px 6px;font:inherit;font-size:12px;margin-left:4px;background:#fff}

.pn-po-list{max-height:280px;overflow:auto;border:1px solid var(--line);border-radius:11px;padding:6px}
.pn-po-row{display:flex;align-items:center;gap:10px;padding:8px;border-bottom:1px dashed var(--line);font-size:14px}
.pn-po-row:last-child{border-bottom:none}
.pn-po-row input[type=checkbox]{width:18px;height:18px}
.pn-po-row .grow{flex:1}
.pn-po-row .amt{font-variant-numeric:tabular-nums;font-weight:700;color:var(--blue)}

.logo-uploader{display:flex;gap:14px;align-items:center}
.logo-preview-wrap{width:140px;height:80px;border:1.5px dashed var(--line);border-radius:11px;display:flex;align-items:center;justify-content:center;background:#fbfcfe;overflow:hidden;position:relative}
.logo-preview-wrap img{max-width:100%;max-height:100%;display:none}
.logo-preview-wrap img[src]:not([src=""]){display:block}
.logo-preview-wrap img[src]:not([src=""]) + #set-logo-empty{display:none}
.logo-uploader-btns{display:flex;flex-direction:column;gap:6px}

.csv-preview{margin:10px 0;max-height:240px;overflow:auto;border:1px solid var(--line);border-radius:11px}
.csv-preview table{width:100%;border-collapse:collapse;font-size:12px}
.csv-preview th{background:var(--gray-soft);padding:7px 10px;text-align:left;font-weight:700;color:var(--muted);position:sticky;top:0}
.csv-preview td{padding:6px 10px;border-bottom:1px solid var(--line)}
.csv-summary{font-size:13px;padding:8px 12px;background:var(--blue-soft);border-radius:8px;margin:6px 0;color:var(--blue);font-weight:700}

/* 会計帳簿 */
.bs-section h3,.cf-section h3,.pl-section h3{font-size:14px;margin:12px 0 6px;color:var(--blue)}
.bs-line,.cf-line,.pl-line{display:flex;justify-content:space-between;padding:8px 4px;border-bottom:1px solid var(--line);font-size:14px}
.bs-line .v,.cf-line .v,.pl-line .v{font-variant-numeric:tabular-nums;font-weight:700}
.bs-line.total,.cf-line.total,.pl-line.total{border-top:2px solid var(--blue);border-bottom:none;background:var(--blue-soft);color:var(--blue);font-weight:900;border-radius:0 0 8px 8px;margin-top:4px;padding:10px 12px}
.pl-sub{padding-left:14px;color:var(--muted)}

/* ===== LEVEL 1: 経営レポート関連 ===== */
.report-section{margin:18px 0 24px}
.report-h{font-size:16px;color:var(--blue);margin:0 0 12px;padding-bottom:6px;border-bottom:2px solid var(--blue-soft)}

/* 経営ハイライト（自動コメント） */
.mr-highlight{background:linear-gradient(135deg,#eef4ff,#f7faff);border:1px solid var(--blue-soft);border-radius:var(--radius);padding:18px 22px;margin-bottom:20px;box-shadow:var(--shadow)}
.mr-highlight h3{margin:0 0 10px;font-size:15px;color:var(--blue);display:flex;align-items:center;gap:8px}
.mr-highlight h3::before{content:"";display:inline-block;width:6px;height:18px;background:var(--blue);border-radius:3px}
.mr-highlight ul{margin:0;padding-left:4px;list-style:none}
.mr-highlight li{font-size:14px;line-height:1.7;padding:3px 0;padding-left:22px;position:relative}
.mr-highlight li::before{content:"";position:absolute;left:4px;top:11px;width:8px;height:8px;border-radius:50%;background:var(--blue-2)}
.mr-highlight li.good::before{background:var(--green)}
.mr-highlight li.warn::before{background:var(--yellow)}
.mr-highlight li.bad::before{background:var(--red)}
.mr-highlight li strong{font-variant-numeric:tabular-nums}

/* BSボックス図 */
.bs-box{display:flex;gap:10px;min-height:240px;align-items:stretch;padding:8px 0}
.bs-box-col{flex:1;display:flex;flex-direction:column;gap:6px}
.bs-box-col .col-title{text-align:center;font-size:12px;font-weight:700;color:var(--muted);margin-bottom:4px}
.bs-box-item{border-radius:10px;padding:10px 12px;color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:50px;box-shadow:0 2px 8px rgba(0,0,0,.08)}
.bs-box-item .bi-label{font-size:12px;font-weight:700;opacity:.95}
.bs-box-item .bi-val{font-size:15px;font-weight:900;font-variant-numeric:tabular-nums;margin-top:2px}
.bs-box-item.asset-cash{background:linear-gradient(135deg,#2bb9a3,#1f8fb0)}
.bs-box-item.asset-ar{background:linear-gradient(135deg,#4a90d9,#2f6fd0)}
.bs-box-item.liab-ap{background:linear-gradient(135deg,#ff9a4d,#ff6a3d)}
.bs-box-item.equity{background:linear-gradient(135deg,#7c5cff,#5a3fd0)}

.acct-note{background:var(--gray-soft);border-radius:8px;padding:10px 14px;color:var(--muted);line-height:1.5;margin-top:8px}

/* 企業ドック */
.health-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.health-card{background:#fff;border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow);border-left:6px solid var(--gray-soft)}
.health-card.good{border-left-color:var(--green)}
.health-card.warn{border-left-color:var(--yellow)}
.health-card.bad{border-left-color:var(--red)}
.health-label{font-size:13px;font-weight:700;color:var(--muted)}
.health-value{font-size:28px;font-weight:900;margin:6px 0;font-variant-numeric:tabular-nums}
.health-value.good{color:var(--green)}
.health-value.warn{color:var(--yellow)}
.health-value.bad{color:var(--red)}
.health-desc{font-size:12px;color:var(--muted);line-height:1.5}
.health-status{display:inline-block;padding:2px 10px;border-radius:999px;font-size:11px;font-weight:700;margin-bottom:6px}
.health-status.good{background:var(--green-soft);color:var(--green)}
.health-status.warn{background:var(--yellow-soft);color:var(--yellow)}
.health-status.bad{background:var(--red-soft);color:var(--red)}

/* 取引分析 */
.rank-table{width:100%;border-collapse:collapse;font-size:14px}
.rank-table th{text-align:left;color:var(--muted);font-weight:700;font-size:12px;border-bottom:2px solid var(--line);padding:10px 8px}
.rank-table td{border-bottom:1px solid var(--line);padding:10px 8px;vertical-align:middle}
.rank-table .num{text-align:right;font-variant-numeric:tabular-nums}
.rank-table .rank-pos{width:40px;color:var(--blue);font-weight:900;text-align:center}
.rank-bar{position:relative;background:var(--gray-soft);height:18px;border-radius:9px;overflow:hidden;min-width:120px}
.rank-bar-fill{background:linear-gradient(90deg,var(--blue-2),var(--blue));height:100%;border-radius:9px}
.rank-bar-label{position:absolute;top:0;left:8px;line-height:18px;font-size:11px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}

/* シンプル月次レポート */
.simple-report-body{padding:20px}
.sr-head{text-align:center;border-bottom:3px solid var(--blue);padding-bottom:14px;margin-bottom:18px}
.sr-head h1{margin:0;font-size:22px;color:var(--blue)}
.sr-head .sr-sub{color:var(--muted);font-size:13px;margin-top:4px}
.sr-block{margin:18px 0}
.sr-block h3{font-size:14px;color:var(--blue);margin:0 0 8px;border-left:4px solid var(--blue);padding-left:8px}
.sr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.sr-cell{background:var(--blue-soft);border-radius:10px;padding:12px 14px}
.sr-cell .sr-label{font-size:11px;color:var(--muted);font-weight:700}
.sr-cell .sr-num{font-size:22px;font-weight:900;color:var(--blue);font-variant-numeric:tabular-nums;margin-top:4px}
.sr-table{width:100%;border-collapse:collapse;font-size:13px}
.sr-table th,.sr-table td{padding:6px 8px;border-bottom:1px solid var(--line)}
.sr-table th{text-align:left;color:var(--muted);font-size:11px}
.sr-table .num{text-align:right;font-variant-numeric:tabular-nums}

/* 基本帳票 */
.br-table{width:100%;border-collapse:collapse;font-size:13px}
.br-table th,.br-table td{padding:8px;border-bottom:1px solid var(--line)}
.br-table th{background:var(--blue-soft);color:var(--blue);text-align:left;font-size:12px;position:sticky;top:0}
.br-table .num{text-align:right;font-variant-numeric:tabular-nums}
.br-table tr.total{background:var(--blue-soft);font-weight:900;color:var(--blue)}

/* PDF プレビュー */
.preview-wrap{position:absolute;left:-99999px;top:0;width:794px;z-index:-1}
.preview-wrap.hidden{display:none !important}
.invoice-sheet{width:794px;min-height:1123px;background:#fff;color:#222;padding:50px 56px;font-family:"Noto Sans JP",sans-serif;font-size:13px;}
.inv-head{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:3px solid var(--blue);padding-bottom:14px;gap:20px}
.inv-head .inv-title{font-size:28px;font-weight:900;color:var(--blue);letter-spacing:4px}
.inv-head .inv-no{font-size:13px;color:#666;margin-top:6px}
.inv-head .inv-right{text-align:right;font-size:13px;line-height:1.7}
.inv-head .inv-logo{max-height:60px;max-width:220px;display:block;margin-bottom:6px;margin-left:auto}
.inv-head .inv-comp{font-weight:900;font-size:16px}
.inv-meta{display:grid;grid-template-columns:1.2fr 1fr;gap:24px;margin-top:24px}
.inv-meta .box{font-size:13px;line-height:1.7}
.inv-meta .box h4{font-size:12px;margin:0 0 6px;color:#777;font-weight:700}
.inv-meta .box .name{font-size:18px;font-weight:900;border-bottom:1px solid #999;padding-bottom:4px;margin-bottom:6px}
.inv-total-banner{margin:24px 0;padding:14px 18px;background:var(--blue-soft);border-left:6px solid var(--blue);display:flex;justify-content:space-between;align-items:center}
.inv-total-banner span{font-size:14px;color:var(--blue);font-weight:700}
.inv-total-banner strong{font-size:24px;color:var(--blue);font-weight:900;font-variant-numeric:tabular-nums}
.inv-items{width:100%;border-collapse:collapse;margin-top:8px}
.inv-items th{background:var(--blue);color:#fff;padding:8px 10px;font-size:12px;text-align:left}
.inv-items th.num{text-align:right}
.inv-items td{padding:9px 10px;border-bottom:1px solid #ddd;font-size:13px}
.inv-items td.num{text-align:right;font-variant-numeric:tabular-nums}
.inv-sub{margin-top:14px;display:flex;justify-content:flex-end}
.inv-sub table{font-size:13px;min-width:240px}
.inv-sub td{padding:4px 8px}
.inv-sub td.num{text-align:right;font-variant-numeric:tabular-nums}
.inv-sub tr.grand td{font-weight:900;border-top:2px solid var(--blue);font-size:15px;color:var(--blue);padding-top:8px}
.inv-foot{margin-top:30px;padding-top:14px;border-top:1px solid #ddd;font-size:12px;line-height:1.7;color:#444;white-space:pre-line}


/* ===== LEVEL 2: 経営支援 ===== */
/* 経営計画（予算） */
.bg-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:8px}
.bg-table th,.bg-table td{padding:6px 4px;border:1px solid var(--line);text-align:right;font-variant-numeric:tabular-nums}
.bg-table th{background:var(--blue-soft);color:var(--blue);font-weight:700;font-size:11px;text-align:center}
.bg-table th.first,.bg-table td.first{text-align:left;background:var(--gray-soft);font-weight:700;color:var(--ink);min-width:90px}
.bg-table input{width:90px;border:1.5px solid var(--line);border-radius:6px;padding:4px 6px;font:inherit;text-align:right;background:#fbfcfe}
.bg-table input:focus{outline:none;border-color:var(--blue-2);background:#fff}
.bg-table .ach-good{color:var(--green);font-weight:700}
.bg-table .ach-warn{color:var(--yellow);font-weight:700}
.bg-table .ach-bad{color:var(--red);font-weight:700}

/* KPI管理 */
.kpi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.kpi-bg-card{background:#fff;border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);border-left:6px solid var(--blue)}
.kpi-bg-card h3{margin:0 0 8px;font-size:15px}
.kpi-bg-card .kpi-vals{display:flex;justify-content:space-between;align-items:baseline;margin:6px 0}
.kpi-bg-card .kpi-cur{font-size:22px;font-weight:900;color:var(--blue);font-variant-numeric:tabular-nums}
.kpi-bg-card .kpi-tgt{color:var(--muted);font-size:13px}
.kpi-bg-card .progress-bar{background:var(--gray-soft);height:10px;border-radius:5px;overflow:hidden;margin:8px 0 4px}
.kpi-bg-card .progress-fill{background:linear-gradient(90deg,var(--blue-2),var(--blue));height:100%;border-radius:5px;transition:width .3s}
.kpi-bg-card .progress-fill.over{background:linear-gradient(90deg,#2bb46a,#1a8a4a)}
.kpi-bg-card .kpi-foot{display:flex;justify-content:space-between;align-items:center;margin-top:6px;font-size:12px;color:var(--muted)}

/* シミュレーション */
.sim-result-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:14px}
.sim-card{background:#fff;border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);text-align:center}
.sim-card .sim-label{font-size:12px;color:var(--muted);font-weight:700}
.sim-card .sim-val{font-size:22px;font-weight:900;margin:6px 0;font-variant-numeric:tabular-nums;color:var(--blue)}
.sim-card .sim-delta{font-size:12px;padding:2px 8px;border-radius:999px;background:var(--blue-soft);color:var(--blue);display:inline-block}

/* 資金繰り */
.cff-event-row{display:grid;grid-template-columns:90px 60px 1fr 120px 120px;gap:8px;padding:6px 4px;border-bottom:1px solid var(--line);font-size:13px;align-items:center}
.cff-event-row.head{background:var(--gray-soft);font-weight:700;color:var(--muted);font-size:11px}
.cff-event-row .cff-in{color:var(--green);font-weight:700;font-variant-numeric:tabular-nums;text-align:right}
.cff-event-row .cff-out{color:var(--red);font-weight:700;font-variant-numeric:tabular-nums;text-align:right}
.cff-event-row .cff-bal{font-variant-numeric:tabular-nums;font-weight:700;text-align:right}
.cff-event-row .cff-bal.neg{color:var(--red)}
.cff-event-row .cff-type{font-size:11px;padding:2px 6px;border-radius:8px;text-align:center}
.cff-event-row .cff-type.in{background:var(--green-soft);color:var(--green)}
.cff-event-row .cff-type.out{background:var(--red-soft);color:var(--red)}

/* 借入金 */
.loan-schedule-table{width:100%;border-collapse:collapse;font-size:13px}
.loan-schedule-table th,.loan-schedule-table td{padding:7px 8px;border-bottom:1px solid var(--line)}
.loan-schedule-table th{background:var(--blue-soft);color:var(--blue);font-size:12px;text-align:right}
.loan-schedule-table th:first-child{text-align:left}
.loan-schedule-table td{text-align:right;font-variant-numeric:tabular-nums}
.loan-schedule-table td:first-child{text-align:left}

/* 財務DD */
.dd-table{width:100%;border-collapse:collapse;font-size:13px}
.dd-table th,.dd-table td{padding:9px 8px;border-bottom:1px solid var(--line)}
.dd-table th{background:var(--blue-soft);color:var(--blue);font-size:12px}
.dd-table th{text-align:right}
.dd-table th:first-child{text-align:left}
.dd-table td{text-align:right;font-variant-numeric:tabular-nums}
.dd-table td:first-child{text-align:left;font-weight:700;background:var(--gray-soft)}
.dd-trend{font-size:11px;margin-left:6px}
.dd-trend.up{color:var(--green)}
.dd-trend.down{color:var(--red)}


/* ===== LEVEL 3: 顧問先管理 ===== */
.chk-toggle{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);font-weight:700;cursor:pointer}
.chk-toggle input{width:16px;height:16px}

/* コメント・ToDo */
.td-item{display:flex;align-items:flex-start;gap:12px;padding:12px 8px;border-bottom:1px solid var(--line)}
.td-item:last-child{border-bottom:none}
.td-check{width:22px;height:22px;flex-shrink:0;margin-top:2px;cursor:pointer}
.td-content{flex:1;min-width:0}
.td-text{font-size:14px;line-height:1.5}
.td-item.done .td-text{text-decoration:line-through;color:var(--muted)}
.td-meta{display:flex;gap:10px;margin-top:4px;font-size:11px;color:var(--muted);flex-wrap:wrap;align-items:center}
.td-kind{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700}
.td-kind.todo{background:var(--orange-soft);color:var(--orange)}
.td-kind.comment{background:var(--blue-soft);color:var(--blue)}
.td-due{font-weight:700}
.td-due.overdue{color:var(--red)}
.td-del{border:none;background:transparent;color:var(--red);cursor:pointer;font-size:14px;padding:4px 8px;flex-shrink:0}

/* データチェック */
.dc-summary-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.dc-stat{background:#fff;border-radius:14px;padding:14px 16px;box-shadow:var(--shadow);text-align:center}
.dc-stat .dc-num{font-size:26px;font-weight:900;font-variant-numeric:tabular-nums}
.dc-stat .dc-lab{font-size:12px;color:var(--muted);font-weight:700;margin-top:2px}
.dc-stat.danger .dc-num{color:var(--red)}
.dc-stat.warn .dc-num{color:var(--yellow)}
.dc-stat.ok .dc-num{color:var(--green)}
.dc-stat.total .dc-num{color:var(--blue)}

.dc-cat{margin-bottom:18px}
.dc-cat-head{font-size:14px;font-weight:900;color:var(--blue);padding:8px 0;border-bottom:2px solid var(--blue-soft);margin-bottom:8px;display:flex;justify-content:space-between}
.dc-finding{border:1px solid var(--line);border-radius:11px;padding:12px 14px;margin-bottom:8px;border-left:5px solid var(--gray-soft)}
.dc-finding.sev-high{border-left-color:var(--red);background:var(--red-soft)}
.dc-finding.sev-mid{border-left-color:var(--yellow);background:var(--yellow-soft)}
.dc-finding.sev-low{border-left-color:var(--blue-2)}
.dc-finding.resolved{border-left-color:var(--green);background:var(--green-soft);opacity:.75}
.dc-finding-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.dc-finding-title{font-size:14px;font-weight:700}
.dc-finding-detail{font-size:12px;color:#555;margin-top:4px;line-height:1.5}
.dc-sev-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;white-space:nowrap;flex-shrink:0}
.dc-sev-badge.sev-high{background:var(--red);color:#fff}
.dc-sev-badge.sev-mid{background:var(--yellow);color:#fff}
.dc-sev-badge.sev-low{background:var(--blue-soft);color:var(--blue)}
.dc-actions{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap;align-items:center}
.dc-status-btn{border:1.5px solid var(--line);background:#fff;border-radius:8px;padding:5px 12px;font:inherit;font-size:12px;font-weight:700;cursor:pointer;color:var(--muted)}
.dc-status-btn:hover{border-color:var(--blue-2)}
.dc-status-btn.active{color:#fff}
.dc-status-btn.active[data-st="ok"]{background:var(--green);border-color:var(--green)}
.dc-status-btn.active[data-st="fixed"]{background:var(--blue);border-color:var(--blue)}
.dc-status-btn.active[data-st="hold"]{background:var(--yellow);border-color:var(--yellow)}
.dc-status-btn.active[data-st="na"]{background:#8893a3;border-color:#8893a3}

@media(max-width:980px){.grid-2{grid-template-columns:1fr} .form-row{grid-template-columns:1fr 1fr} .health-grid{grid-template-columns:1fr 1fr} .sr-grid{grid-template-columns:1fr 1fr}}
@media(max-width:840px){.app-shell{flex-direction:column}.sidebar{width:100%;height:auto;position:static;flex-direction:column}.nav{flex-direction:row;flex-wrap:wrap}.kpi-row{grid-template-columns:1fr} .health-grid{grid-template-columns:1fr} .sr-grid{grid-template-columns:1fr}}

/* 銀行明細取込 */
.nav-section{font-size:11px;color:#aab2bf;margin:10px 6px 2px;font-weight:700;letter-spacing:.5px}
.bank-steps{margin:6px 0 14px;padding-left:20px;font-size:13px;color:#566173;line-height:1.8}
.bank-steps li{margin-bottom:2px}
.bank-preview-scroll{max-height:420px;overflow:auto;border:1px solid var(--line);border-radius:11px}
.bank-preview-scroll table{margin:0}
.bank-chk{width:18px;height:18px;cursor:pointer}
.bank-type{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700}
.bank-type.in{background:var(--green-soft);color:var(--green)}
.bank-type.out{background:var(--red-soft);color:var(--red)}

/* ===================================================================== */
/* ============ かんたんモード (Phase 10) ============ */
/* ===================================================================== */
#easy-mode-wrap{display:none;min-height:100vh;background:linear-gradient(180deg,#eef4ff,#f6f8fc);padding-bottom:60px}
body.easy #easy-mode-wrap{display:block}
body.easy #normal-mode-wrap{display:none}
/* デフォルト（通常モード）では easy を隠す */
#normal-mode-wrap{display:flex}

.easy-top{display:flex;align-items:center;justify-content:space-between;background:#fff;padding:16px 28px;box-shadow:0 2px 10px rgba(0,0,0,.05);position:sticky;top:0;z-index:10;flex-wrap:wrap;gap:12px}
.easy-logo{height:40px;width:auto}
.easy-top-right{display:flex;align-items:center;gap:14px}
.easy-date{font-size:16px;font-weight:700;color:#566173}
.mode-switch{border:2px solid var(--blue);background:#fff;color:var(--blue);font:inherit;font-weight:700;font-size:15px;padding:8px 18px;border-radius:999px;cursor:pointer;transition:background .15s}
.mode-switch:hover{background:var(--blue-soft)}
.easy-logout{border:none;background:transparent;color:var(--muted);font:inherit;font-size:14px;cursor:pointer;text-decoration:underline}

#easy-home{max-width:920px;margin:0 auto;padding:24px 20px}

.easy-cash-card{background:linear-gradient(135deg,#2f6fd0,#1f4e96);color:#fff;border-radius:22px;padding:30px 28px;text-align:center;box-shadow:0 10px 30px rgba(31,78,150,.25);margin-bottom:24px}
.easy-cash-label{font-size:18px;font-weight:700;opacity:.95}
.easy-cash-value{font-size:52px;font-weight:900;margin:8px 0;font-variant-numeric:tabular-nums;line-height:1.1}
.easy-cash-note{font-size:15px;opacity:.9}

.easy-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px}
@media(max-width:780px){.easy-actions{grid-template-columns:1fr}}
.easy-btn{display:flex;flex-direction:column;align-items:center;gap:8px;border:none;border-radius:20px;padding:28px 18px;cursor:pointer;color:#fff;box-shadow:0 6px 18px rgba(0,0,0,.12);transition:transform .12s,filter .12s}
.easy-btn:hover{transform:translateY(-3px);filter:brightness(1.05)}
.easy-btn:active{transform:translateY(0)}
.easy-btn-sales{background:linear-gradient(135deg,#ff9a4d,#ff6a3d)}
.easy-btn-pay{background:linear-gradient(135deg,#ff6a6a,#ef3e6e)}
.easy-btn-photo{background:linear-gradient(135deg,#7c5cff,#5a3fd0)}
.easy-btn-ico{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.22);border-radius:50%}
.easy-btn-ico svg{width:28px;height:28px}
.easy-btn-main{font-size:21px;font-weight:900}
.easy-btn-sub{font-size:14px;opacity:.92}

.easy-section{background:#fff;border-radius:18px;padding:22px 24px;box-shadow:0 4px 14px rgba(0,0,0,.06);margin-bottom:20px}
.easy-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px}
.easy-section-head h2{margin:0;font-size:20px;color:#26303f}
.easy-mini-btn{border:2px solid var(--blue);background:var(--blue);color:#fff;font:inherit;font-weight:700;font-size:15px;padding:8px 18px;border-radius:999px;cursor:pointer}
.easy-mini-btn:hover{filter:brightness(1.08)}
.easy-month-input{font:inherit;font-size:15px;padding:7px 12px;border:1.5px solid var(--line);border-radius:10px}

.easy-reg-summary{font-size:16px;color:#566173;line-height:1.7}
.easy-reg-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line)}
.easy-reg-row:last-child{border-bottom:none}
.easy-reg-row .diff-ok{color:var(--green);font-weight:700}
.easy-reg-row .diff-ng{color:var(--red);font-weight:700}

.easy-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:780px){.easy-summary-grid{grid-template-columns:1fr}}
.easy-sum-card{border-radius:16px;padding:20px;text-align:center}
.easy-sum-card.in{background:var(--green-soft)}
.easy-sum-card.out{background:var(--red-soft)}
.easy-sum-card.net{background:var(--blue-soft)}
.easy-sum-label{font-size:15px;font-weight:700;color:#566173;margin-bottom:6px}
.easy-sum-val{font-size:30px;font-weight:900;font-variant-numeric:tabular-nums}
.easy-sum-card.in .easy-sum-val{color:var(--green)}
.easy-sum-card.out .easy-sum-val{color:var(--red)}
.easy-sum-card.net .easy-sum-val{color:var(--blue)}
.easy-sum-card.net.minus .easy-sum-val{color:var(--red)}

.easy-signal{margin-top:16px;padding:16px 20px;border-radius:14px;font-size:17px;font-weight:700;display:flex;align-items:center;gap:12px}
.easy-signal::before{content:"";width:20px;height:20px;border-radius:50%;flex-shrink:0}
.easy-signal.green{background:var(--green-soft);color:#1a7a44}
.easy-signal.green::before{background:var(--green)}
.easy-signal.yellow{background:var(--yellow-soft);color:#9a6a00}
.easy-signal.yellow::before{background:var(--yellow)}
.easy-signal.red{background:var(--red-soft);color:#b5302a}
.easy-signal.red::before{background:var(--red)}

/* かんたんモーダル（大きめ・年配向け） */
.easy-modal{max-width:440px}
.easy-field{display:block;margin-bottom:16px}
.easy-field>span{display:block;font-size:16px;font-weight:700;color:#3a4453;margin-bottom:6px}
.easy-field input{width:100%;font-size:22px;font-weight:700;padding:14px 16px;border:2px solid var(--line);border-radius:12px;box-sizing:border-box}
.easy-field input:focus{outline:none;border-color:var(--blue)}
.easy-cat-chips{display:flex;flex-wrap:wrap;gap:8px}
.easy-cat-chip{border:2px solid var(--line);background:#fff;border-radius:999px;padding:8px 16px;font:inherit;font-size:15px;font-weight:700;cursor:pointer;color:#566173}
.easy-cat-chip.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.easy-modal-actions{margin-top:8px}
.easy-cancel{font-size:16px;padding:13px 20px}
.easy-save{font-size:18px;font-weight:900;padding:13px 28px}
.reg-expected{display:flex;justify-content:space-between;align-items:center;background:var(--gray-soft);border-radius:12px;padding:14px 16px;margin-bottom:16px;font-size:15px;font-weight:700}
.reg-expected strong{font-size:20px;color:var(--blue)}
.reg-diff{border-radius:12px;padding:16px;font-size:17px;font-weight:700;text-align:center;margin-bottom:8px}
.reg-diff.ok{background:var(--green-soft);color:#1a7a44}
.reg-diff.ng{background:var(--yellow-soft);color:#9a6a00}

/* ===================================================================== */
/* ============ はじめてガイド (Phase 11) ============ */
/* ===================================================================== */
.guide-block{margin:0 0 18px}
.guide-toggle{display:flex;align-items:center;gap:10px;width:100%;text-align:left;border:1.5px dashed var(--blue-2);background:var(--blue-soft);color:var(--blue);font:inherit;font-weight:700;font-size:14px;padding:11px 16px;border-radius:12px;cursor:pointer;transition:background .15s}
.guide-toggle:hover{background:#e2ecfb}
.guide-q{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--blue);color:#fff;border-radius:50%;font-size:14px;font-weight:900;flex-shrink:0}
.guide-toggle-label{flex:1}
.guide-chevron{font-size:11px;transition:transform .2s}
.guide-toggle.open .guide-chevron{transform:rotate(180deg)}
.guide-body{display:none;background:#fff;border:1px solid var(--blue-soft);border-radius:0 0 14px 14px;border-top:none;margin-top:-4px;padding:18px 20px 16px;box-shadow:var(--shadow)}
.guide-body.open{display:block;animation:guide-in .2s ease}
@keyframes guide-in{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.guide-section{margin-bottom:14px}
.guide-section h4{margin:0 0 6px;font-size:13px;color:var(--blue);font-weight:800}
.guide-section p{margin:0;font-size:14px;line-height:1.7;color:#3a4453}
.guide-section ul,.guide-section ol{margin:0;padding-left:22px;font-size:14px;line-height:1.8;color:#3a4453}
.guide-section li{margin-bottom:2px}
.guide-tip{background:var(--yellow-soft);border-radius:10px;padding:11px 14px;font-size:13.5px;line-height:1.6;color:#7a5a00;margin-bottom:14px}
.guide-close-btn{border:1.5px solid var(--line);background:#fff;color:var(--muted);font:inherit;font-size:13px;font-weight:700;padding:8px 16px;border-radius:9px;cursor:pointer}
.guide-close-btn:hover{border-color:var(--blue-2);color:var(--blue)}

/* かんたんモード用ガイド（大きめ） */
.easy-guide{background:#fff;border:2px solid var(--blue-soft);border-radius:18px;padding:20px 22px;margin-bottom:20px}
.easy-guide-toggle{display:flex;align-items:center;gap:12px;width:100%;text-align:left;border:none;background:transparent;font:inherit;font-weight:800;font-size:18px;color:var(--blue);cursor:pointer}
.easy-guide-toggle .guide-q{width:28px;height:28px;font-size:17px}
.easy-guide-toggle .guide-chevron{margin-left:auto;font-size:14px;transition:transform .2s}
.easy-guide-toggle.open .guide-chevron{transform:rotate(180deg)}
.easy-guide-body{display:none;margin-top:14px}
.easy-guide-body.open{display:block}
.easy-guide-step{display:flex;gap:14px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--line)}
.easy-guide-step:last-child{border-bottom:none}
.easy-guide-num{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--blue);color:#fff;border-radius:50%;font-weight:900;font-size:17px;flex-shrink:0}
.easy-guide-text{font-size:16px;line-height:1.5;color:#3a4453;padding-top:4px}
.easy-guide-text strong{color:var(--blue)}

/* 設定：事業所情報 */
.req{display:inline-block;background:#ffe0e0;color:#c0392b;font-size:10px;font-weight:800;padding:1px 6px;border-radius:4px;margin-left:6px;vertical-align:middle}
.invoice-box{border:1px solid var(--line);border-radius:12px;padding:16px;margin:16px 0;background:var(--gray-soft)}
.invoice-box-title{font-weight:800;font-size:14px;color:#26303f;margin-bottom:4px}

/* クリック可能な会計年度バッジ */
.topbar-badge-btn{font:inherit;cursor:pointer;transition:background .12s}
.topbar-badge-btn:hover{background:var(--blue-soft);border-color:var(--blue-2)}

/* 郵便番号の自動入力行 */
.zip-row{display:flex;gap:8px;align-items:center}
.zip-row input{flex:1;min-width:0}
.zip-row .btn-ghost{flex-shrink:0;white-space:nowrap}

/* 銀行CSV重複候補 */
.bank-dup-row{background:#fff6f0}
.bank-dup-tag{display:inline-block;background:#ffe0e0;color:#c0392b;font-size:10px;font-weight:800;padding:1px 6px;border-radius:4px;margin-left:6px}

/* 会社作成：モード選択 */
.mode-choice{display:flex;flex-direction:column;gap:10px;margin-top:4px}
.mode-choice-opt{display:flex;gap:12px;align-items:flex-start;border:1.5px solid var(--line);border-radius:12px;padding:14px 16px;cursor:pointer;transition:border-color .12s,background .12s}
.mode-choice-opt:hover{border-color:var(--blue-2);background:var(--blue-soft)}
/* 共通の入力欄スタイル（幅100%・枠線）を打ち消し、通常サイズのラジオに戻す */
.mode-choice-opt input[type="radio"]{width:18px;height:18px;min-width:0;flex-shrink:0;margin:2px 0 0;padding:0;border:none;border-radius:0;background:none;-webkit-appearance:radio;appearance:radio;accent-color:var(--blue)}
.mode-choice-opt:has(input:checked){border-color:var(--blue);background:var(--blue-soft)}
.mode-choice-opt span{line-height:1.5}
.mode-choice-opt strong{font-size:15px;color:var(--ink)}
.mode-choice-opt small{font-size:12px}

/* ============================================================ */
/* ===== デザイン洗練 (CSSのみ・機能/HTML/JSは不変) ===== */
/* 方針: 1色アクセント＋無彩色、白基調、数字を強調、影と角丸を上品に */
/* ============================================================ */

/* 変数の上書き：影を中立・控えめに、角丸と罫線を上品に */
:root{
  --shadow:0 1px 2px rgba(16,24,40,.04), 0 1px 3px rgba(16,24,40,.06);
  --radius:12px;
  --line:#e9ecf2;
  --blue:#1d4d8c;
  --ink:#1a2330;
  --muted:#697485;
}

/* タイポの太さを上品に（900→800） */
.brand{font-weight:800}
.view-head h2{font-weight:800;letter-spacing:-.01em}
.auth-logo{font-weight:800}

/* パネル：白＋細い罫線＋控えめ影 */
.panel{border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow)}
.auth-card{border-radius:14px}
.modal-card{border-radius:14px}

/* ボタン：AIっぽい装飾（紫グラデ・キラキラ）を除去して無地に */
.btn-ai{background:var(--blue-2);border:none}
.btn-ai::before{content:"";margin:0}
.btn-ai:hover{filter:brightness(1.06)}
.btn-primary{border-radius:10px}
.btn-ghost{border-radius:10px}

/* KPIカード：白基調＋左の細い色アクセント＋大きく濃い数字（記事の「白＝クリーン」「数字に強弱」） */
.kpi-card{background:#fff;border:1px solid var(--line);color:var(--ink);border-radius:12px;min-height:auto;padding:18px 20px;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.kpi-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--kpi-accent,#cfd6e2)}
.kpi-label{color:var(--muted);opacity:1;font-weight:700;font-size:13px}
.kpi-value{color:var(--ink);font-weight:800;font-size:32px;letter-spacing:-.02em}
.kpi-sub{color:var(--muted);opacity:1;font-size:12px}
.grad-orange{background:#fff;--kpi-accent:#e8732f}
.grad-red{background:#fff;--kpi-accent:#d8453c}
.grad-teal{background:#fff;--kpi-accent:#1f8fb0}
.grad-blue{background:#fff;--kpi-accent:#2f6fd0}
.grad-orange .kpi-value{color:#c95f24}
.grad-red .kpi-value{color:#c33b33}
.grad-teal .kpi-value{color:#197a98}
.grad-blue .kpi-value{color:#2a62bb}

/* 経営ハイライト：グラデを廃しフラットに */
.mr-highlight{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}

/* BSボックス図：彩度を一段落として上品なソリッドに */
.bs-box-item.asset-cash{background:#2a8aa3}
.bs-box-item.asset-ar{background:#3a76c4}
.bs-box-item.liab-ap{background:#dd7642}
.bs-box-item.equity{background:#6356c4}

/* バー類：単色寄りに */
.rank-bar-fill{background:var(--blue-2)}
.kpi-bg-card .progress-fill{background:var(--blue-2)}
.kpi-bg-card .progress-fill.over{background:var(--green)}

/* データテーブル：Excel感を減らし、見出しは控えめ・1列目を強調・行hover */
.data-table th{border-bottom:1px solid var(--line);font-size:11px;font-weight:700;letter-spacing:.2px}
.data-table tbody tr{transition:background .1s}
.data-table tbody tr:hover{background:#f7f9fc}
.data-table td:first-child{font-weight:700;color:var(--ink)}

/* かんたんモード：派手さを抑えつつ、年配向けの大きさは維持 */
#easy-mode-wrap{background:#f5f7fb}
.easy-cash-card{background:var(--blue);border-radius:16px;box-shadow:var(--shadow)}
.easy-btn{box-shadow:var(--shadow);border-radius:16px}
.easy-btn-sales{background:#e0712e}
.easy-btn-pay{background:#cf4444}
.easy-btn-photo{background:#5a50ba}
.easy-btn:hover{filter:brightness(1.04)}

/* ガイド：装飾の点線を実線寄りに（落ち着いた印象） */
.guide-toggle{border-style:solid;border-width:1px}

/* 入力フォーカス：色アクセントを主色1色に統一 */
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(29,77,140,.08)}

/* ============================================================ */
/* ===== レスポンシブ強化 (CSSのみ・機能/HTML/JS不変) ===== */
/* ============================================================ */

/* 横長テーブルはパネル内で横スクロール（画面外にはみ出さない） */
.panel:has(.data-table){overflow-x:auto}

/* タブレット〜スマホ：サイドバーは縦のまま全幅（グループ折りたたみ済みでコンパクト） */
@media(max-width:840px){
  .nav{flex-direction:column;flex-wrap:nowrap;gap:1px}
  .sidebar{border-right:none;border-bottom:1px solid var(--line);padding:16px 14px;gap:12px}
  .main{padding:16px 16px 48px}
  .topbar{margin-bottom:14px}
  .topbar-right{width:100%;justify-content:flex-start;flex-wrap:wrap}
}

/* スマホ：見出し・操作・数字を縦積み＆サイズ調整、はみ出し防止 */
@media(max-width:560px){
  .view-head{flex-direction:column;align-items:stretch;gap:10px}
  .head-actions{flex-wrap:wrap}
  .view-head h2{font-size:19px}
  .kpi-value{font-size:26px}
  .easy-cash-value{font-size:40px}
  .easy-top{padding:14px 16px}
  .easy-logo{height:32px}
  .modal-card{padding:20px 16px}
  .company-dropdown{right:auto;left:0;width:min(290px,calc(100vw - 32px))}
  .search-input,.month-input{min-width:0;width:100%}
  .zip-row{flex-wrap:wrap}
  .totals .total-line{min-width:0}
}

/* ============================================================ */
/* ===== ログイン/登録UI (freee風) ===== */
/* ============================================================ */
.pw-row{position:relative;display:flex;align-items:center}
.pw-row input{width:100%;padding-right:42px}
.pw-eye{position:absolute;right:10px;background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;display:flex}
.pw-eye svg{width:18px;height:18px}
.pw-eye:hover{color:var(--blue)}

.auth-links{display:flex;flex-direction:column;gap:8px;align-items:center;margin-top:14px}
.auth-textlink{background:none;border:none;color:var(--blue);font:inherit;font-size:13px;cursor:pointer;padding:2px}
.auth-textlink:hover{text-decoration:underline}

.auth-divider{display:flex;align-items:center;text-align:center;color:var(--muted);font-size:12px;font-weight:700;margin:20px 0 14px}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--line)}
.auth-divider span{padding:0 12px}

.provider-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;border:1.5px solid var(--line);background:#fff;border-radius:10px;padding:11px;font:inherit;font-weight:700;font-size:14px;color:var(--ink);cursor:pointer;transition:background .12s,border-color .12s}
.provider-btn:hover{background:#f7f9fc;border-color:#cfd6e2}
.provider-btn + .provider-btn{margin-top:10px}

.auth-msg{font-size:13px;min-height:18px;margin:6px 0 0;font-weight:600}
.auth-step-title{font-size:20px;font-weight:800;color:var(--ink);text-align:center;margin:6px 0 4px}

/* 登録ステップインジケーター */
.auth-steps{display:flex;align-items:center;justify-content:center;gap:6px;margin:4px 0 18px}
.auth-step{display:flex;flex-direction:column;align-items:center;gap:4px;opacity:.5}
.auth-step.active{opacity:1}
.auth-step-num{width:30px;height:30px;border-radius:50%;border:2px solid var(--line);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;color:var(--muted);background:#fff}
.auth-step.active .auth-step-num{border-color:var(--blue);color:var(--blue)}
.auth-step.done .auth-step-num{background:var(--blue);border-color:var(--blue);color:#fff}
.auth-step-label{font-size:11px;font-weight:700;color:var(--muted)}
.auth-step.active .auth-step-label{color:var(--blue)}
.auth-step-line{width:48px;height:2px;background:var(--line);margin-bottom:18px}

/* メール確認待ち */
.verify-note{background:var(--blue-soft);border-radius:10px;padding:12px 14px;font-size:13px;line-height:1.6;color:#3a4453;margin:4px 0 14px}
.verify-note p{margin:0}

/* 請求書PDF：件名 */
.inv-subject-line{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:8px;padding:10px 14px;margin-bottom:12px}
.inv-subject-line span{font-size:12px;font-weight:700;color:var(--muted);flex-shrink:0}
.inv-subject-line strong{font-size:15px;color:var(--ink)}

/* AI自動仕訳（経費モーダル内） */
.ai-suggest-wrap{margin-top:10px;padding-top:12px;border-top:1px dashed var(--line)}
.btn-ai.small{padding:8px 14px;font-size:13px}
.ai-suggest-result{margin-top:10px}
.ai-suggest-card{border:1px solid var(--blue-soft);background:var(--blue-soft);border-radius:10px;padding:12px 14px}
.ai-suggest-head{font-size:14px;margin-bottom:4px}
.ai-suggest-head strong{font-size:16px;color:var(--blue)}
.ai-suggest-reason{font-size:12px;color:var(--muted);margin-bottom:10px}
.ai-conf{font-size:11px;font-weight:700;padding:1px 7px;border-radius:10px;margin-left:6px}
.ai-conf-high{background:var(--green-soft);color:#1a7a44}
.ai-conf-medium{background:var(--yellow-soft);color:#8a6500}
.ai-conf-low{background:var(--red-soft);color:#b23b34}
.ai-applied{font-size:13px;font-weight:700;color:#1a7a44}
.ai-err-text{font-size:13px;color:#c0392b}

/* AI二重チェック結果 */
.dc-ai-ok{background:var(--green-soft);color:#1a7a44;font-weight:700;border-radius:10px;padding:14px 16px}
.dc-ai-item{border:1px solid var(--line);border-left-width:4px;border-radius:8px;padding:12px 14px;margin-bottom:10px}
.dc-ai-item.sev-high{border-left-color:var(--red)}
.dc-ai-item.sev-medium{border-left-color:var(--yellow)}
.dc-ai-item.sev-low{border-left-color:var(--blue-2)}
.dc-ai-item-head{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.dc-ai-sev{font-size:11px;font-weight:800;padding:2px 8px;border-radius:6px;color:#fff}
.dc-ai-sev.sev-high{background:var(--red)}
.dc-ai-sev.sev-medium{background:var(--yellow)}
.dc-ai-sev.sev-low{background:var(--blue-2)}
.dc-ai-detail{font-size:13px;color:#3a4453;line-height:1.5}
.dc-ai-ref{font-size:12px;color:var(--muted);margin-top:6px;background:var(--gray-soft);padding:6px 10px;border-radius:6px}

/* ============================================================ */
/* ===== 法的文書オーバーレイ・規約同意 ===== */
/* ============================================================ */
.legal-overlay{position:fixed;inset:0;background:rgba(22,33,54,.5);display:flex;align-items:center;justify-content:center;padding:20px;z-index:60}
.legal-card{width:100%;max-width:680px;max-height:88vh;background:#fff;border-radius:14px;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.legal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line);flex-shrink:0}
.legal-head h2{margin:0;font-size:18px;font-weight:800}
.legal-close{background:none;border:none;font-size:24px;line-height:1;color:var(--muted);cursor:pointer;padding:0 4px}
.legal-close:hover{color:var(--ink)}
.legal-body{overflow-y:auto;padding:20px 22px;font-size:13.5px;line-height:1.8;color:#2c3543}
.legal-body h3{font-size:14px;font-weight:800;color:var(--ink);margin:18px 0 6px}
.legal-body p{margin:0 0 10px}
.legal-note{background:var(--yellow-soft);border-left:4px solid var(--yellow);padding:10px 12px;border-radius:8px;color:#8a6500;font-size:12.5px}
.legal-date{margin-top:20px;color:var(--muted);font-size:12px}

.consent-row{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--ink);margin:4px 0 14px;cursor:pointer;line-height:1.5}
.consent-row input{margin-top:3px;flex-shrink:0}
.auth-textlink.inline{display:inline;font-size:13px;padding:0;color:var(--blue);text-decoration:underline}

.auth-footer-links{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:6px;margin-top:18px;padding-top:14px;border-top:1px solid var(--line)}
.auth-foot-sep{color:var(--line)}

/* 退会（危険操作）ゾーン */
.danger-zone{border:1px solid var(--red-soft);background:#fffafa;border-radius:12px;padding:16px}
.danger-title{color:var(--red);margin-top:0}
.btn-danger{border:none;border-radius:10px;background:var(--red);color:#fff;font:inherit;font-weight:700;padding:11px 18px;cursor:pointer}
.btn-danger:hover{filter:brightness(1.06)}
.btn-danger:disabled{opacity:.5;cursor:not-allowed}

/* 特定商取引法に基づく表記 */
.tokusho-table{width:100%;border-collapse:collapse;font-size:13px}
.tokusho-table th{text-align:left;vertical-align:top;width:34%;padding:10px 12px;background:var(--gray-soft);border:1px solid var(--line);font-weight:700;color:var(--ink)}
.tokusho-table td{padding:10px 12px;border:1px solid var(--line);line-height:1.7;color:#2c3543}

/* お支払いゲート */
.billing-card{max-width:480px}
.billing-plan{border:1px solid var(--line);border-radius:12px;padding:18px;margin:16px 0;background:var(--gray-soft)}
.billing-plan-name{font-weight:800;color:var(--blue);font-size:15px}
.billing-plan-price{margin:6px 0 12px}
.billing-plan-price strong{font-size:26px;color:var(--ink)}
.billing-features{margin:0;padding-left:18px;color:#2c3543;font-size:13px;line-height:1.9}

/* 見積→請求/納品 変換ボタン */
.row-btn.conv{background:var(--blue-soft);color:var(--blue);border-color:var(--blue-2)}
.row-btn.conv:hover{background:var(--blue-2);color:#fff}

/* 請求書PDFの振込先（項目別） */
.inv-bank{margin-top:10px;line-height:1.7}
.inv-bank strong{display:block;margin-bottom:2px}

/* ===== 在庫・物流 ===== */
.inv-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
@media(max-width:900px){.inv-kpis{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.inv-kpis{grid-template-columns:1fr}}
.inv-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:2px solid var(--line);flex-wrap:wrap}
.inv-tab{background:none;border:none;font:inherit;font-weight:700;font-size:14px;color:var(--muted);padding:10px 18px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}
.inv-tab:hover{color:var(--ink)}
.inv-tab.active{color:var(--blue);border-bottom-color:var(--blue)}
.tag-low{display:inline-block;background:#fde8e6;color:#c0392b;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px}
.tag-ok{display:inline-block;background:#dff3e8;color:#1a7a44;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px}
.tag-info{display:inline-block;background:var(--blue-soft);color:var(--blue);font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px}
.row-btn.conv{white-space:nowrap}

/* ===== 月次レポート かんたん入力ボタン ===== */
.quick-entry{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
@media(max-width:680px){.quick-entry{grid-template-columns:1fr 1fr}}
.qe-btn{display:flex;flex-direction:column;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 16px;cursor:pointer;font:inherit;transition:transform .15s,box-shadow .15s,border-color .15s}
.qe-btn:hover{transform:translateY(-3px);box-shadow:0 10px 24px rgba(16,32,64,.1);border-color:transparent}
.qe-ico{width:52px;height:52px;border-radius:13px;display:flex;align-items:center;justify-content:center}
.qe-ico svg{width:26px;height:26px}
.qe-sales{background:rgba(31,138,91,.12);color:#1f8a5b}
.qe-expense{background:rgba(216,85,78,.12);color:#d8554e}
.qe-advance{background:rgba(31,95,176,.12);color:var(--blue)}
.qe-officer{background:rgba(200,162,74,.16);color:#b8902f}
.qe-label{font-size:15px;font-weight:700;color:var(--ink)}

/* ===== 折りたためるレポートセクション ===== */
.report-fold{margin-bottom:24px;border:none}
.report-fold>summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;padding:6px 0;margin-bottom:14px;border-bottom:2px solid var(--line)}
.report-fold>summary::-webkit-details-marker{display:none}
.report-fold .fold-chevron{color:var(--muted);transition:transform .25s;flex-shrink:0}
.report-fold .fold-chevron svg{width:22px;height:22px;display:block}
.report-fold[open]>summary .fold-chevron{transform:rotate(180deg)}
.report-fold>summary .report-h{margin:0;border:none;padding:0}

/* ===== 部門（事業部・店舗）エディタ ===== */
.dept-editor{margin-top:6px}
.dept-add-row{display:flex;gap:10px;align-items:center;margin-bottom:12px}
.dept-add-row input{flex:1;padding:11px 13px;border:1.5px solid var(--line);border-radius:11px;font:inherit}
.dept-add-row input:focus{outline:none;border-color:var(--blue)}
.dept-list{display:flex;flex-wrap:wrap;gap:8px}
.dept-chip{display:inline-flex;align-items:center;gap:8px;background:var(--blue-soft);color:var(--blue);font-weight:700;font-size:13px;padding:7px 8px 7px 14px;border-radius:999px}
.dept-chip button{background:rgba(0,0,0,.12);color:#fff;border:none;width:20px;height:20px;border-radius:50%;cursor:pointer;font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center}
.dept-chip button:hover{background:rgba(0,0,0,.3)}

/* ===== 品名マスタ ===== */
.item-add-row{display:flex;gap:10px;align-items:center;margin-bottom:12px;flex-wrap:wrap}
.item-add-row input[type="text"]{flex:2;min-width:160px;padding:11px 13px;border:1.5px solid var(--line);border-radius:11px;font:inherit}
.item-add-row input[type="number"]{flex:1;min-width:110px;padding:11px 13px;border:1.5px solid var(--line);border-radius:11px;font:inherit}
.item-add-row input:focus{outline:none;border-color:var(--blue)}
.item-list{display:flex;flex-wrap:wrap;gap:8px}
.item-chip{display:inline-flex;align-items:center;gap:10px;background:var(--blue-soft);color:var(--blue);font-weight:700;font-size:13px;padding:7px 8px 7px 14px;border-radius:999px}
.item-chip-price{background:#fff;color:var(--blue);border-radius:999px;padding:2px 10px;font-size:12px}
.item-chip button{background:rgba(0,0,0,.12);color:#fff;border:none;width:20px;height:20px;border-radius:50%;cursor:pointer;font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center}
.item-chip button:hover{background:rgba(0,0,0,.3)}

/* ===== KPI追加フォーム ===== */
.kpi-add-form{margin-bottom:20px}
.kpi-form-row{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap}
.kpi-form-row .field{flex:1;min-width:150px;margin:0}
.kpi-form-row .btn-primary{flex-shrink:0;white-space:nowrap}

/* ===== 経営計画（部門別・内訳・折りたたみ） ===== */
.bg-scroll{overflow-x:auto}
.bg-total-row td{border-top:2px solid var(--line);font-weight:700;background:var(--blue-soft)}
#view-budget .report-fold{margin-bottom:16px}
