:root{
  --ink:#23323c;
  --muted:#6c7a82;
  --bg:#f7f8f5;
  --card:#ffffff;
  --line:#e6ebe5;
  --green:#5aa66a;
  --green-dark:#2e7d43;
  --green-soft:#eaf6ed;
  --blue:#4e91cf;
  --blue-soft:#eaf4fc;
  --orange:#ed9a4b;
  --orange-soft:#fff2e3;
  --purple:#8e78c9;
  --purple-soft:#f3effc;
  --red:#d86060;
  --red-soft:#ffeded;
  --yellow:#f6c658;
  --shadow:0 10px 28px rgba(34,54,48,.08);
  --radius:20px;
  font-family:-apple-system,BlinkMacSystemFont,"Hiragino Sans","Yu Gothic UI","Yu Gothic",Meiryo,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--ink);min-height:100%;-webkit-font-smoothing:antialiased}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
.app-shell{max-width:1180px;margin:0 auto;padding:0 18px 92px}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 4px 12px;gap:14px}
.brand{display:flex;align-items:center;gap:11px;min-width:0}
.brand-icon{font-size:31px;filter:drop-shadow(0 3px 3px rgba(0,0,0,.09))}
.brand h1{font-size:20px;margin:0;letter-spacing:.02em;white-space:nowrap}
.brand p{margin:2px 0 0;color:var(--muted);font-size:12px}
.top-actions{display:flex;align-items:center;gap:8px}
.icon-button{border:1px solid var(--line);background:#fff;color:var(--green-dark);width:38px;height:38px;border-radius:50%;font-size:19px;font-weight:800}
#appUpdateButton{color:#276799;background:var(--blue-soft);border-color:#cfe4f5}
.mobile-menu{display:none}
.content{padding:4px 0 22px}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;margin:6px 0 16px}
.page-head h2{font-size:23px;margin:0}
.page-head p{margin:5px 0 0;color:var(--muted);font-size:14px}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:6px 10px;border-radius:999px;background:var(--green-soft);color:var(--green-dark);font-weight:700;white-space:nowrap}
.grid{display:grid;gap:14px}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}
.card{background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:var(--radius);padding:18px}
.card.flat{box-shadow:none}
.card h3{font-size:16px;margin:0 0 12px}
.card p{line-height:1.65}
.hero{padding:20px;background:linear-gradient(135deg,#eef8f1 0%,#fff 56%,#fff7eb 100%);position:relative;overflow:hidden}
.hero:after{content:"";position:absolute;width:190px;height:190px;border-radius:50%;right:-65px;top:-85px;background:rgba(255,200,90,.16)}
.hero .hero-body{position:relative;z-index:1}
.hero-title{display:flex;align-items:center;gap:10px;font-size:21px;font-weight:800;margin:0 0 5px}
.hero-sub{color:var(--muted);margin:0 0 16px;font-size:14px}
.task-card{border:1px solid #bfddc5;background:linear-gradient(135deg,#ffffff,#f1fbf3);padding:16px;border-radius:17px}
.task-card.warning{border-color:#f5ca8a;background:linear-gradient(135deg,#fff,#fff7e8)}
.task-card.danger{border-color:#f2b5b5;background:linear-gradient(135deg,#fff,#fff0f0)}
.task-card h3{margin:0 0 6px;font-size:18px}
.task-card p{margin:0;color:#4b5c54;font-size:14px}
.task-meta{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 0}
.meta-chip{font-size:12px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:5px 8px;color:var(--muted)}
.btn-row{display:flex;flex-wrap:wrap;gap:9px;margin-top:14px}
.btn{border:0;border-radius:13px;padding:11px 15px;font-weight:800;box-shadow:0 3px 9px rgba(33,54,44,.08);min-height:43px}
.btn.primary{background:var(--green);color:#fff}
.btn.primary:hover{background:var(--green-dark)}
.btn.secondary{background:var(--blue-soft);color:#276799}
.btn.orange{background:var(--orange);color:#fff}
.btn.outline{background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:none}
.btn.danger{background:var(--red-soft);color:#a33b3b;box-shadow:none}
.btn.small{padding:8px 10px;min-height:35px;border-radius:10px;font-size:13px}
.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:11px}
.summary-box{border:1px solid var(--line);background:#fff;border-radius:15px;padding:13px}
.summary-box .label{display:block;color:var(--muted);font-size:12px;margin-bottom:6px}
.summary-box .value{display:block;font-size:20px;font-weight:800;word-break:break-word}
.summary-box .note{font-size:11px;color:var(--muted);margin-top:4px;display:block}
.tone-green{background:var(--green-soft);border-color:#cce9d2}
.tone-blue{background:var(--blue-soft);border-color:#cfe4f5}
.tone-orange{background:var(--orange-soft);border-color:#f7d5ac}
.tone-purple{background:var(--purple-soft);border-color:#ddd3f3}
.status-row{display:flex;gap:11px;align-items:flex-start;padding:11px 0;border-bottom:1px dashed var(--line)}
.status-row:last-child{border-bottom:0}
.status-icon{font-size:21px;line-height:1}
.status-row b{display:block;margin-bottom:3px}
.status-row span{color:var(--muted);font-size:13px;line-height:1.5}
.notice{padding:13px 14px;border-radius:14px;font-size:13px;line-height:1.65}
.notice.info{background:var(--blue-soft);color:#265b82;border:1px solid #cfe3f2}
.notice.warn{background:var(--orange-soft);color:#86531e;border:1px solid #f3d1a4}
.notice.good{background:var(--green-soft);color:#2e7040;border:1px solid #cae6d0}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:13px;font-weight:700}
.field small{font-size:11px;color:var(--muted);line-height:1.45}
.field input,.field select,.field textarea{width:100%;border:1px solid #d9e2dc;border-radius:12px;padding:11px 12px;background:#fff;color:var(--ink);outline:none}
.field textarea{min-height:90px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(90,166,106,.15)}
.field.full{grid-column:1/-1}
.unit-input{position:relative}
.unit-input input{padding-right:40px}
.unit-input span{position:absolute;right:13px;top:50%;transform:translateY(-50%);font-size:13px;color:var(--muted);pointer-events:none}
.section-divider{height:1px;background:var(--line);margin:18px 0}
.tabs{display:flex;gap:8px;overflow:auto;padding-bottom:3px;margin-bottom:14px}
.tab-button{border:1px solid var(--line);background:#fff;border-radius:999px;padding:8px 12px;white-space:nowrap;font-weight:700;font-size:13px;color:var(--muted)}
.tab-button.active{background:var(--green-soft);border-color:#bfe0c6;color:var(--green-dark)}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:14px}
table{border-collapse:collapse;width:100%;min-width:600px;background:#fff;font-size:13px}
th,td{padding:11px 12px;border-bottom:1px solid var(--line);text-align:right}
th{background:#f6f8f7;color:#52605a;font-size:12px;white-space:nowrap}
td:first-child,th:first-child{text-align:left}
tr:last-child td{border-bottom:0}
.empty{padding:27px;text-align:center;color:var(--muted);font-size:14px}
.score{font-size:30px;letter-spacing:2px;line-height:1.1}
.score.good{color:var(--green)}
.score.mid{color:var(--orange)}
.score.low{color:var(--red)}
.advice-list{padding:0;margin:10px 0 0;list-style:none}
.advice-list li{margin:8px 0;padding-left:23px;position:relative;line-height:1.55;font-size:14px}
.advice-list li:before{content:"✓";position:absolute;left:0;color:var(--green-dark);font-weight:900}
.progress{background:#ecf0ed;border-radius:999px;height:10px;overflow:hidden}
.progress > span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--green),#83c56e)}
.kpi-line{display:flex;justify-content:space-between;gap:10px;align-items:baseline;border-bottom:1px dashed var(--line);padding:8px 0}
.kpi-line:last-child{border-bottom:0}
.kpi-line span{color:var(--muted);font-size:13px}
.kpi-line b{font-size:16px}
.bottom-nav{position:fixed;left:50%;transform:translateX(-50%);bottom:0;width:min(1180px,100%);background:rgba(255,255,255,.95);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding:7px max(12px,env(safe-area-inset-left)) calc(7px + env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-right));display:flex;justify-content:space-around;z-index:10}
.nav-item{border:0;background:transparent;color:#728078;display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 6px;min-width:52px;font-size:11px}
.nav-item span{font-size:20px;line-height:1}
.nav-item b{font-weight:700}
.nav-item.active{color:var(--green-dark)}
.app-modal{border:0;border-radius:22px;max-width:min(620px,calc(100% - 28px));padding:0;box-shadow:0 22px 60px rgba(0,0,0,.25)}
.app-modal::backdrop{background:rgba(25,37,34,.34);backdrop-filter:blur(2px)}
.modal-inner{padding:20px;background:#fff;border-radius:22px}
.modal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:13px}
.modal-head h2{font-size:19px;margin:0}
.close-button{border:0;background:#f1f4f1;width:34px;height:34px;border-radius:50%;font-size:20px;color:var(--muted)}
.toast{position:fixed;left:50%;bottom:88px;transform:translateX(-50%) translateY(20px);background:#24362c;color:#fff;border-radius:999px;padding:10px 15px;font-size:13px;opacity:0;pointer-events:none;transition:.22s;z-index:30;box-shadow:0 8px 22px rgba(0,0,0,.2)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.hidden{display:none!important}
.muted{color:var(--muted)}
.danger-text{color:#ae3d3d}
.good-text{color:var(--green-dark)}
@media (max-width:820px){
  .app-shell{padding:0 12px 88px}
  .brand h1{font-size:17px}
  .brand p{display:none}
  .mobile-menu{display:block}
  .grid.two,.grid.three,.summary-grid{grid-template-columns:1fr}
  .page-head{align-items:flex-start;flex-direction:column;gap:7px}
  .form-grid{grid-template-columns:1fr}
  .field.full{grid-column:auto}
  .card{padding:15px}
  .hero{padding:17px}
  .hero-title{font-size:19px}
  .summary-grid{gap:9px}
  .summary-box{display:grid;grid-template-columns:1fr auto;gap:2px 10px;align-items:baseline}
  .summary-box .label{margin:0}
  .summary-box .value{font-size:19px}
  .summary-box .note{grid-column:1/-1}
  .bottom-nav{padding-top:6px}
  .nav-item{min-width:0;font-size:9px}
  .nav-item span{font-size:18px}
}
