/* =====================================================================
   アツメル — アプリ共通スタイル（LINE_DESIGN準拠）
   ===================================================================== */
:root{
  --green:#06c755;--green-dark:#05b34c;--green-deep:#0a8f43;--green-soft:#e8f9ef;
  --danger:#d93025;--warning:#f9ab00;--warning-soft:#fef5e0;
  --text:#1a1a1a;--text-sub:#666;--text-mute:#999;
  --border:#e5e5e5;--bg:#fff;--surface:#f7f8f9;
  --radius:12px;--radius-lg:20px;
  --shadow-1:0 2px 8px rgba(0,0,0,.08);--shadow-2:0 4px 16px rgba(0,0,0,.12);--shadow-3:0 8px 24px rgba(0,0,0,.16);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{font-family:SFPro,Arial,"Noto Sans JP","Noto Sans KR",sans-serif;color:var(--text);
  background:var(--surface);-webkit-font-smoothing:antialiased;overflow-wrap:break-word;line-height:1.7}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
input,select,textarea,button{font-family:inherit}

/* ---- ボタン ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;border:none;
  cursor:pointer;border-radius:12px;transition:.12s;text-align:center;line-height:1.3;text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-dark)}
.btn-ghost{background:#fff;color:var(--text);border:1px solid var(--border)}
.btn-ghost:hover{background:var(--surface)}
.btn-danger{background:#fff;color:var(--danger);border:1px solid #f3c3bf}
.btn-danger:hover{background:#fdeceb}
.btn-block{width:100%}
.btn-xl{min-height:64px;font-size:20px;padding:16px 28px;border-radius:16px}
.btn-lg{min-height:52px;font-size:17px;padding:12px 24px}
.btn-md{min-height:44px;font-size:15px;padding:10px 18px;border-radius:10px}
.btn-sm{min-height:36px;font-size:13px;padding:6px 14px;border-radius:8px}

/* ---- バッジ ---- */
.badge{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:13px;padding:5px 12px;border-radius:999px;white-space:nowrap}
.badge .dot{width:8px;height:8px;border-radius:50%}
.badge-done{background:var(--green-soft);color:var(--green-dark)} .badge-done .dot{background:var(--green)}
.badge-partial{background:var(--warning-soft);color:#9a6a00} .badge-partial .dot{background:var(--warning)}
.badge-none{background:#f0f1f3;color:#888} .badge-none .dot{background:#bbb}
.badge-late{background:#fdeceb;color:var(--danger)} .badge-late .dot{background:var(--danger)}

/* ---- プログレス ---- */
.progress{height:10px;background:#eceef0;border-radius:999px;overflow:hidden}
.progress > span{display:block;height:100%;background:var(--green);border-radius:999px}

/* ---- フラッシュ ---- */
.flash{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:200;background:#fff;
  border:1px solid var(--border);border-left:4px solid var(--green);border-radius:10px;padding:14px 20px;
  box-shadow:var(--shadow-2);font-weight:700;font-size:14px;max-width:90%}
.flash.err{border-left-color:var(--danger)}

/* =====================================================================
   管理レイアウト
   ===================================================================== */
.layout{display:flex;min-height:100vh}
.side{width:248px;flex:none;background:#fff;border-right:1px solid var(--border);padding:22px 16px;
  display:flex;flex-direction:column;gap:6px;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 18px}
.brand .mk{width:38px;height:38px;border-radius:10px;background:var(--green);color:#fff;display:flex;
  align-items:center;justify-content:center;font-weight:800;font-size:18px}
.brand .nm{font-weight:800;font-size:18px}
.brand .nm small{display:block;font-size:11px;color:var(--text-mute);font-weight:600}
.nav{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:10px;font-weight:700;
  font-size:14px;color:var(--text-sub)}
.nav .e{font-size:18px;width:20px;text-align:center}
.nav.active{background:var(--green-soft);color:var(--green-dark)}
.nav:hover:not(.active){background:var(--surface)}
.side .spacer{flex:1}
.side .me{display:flex;align-items:center;gap:10px;padding:10px;border-top:1px solid var(--border)}
.side .me .av{width:34px;height:34px;border-radius:50%;background:#dfe4ea;display:flex;align-items:center;
  justify-content:center;font-size:14px;font-weight:700;color:#667}
.side .me b{font-size:13px} .side .me span{font-size:11px;color:var(--text-mute)}

.main{flex:1;padding:28px 32px 60px;max-width:1200px}
.head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;gap:16px;flex-wrap:wrap}
.head h1{font-size:26px;font-weight:800}
.head .sub{font-size:14px;color:var(--text-sub);margin-top:4px}
.head .actions{display:flex;gap:10px;flex-wrap:wrap}

/* KPI */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.kpi{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-1);padding:18px 20px}
.kpi .lbl{font-size:13px;color:var(--text-sub);font-weight:700;display:flex;align-items:center;gap:7px}
.kpi .val{font-size:34px;font-weight:800;margin-top:8px;line-height:1}
.kpi .val small{font-size:15px;color:var(--text-mute);font-weight:700}
.kpi .bar{margin-top:12px}
.kpi.green .val{color:var(--green-dark)} .kpi.warn .val{color:#9a6a00} .kpi.dgr .val{color:var(--danger)}
.kpi .delta{font-size:12px;color:var(--text-mute);margin-top:8px}

/* ツールバー */
.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{font-size:13px;font-weight:700;padding:8px 14px;border-radius:999px;border:1px solid var(--border);
  background:#fff;color:var(--text-sub);cursor:pointer}
.chip.on{background:var(--text);color:#fff;border-color:var(--text)}

/* パネル/テーブル */
.panel{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-1);overflow:hidden}
table{width:100%;border-collapse:collapse}
thead th{text-align:left;font-size:12px;color:var(--text-mute);font-weight:700;padding:14px 18px;
  border-bottom:1px solid var(--border);background:#fafbfc;letter-spacing:.03em}
tbody td{padding:16px 18px;border-bottom:1px solid var(--border);font-size:14px;vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:#fafbfc}
.cclient{display:flex;align-items:center;gap:12px}
.cclient .av{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:15px;color:#fff;flex:none}
.cclient b{font-size:15px;display:block} .cclient span{font-size:12px;color:var(--text-mute)}
.pcell{min-width:170px}
.pcell .t{display:flex;justify-content:space-between;font-size:12px;margin-bottom:6px;color:var(--text-sub)}
.pcell .t b{color:var(--text)}
.due{font-weight:700} .due .small{display:block;font-size:11px;color:var(--text-mute);font-weight:600}
.due.red{color:var(--danger)}
.rowact{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}
.empty{padding:50px;text-align:center;color:var(--text-mute)}
.linkpill{font-family:monospace;font-size:12px;background:var(--surface);border:1px solid var(--border);
  border-radius:8px;padding:4px 10px;color:var(--text-sub);word-break:break-all}

/* =====================================================================
   フォーム
   ===================================================================== */
.crumb{font-size:13px;color:var(--text-mute);margin-bottom:6px}
.crumb a{color:var(--text-sub);font-weight:700}
.step{margin-bottom:30px}
.step .sh{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.step .sh .n{width:28px;height:28px;border-radius:50%;background:var(--text);color:#fff;display:flex;
  align-items:center;justify-content:center;font-weight:800;font-size:14px}
.step .sh b{font-size:18px;font-weight:800}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:4px}
.field label{display:block;font-size:13px;font-weight:700;color:var(--text-sub);margin-bottom:8px}
.inp{width:100%;height:48px;border:1px solid var(--border);border-radius:8px;padding:0 14px;font-size:15px;
  background:#fff;color:var(--text)}
.inp:focus{outline:none;border-color:var(--green)}
textarea.inp{height:auto;padding:12px 14px;min-height:90px;line-height:1.6}

.tmpls{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.tmpl{background:#fff;border:2px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-1);
  padding:18px;cursor:pointer;transition:.12s;display:block}
.tmpl:hover{border-color:#cfd4da}
.tmpl input{display:none}
.tmpl.sel{border-color:var(--green);background:var(--green-soft)}
.tmpl .e{font-size:28px} .tmpl b{display:block;font-size:16px;margin:10px 0 4px} .tmpl span{font-size:12px;color:var(--text-sub)}
.tmpl .cnt{margin-top:10px;font-size:11px;color:var(--green-dark);font-weight:700}

.items{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-1);overflow:hidden}
.itgroup{display:none} .itgroup.show{display:block}
.items .it{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border);cursor:pointer}
.items .it:last-child{border-bottom:none}
.items .it input{display:none}
.chk{width:24px;height:24px;border-radius:7px;background:#fff;border:1.5px solid var(--border);display:flex;
  align-items:center;justify-content:center;font-size:15px;font-weight:800;flex:none;color:#fff}
.items .it.on .chk{background:var(--green);border-color:var(--green)}
.items .it .ic{font-size:20px} .items .it b{font-size:15px} .items .it .req{font-size:12px;color:var(--text-mute);margin-left:auto}

.clients{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.cl{display:flex;align-items:center;gap:10px;background:#fff;border:2px solid var(--border);border-radius:10px;
  padding:10px 12px;cursor:pointer}
.cl input{display:none}
.cl.on{border-color:var(--green);background:var(--green-soft)}
.cl .av{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:800;font-size:13px;flex:none}
.cl b{font-size:14px} .cl .ck{margin-left:auto;width:20px;height:20px;border-radius:6px;border:1.5px solid var(--border);
  background:#fff;color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px}
.cl.on .ck{background:var(--green);border-color:var(--green)}

.chan{display:flex;gap:12px}
.ch-opt{flex:1;background:#fff;border:2px solid var(--green);border-radius:var(--radius);padding:16px;
  display:flex;align-items:center;gap:12px;background:var(--green-soft)}
.ch-opt .e{font-size:24px} .ch-opt b{font-size:15px;display:block} .ch-opt span{font-size:12px;color:var(--text-sub)}
.preview{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-1);
  padding:20px;font-size:14px;line-height:1.9}
.preview .ph{font-size:12px;color:var(--text-mute);font-weight:700;margin-bottom:10px}
.preview .link{color:var(--green-dark);font-weight:700;word-break:break-all}
.formbar{position:sticky;bottom:0;background:#fff;border-top:1px solid var(--border);margin:0 -32px -60px;
  padding:16px 32px;display:flex;align-items:center;gap:14px;box-shadow:0 -4px 16px rgba(0,0,0,.05)}
.formbar .info{font-size:14px;color:var(--text-sub)} .formbar .info b{color:var(--text)} .formbar .sp{flex:1}

/* =====================================================================
   ログイン
   ===================================================================== */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(165deg,#0a8f43,#06c755 70%,#2ad972)}
.login .box{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-3);padding:40px;width:380px;max-width:92%}
.login .lg{display:flex;align-items:center;gap:10px;justify-content:center;margin-bottom:6px}
.login .lg .mk{width:44px;height:44px;border-radius:12px;background:var(--green);color:#fff;display:flex;
  align-items:center;justify-content:center;font-weight:800;font-size:22px}
.login .lg b{font-size:24px;font-weight:800}
.login .tag{text-align:center;color:var(--text-mute);font-size:13px;margin-bottom:26px}
.login label{font-size:13px;font-weight:700;color:var(--text-sub);display:block;margin-bottom:8px}
.login .hint{font-size:12px;color:var(--text-mute);margin-top:14px;text-align:center}

/* =====================================================================
   顧客モバイル画面
   ===================================================================== */
.cscreen{max-width:480px;margin:0 auto;min-height:100vh;background:var(--surface);display:flex;flex-direction:column}
.appbar{position:sticky;top:0;z-index:10;background:#fff;border-bottom:1px solid var(--border);padding:14px 18px;
  display:flex;align-items:center;gap:10px}
.appbar .logo{width:30px;height:30px;border-radius:8px;background:var(--green);display:flex;align-items:center;
  justify-content:center;color:#fff;font-weight:800;font-size:16px}
.appbar .office{font-weight:700;font-size:16px}
.appbar .secure{margin-left:auto;font-size:12px;color:var(--green-dark);font-weight:700}
.appbar .back{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-size:24px;color:var(--text)}
.appbar .title{font-weight:700;font-size:17px}
.cwrap{padding:18px 18px 120px;display:flex;flex-direction:column;gap:16px}

.hello{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-1);border:1px solid var(--border);padding:22px}
.hello .hi{font-size:18px;font-weight:700;margin-bottom:4px}
.hello .lead{font-size:15px;color:var(--text-sub);line-height:1.6}
.hello .lead b{color:var(--text)}
.deadline{margin-top:16px;background:var(--green-soft);border-radius:14px;padding:14px 16px;display:flex;align-items:center;gap:14px}
.deadline .cal{width:46px;height:46px;border-radius:12px;background:#fff;border:1px solid #cdeedd;display:flex;
  flex-direction:column;align-items:center;justify-content:center;line-height:1}
.deadline .cal b{font-size:17px;color:var(--green-dark)} .deadline .cal span{font-size:10px;color:var(--green-dark);margin-top:2px}
.deadline .dtxt b{font-size:16px;display:block} .deadline .dtxt span{font-size:13px;color:var(--text-sub)}
.deadline .left{margin-left:auto;text-align:center}
.deadline .left b{font-size:22px;color:var(--green-dark);display:block;line-height:1} .deadline .left span{font-size:11px;color:var(--green-dark)}
.deadline.over{background:#fdeceb} .deadline.over .left b,.deadline.over .cal b,.deadline.over .cal span,.deadline.over .left span{color:var(--danger)}
.deadline.over .cal{border-color:#f3c3bf}

.prog{display:flex;flex-direction:column;gap:8px;padding:0 2px}
.prog .row{display:flex;justify-content:space-between;align-items:baseline}
.prog .row b{font-size:15px} .prog .row span{font-size:13px;color:var(--text-sub)}
.sec-h{font-size:15px;font-weight:700;color:var(--text-sub);margin:6px 2px -2px}

.doc{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-1);padding:18px}
.doc.is-done{background:#fbfdfb;border-color:#d9eede}
.doc .top{display:flex;align-items:flex-start;gap:12px}
.doc .ico{width:44px;height:44px;border-radius:12px;background:var(--surface);display:flex;align-items:center;
  justify-content:center;font-size:22px;flex:none}
.doc .ttl{font-size:18px;font-weight:700;line-height:1.35}
.doc .note{font-size:13px;color:var(--text-sub);margin-top:3px;line-height:1.5}
.doc .st{margin-left:auto;flex:none}
.doc .act{margin-top:14px}
.doc .done-line{margin-top:12px;display:flex;align-items:center;gap:8px;color:var(--green-dark);font-weight:700;font-size:14px}

.help{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 18px;box-shadow:var(--shadow-1)}
.help .q{width:40px;height:40px;border-radius:50%;background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:20px}
.help b{font-size:15px;display:block} .help span{font-size:13px;color:var(--text-sub)}
.help .tel{margin-left:auto;color:var(--green-dark);font-weight:800;font-size:15px}

.footbar{position:fixed;left:0;right:0;bottom:0;max-width:480px;margin:0 auto;background:#fff;
  border-top:1px solid var(--border);padding:12px 18px 18px;box-shadow:0 -4px 16px rgba(0,0,0,.06)}
.footbar .small{text-align:center;font-size:12px;color:var(--text-mute);margin-top:8px}

/* アップロード画面 */
.what{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-1);
  padding:18px;display:flex;gap:12px;align-items:flex-start}
.what .ico{width:48px;height:48px;border-radius:12px;background:var(--surface);display:flex;align-items:center;
  justify-content:center;font-size:24px;flex:none}
.what .ttl{font-size:19px;font-weight:700} .what .note{font-size:14px;color:var(--text-sub);margin-top:4px;line-height:1.6}
.step-h{font-size:15px;font-weight:700;color:var(--text-sub);margin:2px 2px -4px}
.pick{display:flex;flex-direction:column;gap:12px}
.pick .pk{justify-content:flex-start;gap:14px;font-size:19px;position:relative;overflow:hidden}
.pick .pk .e{font-size:26px}
.pick .pk .col{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2}
.pick .pk .sub{font-size:13px;font-weight:500;opacity:.85;margin-top:2px}
.pick .pk input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.picked{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-1);padding:16px}
.picked .ph{font-size:14px;font-weight:700;color:var(--text-sub);margin-bottom:12px;display:flex;justify-content:space-between}
.picked .ph .cnt{color:var(--green-dark)}
.fileslist{display:flex;flex-direction:column;gap:8px}
.fileitem{display:flex;align-items:center;gap:10px;font-size:14px;background:var(--surface);border-radius:8px;padding:8px 12px}
.fileitem .x{font-size:20px} .fileitem .nm{flex:1;word-break:break-all} .fileitem .sz{font-size:12px;color:var(--text-mute)}

/* 完了画面 */
.center{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:30px 26px 40px}
.check{width:120px;height:120px;border-radius:50%;background:var(--green-soft);display:flex;align-items:center;
  justify-content:center;margin-bottom:24px;position:relative}
.check::after{content:"";width:84px;height:84px;border-radius:50%;background:var(--green);position:absolute}
.check .mark{position:relative;z-index:2;color:#fff;font-size:46px;font-weight:900}
.big{font-size:30px;font-weight:800;margin-bottom:12px}
.csub{font-size:16px;color:var(--text-sub);line-height:1.8;margin-bottom:8px}
.summary{width:100%;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-1);
  padding:8px 20px;margin:24px 0 8px;text-align:left}
.summary .row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.summary .row:last-child{border-bottom:none}
.summary .ic{width:38px;height:38px;border-radius:10px;background:var(--green-soft);display:flex;align-items:center;
  justify-content:center;font-size:18px;flex:none}
.summary .nm{font-weight:700;font-size:16px} .summary .meta{font-size:13px;color:var(--text-sub)}
.summary .ok{margin-left:auto;color:var(--green-dark);font-weight:800;font-size:14px}
.cnote{font-size:13px;color:var(--text-mute);margin-top:18px;line-height:1.7}

@media(max-width:1024px){.kpis{grid-template-columns:repeat(2,1fr)}.tmpls{grid-template-columns:repeat(2,1fr)}.clients{grid-template-columns:repeat(2,1fr)}.grid2{grid-template-columns:1fr}}
@media(max-width:720px){.side{display:none}.main{padding:20px 16px 60px}}
