/* ================================================
   FUKUROWA — 管理画面 (Admin)
   ================================================ */
:root{
  --navy:#111e33; --navy-soft:#1b2c4a; --gold:#bc9c6a; --gold-dark:#a8854f;
  --action:#ffce34; --action-dark:#f0bb12;
  --ink:#2b2f36; --ink-dim:#5f6671; --line:#e7e8ec; --paper:#f6f7f9; --white:#fff;
  --radius:14px;
  --font:"Hiragino Sans","Hiragino Kaku Gothic ProN","Noto Sans JP",system-ui,-apple-system,"Segoe UI",sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none !important}
body{font-family:var(--font);color:var(--ink);background:var(--paper);line-height:1.7;-webkit-font-smoothing:antialiased}
a{color:var(--gold-dark);text-decoration:none}

/* header */
.app-header{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;
  height:60px;padding:0 1.2rem;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.app-logo{height:20px;width:auto;display:block}
.app-head-right{display:flex;align-items:center;gap:1rem}
.lang-switch{display:flex;gap:.3rem}
.lang-btn{background:none;border:1px solid var(--line);border-radius:999px;padding:.2rem .6rem;font-size:.76rem;color:var(--ink-dim);cursor:pointer;font-family:inherit}
.lang-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.app-user{display:flex;align-items:center;gap:.9rem;font-size:.9rem;color:var(--ink-dim)}

/* buttons */
.btn-primary{display:inline-flex;align-items:center;gap:.4rem;background:var(--action);color:var(--navy);
  border:none;border-radius:999px;padding:.6rem 1.2rem;font-weight:700;font-size:.92rem;cursor:pointer;font-family:inherit;transition:.15s}
.btn-primary:hover{background:var(--action-dark)}
.btn-ghost-sm{background:none;border:1px solid var(--line);border-radius:999px;padding:.35rem .85rem;
  font-size:.85rem;color:var(--ink);cursor:pointer;font-family:inherit}
.btn-ghost-sm:hover{border-color:var(--gold)}
.btn-row{display:flex;gap:.6rem;justify-content:flex-end;margin-top:1.2rem}

.muted{color:var(--ink-dim);font-size:.9rem}
.hamburger{background:none;border:none;font-size:22px;line-height:1;cursor:pointer;color:var(--navy);margin-right:.1rem}

/* shell: sidebar + content */
.verify-banner{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;background:#fff8ec;border-bottom:1px solid #f0dcae;color:#8a6212;font-size:.85rem;padding:.6rem 1.2rem}
.verify-banner .vb-text{flex:1;min-width:0}
.verify-banner .vb-send{background:var(--gold);color:var(--navy);border:none;border-radius:999px;padding:.35rem .9rem;font-family:inherit;font-size:.8rem;font-weight:700;cursor:pointer;white-space:nowrap}
.verify-banner .vb-send:hover{background:var(--action)}
.verify-banner .vb-send:disabled{opacity:.6;cursor:default}
.verify-banner .vb-msg{font-size:.8rem;color:#6b5a2e}
.verify-banner .vb-close{background:none;border:none;font-size:18px;line-height:1;color:#8a6212;cursor:pointer;padding:0 .2rem}
.app-shell{display:flex;align-items:flex-start;min-height:calc(100vh - 60px)}
.sidebar{position:sticky;top:60px;align-self:flex-start;flex:none;width:240px;height:calc(100vh - 60px);
  overflow-y:auto;background:var(--white);border-right:1px solid var(--line);padding:1.2rem .9rem;display:flex;flex-direction:column;gap:.3rem}
.side-site{margin-bottom:.7rem;padding-top:.5rem}
.side-site-label{display:block;font-size:.68rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:.35rem;padding-left:.7rem}
#site-select{width:100%;padding:.55rem 2rem .55rem .7rem;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.9rem;color:var(--ink);cursor:pointer;
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4.5l4 4 4-4' fill='none' stroke='%235f6671' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 12px center;background-size:11px}
#site-select::-ms-expand{display:none}
.side-nav{display:flex;flex-direction:column;gap:.12rem}
.side-link{display:flex;align-items:center;gap:.6rem;padding:.5rem .7rem;border-radius:9px;font-size:.9rem;color:var(--ink);cursor:pointer;font-family:inherit;background:none;border:none;text-align:left;width:100%}
.side-link .ic{width:17px;height:17px;flex:none;opacity:.85}
.side-link.active .ic{opacity:1}
.sec-head h1{display:flex;align-items:center;gap:.55rem}
.sec-head h1 .ic{width:22px;height:22px;flex:none;color:var(--gold-dark)}
.side-link:hover{background:var(--paper)}
.side-link.active{background:var(--navy);color:#fff;font-weight:700}
.side-link.disabled{opacity:.38;pointer-events:none}
.side-sep{height:1px;background:var(--line);margin:.55rem .2rem}
.side-gap{height:.55rem}
.side-cap{font-size:.66rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-dim);padding:.2rem .7rem;margin-top:.2rem}
.side-soon{font-size:.62rem;border:1px solid var(--line);border-radius:6px;padding:0 .35rem;color:var(--ink-dim);margin-left:auto}
.app-content{flex:1;min-width:0;padding:2rem 1.6rem 4rem;max-width:1000px;margin:0 auto}
.dash{max-width:none}

/* section header (content views) */
.sec-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.4rem;flex-wrap:wrap}
.sec-head h1{font-size:1.4rem;color:var(--navy)}
.sec-head .crumb{font-size:.82rem;color:var(--ink-dim);margin-bottom:.15rem}
.sec-head-r{display:flex;align-items:center;gap:.8rem}
.agent-count{font-size:.85rem;color:var(--ink-dim)}
.conv-month{padding:.4rem .6rem;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:.85rem;background:#fff;color:var(--ink);cursor:pointer}
.conv-month:focus{outline:none;border-color:var(--gold)}
.agent-count.at-limit{color:#c0392b;font-weight:700}
.btn-primary:disabled{opacity:.5;cursor:default}
.btn-primary:disabled:hover{background:var(--action)}
.sec-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem 1.4rem;margin-bottom:1.2rem}
.quick-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}
.quick-card{display:block;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem 1.2rem;cursor:pointer;text-align:left;font-family:inherit}
.quick-card:hover{border-color:var(--gold)}
.quick-card .qc-t{font-weight:800;color:var(--navy);margin-bottom:.2rem}
.quick-card .qc-d{font-size:.82rem;color:var(--ink-dim)}

/* knowledge tabs */
.kn-tabs{display:flex;gap:.3rem;flex-wrap:wrap;border-bottom:1px solid var(--line);margin-bottom:1.3rem}
.kn-tab{background:none;border:none;border-bottom:2px solid transparent;padding:.6rem .9rem;font-family:inherit;font-size:.9rem;font-weight:600;color:var(--ink-dim);cursor:pointer;margin-bottom:-1px}
.kn-tab:hover{color:var(--navy)}
.kn-tab.active{color:var(--navy);border-bottom-color:var(--gold)}
.kn-add{background:var(--white);border:1px solid var(--line);border-radius:12px;padding:1.2rem;margin-bottom:1.4rem}
.kn-add-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.3rem}
.kn-add-title{font-size:.82rem;font-weight:800;letter-spacing:.04em;color:var(--gold-dark);text-transform:uppercase}
.kn-faq-alabel{display:flex;align-items:center;gap:.6rem}
.kn-faq-ai{background:var(--navy);color:#fff;border:none;border-radius:999px;padding:.25rem .7rem;font-size:.76rem;font-weight:700;cursor:pointer;font-family:inherit}
.kn-faq-ai:hover{background:var(--navy-soft)}
.kn-faq-ai:disabled{opacity:.55;cursor:default}
.kn-faq-status{font-size:.8rem;margin:-.5rem 0 .8rem}
.kn-list{margin-bottom:1.4rem}
.kn-exclude{margin-top:1rem;background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:.85rem 1rem}
.kn-ex-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.7rem}
.kn-ex-chip{display:inline-flex;align-items:center;gap:.4rem;background:#fff;border:1px solid var(--line);border-radius:999px;padding:.2rem .3rem .2rem .7rem;font-size:.82rem}
.kn-ex-chip code{font-family:ui-monospace,Menlo,Consolas,monospace;color:var(--navy)}
.kn-ex-chip button{background:#eef0f3;border:none;border-radius:50%;width:18px;height:18px;line-height:1;color:var(--ink-dim);cursor:pointer;font-size:13px}
.kn-ex-chip button:hover{background:#e0533d;color:#fff}
.kn-ex-add{display:flex;gap:.5rem}
.kn-ex-add input{flex:1;min-width:0;padding:.5rem .7rem;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:.88rem;background:#fff}
.kn-ex-add input:focus{outline:none;border-color:var(--gold)}
.pg-search{flex:1;min-width:140px;padding:.4rem .7rem;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:.85rem;background:#fff}
.pg-search:focus{outline:none;border-color:var(--gold)}

/* pagination toolbar */
.pg-bar{display:flex;gap:1.2rem;flex-wrap:wrap;margin-bottom:1rem}
.pg-ctl{font-size:.82rem;color:var(--ink-dim);display:flex;align-items:center;gap:.45rem}
.pg-ctl select{padding:.4rem 1.7rem .4rem .7rem;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:.85rem;color:var(--ink);cursor:pointer;
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4.5l4 4 4-4' fill='none' stroke='%235f6671' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 9px center;background-size:10px}
.pg-ctl select::-ms-expand{display:none}
/* 言語セレクター */
.lang-select{border:1px solid var(--line);border-radius:999px;padding:.32rem 1.7rem .32rem .8rem;font-family:inherit;font-size:.8rem;color:var(--ink);cursor:pointer;
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4.5l4 4 4-4' fill='none' stroke='%235f6671' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 9px center;background-size:10px}
.lang-select:focus{outline:none;border-color:var(--gold)}
.lang-select::-ms-expand{display:none}
.pg-cap{font-size:.78rem;color:#9a6b1e;background:#fff8ec;border:1px solid #f0dcae;border-radius:8px;padding:.45rem .65rem;margin-bottom:.8rem}
.pg-foot{display:flex;align-items:center;justify-content:center;gap:1.2rem;margin-top:1.2rem}
.pg-foot button{background:none;border:1px solid var(--line);border-radius:8px;padding:.4rem .95rem;font-family:inherit;font-size:.85rem;color:var(--ink);cursor:pointer}
.pg-foot button:hover:not(:disabled){border-color:var(--gold)}
.pg-foot button:disabled{opacity:.4;cursor:default}
.pg-info{font-size:.82rem;color:var(--ink-dim);min-width:7.5rem;text-align:center}

/* improvement insights */
.an-ins-body{margin-top:1rem;display:grid;gap:.7rem}
.an-ins-card{border:1px solid var(--line);border-radius:10px;padding:.85rem 1rem;background:var(--paper)}
.an-ins-head{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem;flex-wrap:wrap}
.an-ins-type{font-size:.66rem;font-weight:800;color:var(--gold-dark);border:1px solid var(--line);border-radius:6px;padding:.05rem .45rem;background:#fff}
.an-ins-head b{color:var(--navy);font-size:.95rem}
.an-ins-card p{font-size:.85rem;color:var(--ink-dim);margin-bottom:.5rem;line-height:1.6}
.an-ins-raw{font-size:.88rem;line-height:1.7;color:var(--ink)}

/* analytics chart */
.an-chart{display:flex;align-items:flex-end;gap:4px;height:150px;padding:.4rem 0 0;overflow-x:auto}
.an-bar{flex:1;min-width:13px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}
.an-bar>span{width:68%;background:var(--gold);border-radius:4px 4px 0 0;min-height:2px}
.an-bar>em{font-size:.58rem;color:var(--ink-dim);margin-top:4px;font-style:normal;white-space:nowrap}

/* conversation modal */
.conv-preview{color:var(--ink-dim)}
.modal-overlay{position:fixed;inset:0;background:rgba(17,30,51,.45);z-index:50;animation:ovIn .2s ease}
.modal-overlay.closing{animation:ovOut .18s ease forwards}
.cmodal{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:51;width:min(720px,94vw);max-height:84vh;
  background:#fff;border-radius:16px;box-shadow:0 30px 80px -24px rgba(17,30,51,.55);display:flex;flex-direction:column;overflow:hidden;animation:cmodalIn .22s cubic-bezier(.2,.8,.3,1)}
.cmodal.closing{animation:cmodalOut .18s ease forwards}
@keyframes ovIn{from{opacity:0}to{opacity:1}}
@keyframes ovOut{from{opacity:1}to{opacity:0}}
@keyframes cmodalIn{from{opacity:0;transform:translate(-50%,-46%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
@keyframes cmodalOut{from{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-46%) scale(.96)}}
.cmodal-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.1rem 1.4rem;border-bottom:1px solid var(--line);flex:none}
.cmodal-head h2{font-size:1.05rem;color:var(--navy);display:flex;align-items:center;gap:.45rem}
.cmodal-head h2 .ic{width:19px;height:19px;flex:none;color:var(--gold-dark)}
.cmodal-close{background:none;border:none;font-size:26px;line-height:1;color:var(--ink-dim);cursor:pointer}
.cmodal-body{padding:1.3rem 1.4rem;overflow-y:auto;flex:1;background:var(--paper)}
@media(max-width:560px){
  .cmodal{width:100vw;height:100vh;max-height:none;border-radius:0;top:0;left:0;transform:none}
  @keyframes cmodalIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
  @keyframes cmodalOut{from{opacity:1;transform:none}to{opacity:0;transform:translateY(18px)}}
}

/* confirm modal */
.confirm-modal{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:51;width:min(400px,92vw);
  background:#fff;border-radius:14px;box-shadow:0 30px 80px -24px rgba(17,30,51,.55);padding:1.6rem}
.confirm-modal p{color:var(--ink);line-height:1.7;margin-bottom:1.3rem}
.confirm-modal .cancel{background:none;border:1px solid var(--line);border-radius:999px;padding:.6rem 1.1rem;cursor:pointer;font-family:inherit}
.btn-danger{background:#e0533d;color:#fff;border:none;border-radius:999px;padding:.6rem 1.2rem;font-weight:700;font-size:.92rem;cursor:pointer;font-family:inherit}
.btn-danger:hover{background:#c0392b}

/* drawer (slide-over) */
.drawer-overlay{position:fixed;inset:0;background:rgba(17,30,51,.4);z-index:40;opacity:0;transition:opacity .25s}
.drawer-overlay.open{opacity:1}
.drawer{position:fixed;top:0;right:0;height:100vh;width:min(460px,100vw);z-index:41;background:#fff;
  box-shadow:-16px 0 50px -24px rgba(17,30,51,.5);transform:translateX(100%);
  transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.drawer.open{transform:translateX(0)}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.4rem;border-bottom:1px solid var(--line);flex:none}
.drawer-head h2{font-size:1.1rem;color:var(--navy)}
.drawer-close{background:none;border:none;font-size:26px;line-height:1;color:var(--ink-dim);cursor:pointer}
.drawer-body{padding:1.4rem;overflow-y:auto;flex:1}
.form-note{font-size:.8rem;line-height:1.6;color:var(--ink-dim);background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:.6rem .75rem;margin-bottom:1.1rem}
.fk-form label{display:block;font-size:.85rem;font-weight:600;color:var(--navy);margin-bottom:1rem}
.fk-form input,.fk-form textarea,.fk-form select{display:block;width:100%;margin-top:.35rem;
  padding:.65rem .8rem;border:1px solid var(--line);border-radius:10px;font-size:.95rem;font-family:inherit;background:#fff}
.fk-form input:focus,.fk-form textarea:focus,.fk-form select:focus{outline:none;border-color:var(--gold)}
.fk-form select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:2rem;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4.5l4 4 4-4' fill='none' stroke='%235f6671' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;background-size:11px}
.fk-form select::-ms-expand{display:none}
.fk-form input[type="color"]{height:48px;padding:4px;cursor:pointer}
.fk-form label.chk{display:flex;align-items:center;gap:.5rem;font-weight:600;margin-bottom:.7rem}
.fk-form label.chk input{width:auto;margin:0}
.fk-form .cancel{background:none;border:1px solid var(--line);border-radius:999px;padding:.6rem 1.1rem;cursor:pointer;font-family:inherit}

/* インライン編集（アコーディオン）: エージェントカード内で開く */
.agent-edit{max-height:0;overflow:hidden;transition:max-height .32s ease}
.agent-edit form{border-top:1px solid var(--line);margin-top:.7rem;padding-top:1rem}
#agent-add-panel.open{margin-bottom:1.2rem}
#agent-add-panel form{border:1px solid var(--line);border-radius:12px;background:var(--white);margin-top:0;padding:1.2rem}

/* responsive: off-canvas sidebar */
@media(max-width:760px){
  .sidebar{position:fixed;top:60px;left:0;z-index:26;transform:translateX(-100%);transition:transform .25s;
    box-shadow:8px 0 30px -16px rgba(17,30,51,.4)}
  .app-shell.nav-open .sidebar{transform:translateX(0)}
  .sidebar-scrim{position:fixed;inset:60px 0 0;background:rgba(17,30,51,.35);z-index:25}
  .app-content{padding:1.4rem 1.1rem 3rem;max-width:none;width:100%}
  .drawer{width:100vw}
}
@media(min-width:761px){ .hamburger{display:none} .sidebar-scrim{display:none !important} }

/* auth */
.auth-wrap{position:relative;min-height:78vh;display:grid;place-items:center;overflow:hidden}
.auth-bg-logo{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:min(1240px,150vw);z-index:0;opacity:.9;pointer-events:none;
  filter:drop-shadow(0 22px 44px rgba(17,30,51,.15))}
.auth-card{position:relative;z-index:1;
  background:rgba(255,255,255,.6);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  backdrop-filter:blur(14px) saturate(140%);
  border:1px solid rgba(255,255,255,.7);border-radius:var(--radius);
  padding:2rem;width:min(420px,92vw);box-shadow:0 26px 64px -28px rgba(17,30,51,.45)}
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  .auth-card{background:rgba(255,255,255,.92)}
}
.auth-card h1{font-size:1.3rem;color:var(--navy);margin-bottom:.3rem}
.auth-sub{color:var(--ink-dim);font-size:.9rem;margin-bottom:1.3rem}
.auth-card label,.dlg label{display:block;font-size:.85rem;font-weight:600;color:var(--navy);margin-bottom:1rem}
.auth-card input,.dlg input,.dlg textarea,.dlg select{display:block;width:100%;margin-top:.35rem;
  padding:.65rem .8rem;border:1px solid var(--line);border-radius:10px;font-size:.95rem;font-family:inherit;background:#fff}
.auth-card input:focus,.dlg input:focus{outline:none;border-color:var(--gold)}
.dlg input[type="color"]{height:48px;padding:4px;cursor:pointer}
.auth-card .btn-primary{width:100%;justify-content:center;margin-top:.4rem}
.auth-switch{text-align:center;font-size:.88rem;color:var(--ink-dim);margin-top:1.1rem}
.auth-forgot{text-align:center;font-size:.84rem;margin-top:.7rem}
.auth-forgot a,.auth-switch a{color:var(--gold-dark);cursor:pointer}
.auth-error{background:#fff0f0;border:1px solid #f3c2c2;color:#c0392b;font-size:.85rem;
  padding:.6rem .8rem;border-radius:10px;margin-bottom:1rem}
.auth-error.ok{background:#eafaf0;border-color:#b7e4c7;color:#1b7a43}
.btn-google{display:flex;align-items:center;justify-content:center;gap:.6rem;width:100%;
  background:#fff;border:1px solid var(--line);border-radius:10px;padding:.7rem 1rem;
  font-family:inherit;font-size:.92rem;font-weight:600;color:var(--navy);cursor:pointer}
.btn-google:hover{background:var(--paper);border-color:#d8dade}
.btn-google .g-ico{display:inline-flex;flex:none}
.auth-or{display:flex;align-items:center;gap:.7rem;color:var(--ink-dim);font-size:.8rem;margin:1rem 0}
.auth-or::before,.auth-or::after{content:"";flex:1;height:1px;background:var(--line)}
.pw-card label{display:block;font-size:.85rem;font-weight:600;color:var(--navy);margin-bottom:.9rem;max-width:380px}
.pw-card input{display:block;width:100%;margin-top:.35rem;padding:.6rem .75rem;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.92rem}
.pw-card input:focus{outline:none;border-color:var(--gold)}
.pw-card .btn-primary{margin-top:.2rem}
.pw-card #pw-msg{max-width:380px}

/* dashboard */
.dash-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.6rem}
.stat-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem 1.2rem}
.stat-label{font-size:.78rem;color:var(--ink-dim);margin-bottom:.35rem}
.stat-value{font-size:1.5rem;font-weight:800;color:var(--navy);line-height:1.2}
.stat-bar{margin-top:.6rem;height:6px;background:var(--line);border-radius:999px;overflow:hidden}
.stat-bar span{display:block;height:100%;background:var(--action)}
.stat-alert{border-color:#f0c2c2;background:#fff6f6}
.stat-alert .stat-bar span{background:#e0533d}
.stat-warn{margin-top:.4rem;font-size:.72rem;font-weight:700;color:#c0392b}
.dash-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.6rem}
.dash-head h1{font-size:1.4rem;color:var(--navy)}
.empty{background:var(--white);border:1px dashed var(--line);border-radius:var(--radius);
  padding:2.5rem;text-align:center;color:var(--ink-dim)}

.site{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem 1.4rem;margin-bottom:1.2rem}
.site-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}
.site-name{font-size:1.1rem;font-weight:800;color:var(--navy)}
.site-url{font-size:.85rem;color:var(--ink-dim);word-break:break-all}
.site-actions{display:flex;align-items:center;gap:.6rem;flex:none}
.badge-soft{font-size:.7rem;font-weight:700;border:1px solid var(--line);border-radius:999px;padding:.1rem .55rem;color:var(--ink-dim)}
.badge-on{font-size:.7rem;font-weight:700;border:1px solid #b7e4c7;border-radius:999px;padding:.1rem .55rem;color:#1b7a43;background:#eafaf0}
.badge-on::before{content:"";display:inline-block;width:.42rem;height:.42rem;border-radius:50%;background:#2bae66;margin-right:.32rem;vertical-align:middle}
.agents{margin-top:1rem;border-top:1px solid var(--line);padding-top:1rem;display:grid;gap:.9rem}
.agent{background:var(--white);border:1px solid var(--line);border-radius:12px;padding:.9rem 1rem}
.ag-edit,.ag-del{background:var(--action);color:var(--navy);border:none;border-radius:8px;padding:.28rem .8rem;font-size:.8rem;font-weight:700;cursor:pointer;font-family:inherit}
.ag-edit:hover,.ag-del:hover{background:var(--action-dark);color:var(--navy)}
.agent-top{display:flex;align-items:center;justify-content:space-between;gap:.6rem;flex-wrap:wrap}
.agent-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.agent-name-wrap{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.agent-name{font-weight:700;color:var(--navy)}
.src-auth{margin:-.3rem 0 1rem;border:1px solid var(--line);border-radius:10px;padding:.6rem .8rem;background:#fafbfc}
.src-auth>summary{cursor:pointer;font-size:.85rem;font-weight:600;color:var(--navy);list-style:none}
.src-auth>summary::-webkit-details-marker{display:none}
.src-auth>summary::before{content:"＋ ";color:var(--gold-dark)}
.src-auth[open]>summary::before{content:"− "}
.src-auth[open]>summary{margin-bottom:.6rem}
.src-auth label{margin-bottom:.7rem}
.src-auth-safety{margin:.2rem 0 0;font-size:.78rem;line-height:1.5;color:#9a6b1e;background:#fff8ec;border:1px solid #f0dcae;border-radius:8px;padding:.5rem .65rem}
.ag-text{margin-bottom:1rem}
.ag-text-lbl{display:block;font-size:.85rem;font-weight:600;color:var(--navy);margin-bottom:.4rem}
.ag-text-row{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}
.ag-text-auto{display:flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:600;color:var(--navy);margin:0;flex:1;min-width:0;white-space:nowrap}
.ag-text-auto span{display:inline}
.ag-text-auto input[type="checkbox"]{width:auto;margin:0;flex:none}
.ag-text-row input[type="color"]{flex:none;width:64px;margin-top:0}
.ag-text-row input[type="color"]:disabled{opacity:.4}
.ag-text-note{margin-top:.5rem;font-size:.78rem}
.ag-text-warn{margin:.5rem 0 0;font-size:.78rem;line-height:1.5;color:#9a6b1e;background:#fff8ec;border:1px solid #f0dcae;border-radius:8px;padding:.5rem .65rem}
.ag-mark{margin-bottom:1rem}
.ag-mark-lbl{display:block;font-size:.85rem;font-weight:600;color:var(--navy);margin-bottom:.4rem}
.ag-mark-row{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}
.ag-mark-preview{width:52px;height:52px;border-radius:12px;object-fit:contain;background:#fff;border:1px solid var(--line);padding:4px;flex:none}
.ag-mark-row input[type="file"]{flex:1;min-width:0;font-size:.82rem;margin-top:0}
.ag-mark-note{margin-top:.5rem;font-size:.78rem}
.ag-mark-lock{margin-top:.5rem;font-size:.78rem;color:#9a6b1e;background:#fff8ec;border:1px solid #f0dcae;border-radius:8px;padding:.5rem .65rem}
.dlg label.chk{display:flex;align-items:center;gap:.5rem;font-weight:600;margin-bottom:.7rem}
.dlg label.chk input{width:auto;margin:0}
.agent-id{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.8rem;color:var(--gold-dark)}
.snippet-box{margin-top:.7rem;background:var(--navy);color:#c9d2e3;border-radius:10px;padding:.7rem .85rem;
  font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.78rem;white-space:pre-wrap;word-break:break-all;position:relative}
.copy{position:absolute;top:50%;right:.5rem;transform:translateY(-50%);background:var(--gold);color:var(--navy);border:none;border-radius:8px;
  font-size:.72rem;font-weight:700;padding:.32rem .7rem;cursor:pointer;font-family:var(--font);
  display:inline-flex;align-items:center;justify-content:center;line-height:1}
.copy:hover{background:var(--action)}
.domain-row{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}
.domain-row .domain-host{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:1.05rem;font-weight:700;color:var(--navy);word-break:break-all}
.domain-row .domain-link{cursor:pointer;margin-left:auto;white-space:nowrap}
.badge-warn{display:inline-block;font-size:.78rem;font-weight:700;color:#9a6b1e;background:#fff8ec;border:1px solid #f0dcae;border-radius:8px;padding:.4rem .65rem;margin:0}
.verify-origin{display:flex;align-items:center;justify-content:space-between;gap:.7rem;flex-wrap:wrap;padding:.6rem .8rem;border:1px solid var(--line);border-radius:10px;margin-bottom:.5rem;background:var(--white)}
.verify-origin .vo-host{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.85rem;color:var(--navy);word-break:break-all}
.verify-origin .vo-go{padding:.3rem .8rem;font-size:.78rem}
.verify-empty{margin:0}
.verify-manual{margin-top:1rem}
.verify-manual summary{cursor:pointer;font-weight:700;font-size:.88rem;color:var(--navy)}
/* 管理画面ヘルプAI */
.ah-launch{position:fixed;right:22px;bottom:22px;z-index:45;width:56px;height:56px;border-radius:50%;border:none;cursor:pointer;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:0;box-shadow:0 8px 24px rgba(17,30,51,.28),inset 0 0 0 3px var(--gold);transition:transform .15s}
.ah-launch:hover{transform:scale(1.06)}
.ah-teaser{position:fixed;right:22px;bottom:90px;z-index:45;width:min(280px,calc(100vw - 44px));background:#fff;border-radius:14px;padding:12px 32px 13px 14px;box-shadow:0 12px 34px rgba(17,30,51,.22);cursor:pointer;display:flex;flex-direction:column;gap:.25rem;animation:ahIn .25s cubic-bezier(.2,.8,.3,1)}
.ah-teaser:hover{box-shadow:0 14px 38px rgba(17,30,51,.28)}
.ah-teaser-name{font-weight:700;font-size:.85rem;color:var(--navy)}
.ah-teaser-body{font-size:.8rem;color:var(--ink-dim);line-height:1.55}
.ah-teaser-guide{font-size:.82rem;font-weight:700;color:var(--gold-dark);margin-top:.3rem;cursor:pointer;text-decoration:none}
.ah-teaser-guide:hover{text-decoration:underline}
.ah-teaser-close{position:absolute;top:5px;right:8px;background:none;border:none;font-size:18px;line-height:1;color:var(--ink-dim);cursor:pointer;padding:0}
.ah-launch img{width:70%;height:70%;object-fit:contain;pointer-events:none}
.ah-panel{position:fixed;right:22px;bottom:22px;z-index:46;width:min(370px,calc(100vw - 32px));height:min(560px,calc(100vh - 120px));background:#fff;border-radius:16px;box-shadow:0 30px 80px -24px rgba(17,30,51,.55);display:flex;flex-direction:column;overflow:hidden;animation:ahIn .22s cubic-bezier(.2,.8,.3,1)}
@keyframes ahIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
.ah-head{display:flex;align-items:center;gap:.6rem;padding:.8rem 1rem;background:var(--navy);color:#fff;flex:none}
.ah-head-img{width:30px;height:30px;border-radius:50%;background:#fff;object-fit:contain;padding:2px;flex:none}
.ah-head-title{font-weight:700;font-size:.95rem;flex:1;min-width:0}
.ah-close{background:none;border:none;color:#fff;font-size:22px;line-height:1;cursor:pointer;padding:0}
.ah-body{flex:1;overflow-y:auto;padding:1rem;background:var(--paper);display:flex;flex-direction:column;gap:.6rem}
.ah-msg{max-width:86%;padding:.6rem .8rem;border-radius:14px;font-size:.88rem;line-height:1.6;white-space:pre-wrap;word-break:break-word}
.ah-bot{align-self:flex-start;background:#fff;border:1px solid var(--line);color:var(--ink);border-bottom-left-radius:4px}
.ah-user{align-self:flex-end;background:var(--navy);color:#fff;border-bottom-right-radius:4px}
.ah-typing{color:var(--ink-dim);letter-spacing:.1em}
.ah-input{display:flex;gap:.5rem;padding:.7rem;border-top:1px solid var(--line);background:#fff;flex:none}
.ah-input input{flex:1;min-width:0;padding:.6rem .8rem;border:1px solid var(--line);border-radius:999px;font-family:inherit;font-size:.9rem}
.ah-input input:focus{outline:none;border-color:var(--gold)}
.ah-input button{flex:none;width:40px;height:40px;border-radius:50%;border:none;background:var(--gold);color:var(--navy);font-size:15px;cursor:pointer}
.ah-input button:hover{background:var(--action)}
@media(max-width:480px){.ah-panel{right:0;left:0;bottom:0;width:100vw;height:80vh;border-radius:16px 16px 0 0;margin:0 auto}}

/* 設置ガイド */
.side-sep-guide{margin-top:1.1rem}
.side-guide{color:var(--ink-dim);font-size:.9rem}
.side-guide .ic{opacity:.85}
.side-guide-prog{padding:.1rem .7rem .2rem}
.sg-prog-row{display:flex;align-items:center;justify-content:space-between;gap:.4rem;margin-bottom:.3rem}
.sg-prog-num{font-size:.72rem;font-weight:800;color:var(--ink-dim);letter-spacing:.02em}
.sg-prog-done{font-size:.66rem;font-weight:800;color:#1b7a43;background:#eafaf0;border:1px solid #b7e4c7;border-radius:6px;padding:.02rem .34rem}
.side-guide-prog .stat-bar{margin-top:0;height:5px}
.side-guide-prog .stat-bar.sg-done span{background:#2bae66}
.guide-complete{margin-top:.6rem;text-align:center;font-weight:800;font-size:.9rem;color:#1b7a43;background:#eafaf0;border:1px solid #b7e4c7;border-radius:10px;padding:.6rem}
.dash-guide{display:flex;align-items:center;gap:.9rem;background:#fff8ec;border:1px solid #f0dcae;border-radius:14px;padding:1rem 1.2rem;margin-bottom:1.3rem}
.dash-guide .ic{width:26px;height:26px;flex:none;color:var(--gold-dark)}
.dash-guide-txt{display:flex;flex-direction:column;gap:.1rem;min-width:0}
.dash-guide-txt strong{color:var(--navy);font-size:.95rem}
.dash-guide-txt .muted{font-size:.8rem}
.dash-guide .btn-primary{margin-left:auto;white-space:nowrap}
.guide-intro{font-size:.92rem;color:var(--ink);margin:0 0 1.1rem}
.guide-steps{list-style:none;margin:0;padding:0}
.guide-step{display:flex;gap:.9rem;position:relative;padding-bottom:1.1rem}
.guide-step:not(:last-child)::before{content:"";position:absolute;left:14px;top:30px;bottom:-2px;width:2px;background:var(--line)}
.guide-num{flex:none;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem;background:var(--line);color:var(--ink-dim);z-index:1}
.guide-step.done .guide-num{background:#2bae66;color:#fff}
.guide-step.current .guide-num{background:var(--gold);color:var(--navy)}
.guide-body{flex:1;padding-top:.2rem;min-width:0}
.guide-step-ttl{font-weight:700;color:var(--navy)}
.guide-step.todo{opacity:.5}
.guide-step.current .guide-step-ttl{color:var(--gold-dark)}
.guide-step-desc{font-size:.82rem;color:var(--ink-dim);margin:.15rem 0 .55rem;line-height:1.55}
.guide-go{font-size:.82rem;padding:.42rem 1rem}
.guide-done{font-size:.7rem}
.install-note{margin-top:1rem;background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:.85rem 1rem}
.install-note-ttl{display:block;font-size:.82rem;font-weight:700;color:var(--navy);margin-bottom:.3rem}
.install-note .snippet-help{margin:0}
.snippet-help{margin:.55rem 0 0;font-size:.78rem;line-height:1.65;color:var(--ink-dim)}
.snippet-help code{background:var(--paper);border:1px solid var(--line);border-radius:5px;padding:.05rem .3rem;font-size:.92em;color:var(--navy);font-family:ui-monospace,Menlo,Consolas,monospace}
.knowledge{margin-top:1rem;border-top:1px solid var(--line);padding-top:1rem}
.kn-title{font-size:.78rem;font-weight:800;letter-spacing:.06em;color:var(--gold-dark);text-transform:uppercase;margin-bottom:.6rem}
.kn-empty{font-size:.85rem;color:var(--ink-dim);margin-bottom:.6rem}
.kn-item{display:flex;flex-direction:column;gap:.3rem;padding:.7rem .9rem;border:1px solid var(--line);border-radius:12px;background:var(--white);font-size:.88rem;margin-bottom:.6rem}
.kn-row{display:flex;align-items:center;gap:.55rem}
.kn-ico{flex:none;display:inline-flex;align-items:center;color:var(--gold-dark);opacity:.9}
.kn-ico .ic{width:16px;height:16px}
.kn-meta{font-size:.72rem;color:var(--ink-dim);padding-left:1.6rem}
.kn-meta.err{color:#c0392b}
.kn-meta.kn-capped{color:#9a6b1e}
.kn-type{flex:none;font-size:.68rem;font-weight:800;color:var(--gold-dark);border:1px solid var(--line);border-radius:6px;padding:.05rem .4rem;min-width:3.2rem;text-align:center}
.kn-q{flex:1;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kn-item .kn-q{font-weight:700}
.kn-add-crawl-row{margin-top:.2rem}
.kn-add-crawl-hint{font-size:.76rem;margin:.1rem 0 .6rem}
.kn-crawl-tag{display:inline-block;font-size:.66rem;font-weight:800;color:var(--gold-dark);background:#fff8ec;border:1px solid #f0dcae;border-radius:6px;padding:.02rem .35rem;vertical-align:middle;margin-left:.3rem}
.kn-pg{color:var(--gold-dark)}
.kn-summary{margin:.2rem 0 1.1rem}
.kn-sum-row{display:flex;align-items:baseline;gap:.6rem;flex-wrap:wrap}
.kn-summary .kn-sum-pg{font-size:1.05rem;font-weight:800;color:var(--navy)}
.kn-summary .kn-sum-sep{font-size:.78rem;color:var(--ink-dim)}
.kn-summary .kn-sum-lim{font-size:.78rem;color:var(--ink-dim);margin-left:auto;white-space:nowrap}
.kn-st{flex:none;font-size:.72rem;font-weight:700;border-radius:999px;padding:.1rem .55rem;border:1px solid var(--line);color:var(--ink-dim)}
.kn-ready{color:#1a9d4b;border-color:#bfe6cd}
.kn-failed{color:#c0392b;border-color:#f0c2c2}
.kn-learning{color:#c98a00;border-color:#f0dca0}
.kn-btn{flex:none;background:none;border:1px solid var(--line);border-radius:7px;padding:.2rem .5rem;font-size:.75rem;color:var(--ink-dim);cursor:pointer;font-family:inherit}
.kn-btn:hover{border-color:var(--gold);color:var(--navy)}
.kn-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.8rem}
.add-mini{background:none;border:1px dashed var(--line);border-radius:8px;padding:.4rem .7rem;font-size:.8rem;font-weight:700;color:var(--gold-dark);cursor:pointer;font-family:inherit}
.add-mini:hover{border-color:var(--gold)}
.add-agent{background:none;border:1px dashed var(--line);border-radius:10px;padding:.6rem;width:100%;
  color:var(--gold-dark);font-weight:700;font-size:.85rem;cursor:pointer;font-family:inherit}
.add-agent:hover{border-color:var(--gold)}

/* dialog */
.dlg{position:fixed;inset:0;margin:auto;border:none;border-radius:var(--radius);padding:1.6rem;
  width:min(440px,92vw);max-height:90vh;overflow:auto;box-shadow:0 30px 70px -30px rgba(17,30,51,.5)}
.dlg::backdrop{background:rgba(17,30,51,.4)}
.dlg h2{font-size:1.15rem;color:var(--navy);margin-bottom:1.2rem}
.dlg-wide{width:min(680px,94vw)}
.view-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.view-head h2{margin:0}
.view-close{background:none;border:none;font-size:24px;line-height:1;cursor:pointer;color:var(--ink-dim)}
.view-body{max-height:64vh;overflow:auto}
.log-row{display:flex;align-items:center;gap:.6rem;padding:.6rem .3rem;border-bottom:1px solid var(--line);cursor:pointer}
.log-row:hover{background:#fcfbf8}
.log-row .kn-q{flex:1}
.log-row .kn-btn{cursor:pointer}
.log-back{display:inline-block;margin-bottom:.8rem;font-size:.88rem;color:var(--gold-dark)}
.cmsg{max-width:85%;margin:.5rem 0;padding:.6rem .8rem;border-radius:12px;font-size:.9rem;line-height:1.6;white-space:pre-wrap;word-break:break-word}
.cmsg-u{margin-left:auto;background:var(--navy);color:#fff;border-bottom-right-radius:4px}
.cmsg-a{margin-right:auto;background:var(--paper);border:1px solid var(--line);border-bottom-left-radius:4px}
.cmsg-meta{font-size:.72rem;color:var(--ink-dim);margin-top:.3rem}
.cmsg-ng{color:#c0392b;font-weight:700}
.site-tools{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.8rem}
#verify-tag{display:block;white-space:pre-wrap;word-break:break-all;padding-right:4rem}
.verify-ok{color:#1a9d4b;font-weight:700}
.dlg .cancel{background:none;border:1px solid var(--line);border-radius:999px;padding:.6rem 1.1rem;cursor:pointer;font-family:inherit}
