<!-- ===== /ウルスタ Branding ===== -->
<!-- 外部DB SDK 削除済み — DB は MySQL + api.php 経由 -->
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Noto+Sans+JP:wght@300;400;500;600;700;800;900&display=swap" rel="stylesheet">
<style>
html, body {
  overflow-x: hidden !important;
  max-width: 100vw;
}
*, *::before, *::after {
  box-sizing: border-box;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* agent-03: touch optimization */
*, *::before, *::after {
  -webkit-tap-highlight-color: transparent;
}
button, a, .nav-item, .card, .btn, input, select, textarea,
[onclick], [role="button"], .tab-btn, .sidebar-menu a,
.hamburger-btn, .sidebar-close {
  touch-action: manipulation;
}
button, .btn, .nav-item, .tab-btn, [onclick], [role="button"] {
  cursor: pointer;
}
/* end agent-03 */

:root{
  /* R-NEW77: z-index 層レイヤー定数化。 これより上は使わない (新しい層が必要なら このスタックを拡張) */
  --z-base:1;
  --z-support-btn:8000;
  --z-nav:100001;        /* トップナビ — モーダルより上に出してナビ可能に */
  --z-modal:100000;      /* モーダル overlay */
  --z-floorplan-editor:120400; /* 間取り図エディタ — 通常ナビより上、トーストより下 */
  --z-toast:120500;      /* トースト/通知 — 最上位 */
  /* LP / product UI tokens */
  --ink:#0a0e27;
  --ink-2:#1e293b;
  --accent:#eab308;
  --accent-2:#facc15;
  --primary:#059669;
  --primary-dark:#047857;
  --primary-500:#10b981;
  --primary-50:#ecfdf5;
  --primary-light:#d1fae5;
  --font-en:'Inter',system-ui,sans-serif;
  --font-jp:'Noto Sans JP','Inter',system-ui,sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);

  --sidebar-bg:var(--ink);
  --sidebar-text:#a1a1aa;
  --sidebar-active:#ffffff;
  --sidebar-active-bg:#1c1c1f;
  --main-bg:#f9f9f8;
  --card-bg:#ffffff;
  --border:#e4e4e7;
  --indigo-500:#10b981;
  --indigo-600:#059669;
  --indigo-50:#ecfdf5;
  --green-500:#22c55e;
  --green-50:#f0fdf4;
  --amber-500:#f59e0b;
  --amber-50:#fffbeb;
  --red-500:#ef4444;
  --red-50:#fef2f2;
  --text-primary:var(--ink);
  --text-secondary:#71717a;
  --text-muted:#a1a1aa;
  --gray-50:#f8fafc;
  --gray-100:#f1f5f9;
  --gray-200:#e2e8f0;
  --gray-300:#cbd5e1;
  --gray-400:#94a3b8;
  --gray-500:#64748b;
  --gray-600:#475569;
  --gray-700:#374151;
  --gray-800:#1e293b;
  --gray-900:#0f172a;
  --radius:12px;
  --radius-sm:8px;
  --shadow:0 1px 3px rgba(10,14,39,.08),0 1px 2px rgba(10,14,39,.04);
  --shadow-md:0 4px 6px rgba(10,14,39,.06),0 2px 4px rgba(10,14,39,.04);
  --shadow-lg:0 10px 15px rgba(10,14,39,.08),0 4px 6px rgba(10,14,39,.04);
  --shadow-xl:0 20px 25px rgba(10,14,39,.1),0 10px 10px rgba(10,14,39,.04);
}
body{font-family:var(--font-jp);background:var(--main-bg);color:var(--text-primary);line-height:1.5;font-size:14px;-webkit-font-smoothing:antialiased}

body.fp-editor-open{
  overflow:hidden !important;
  overscroll-behavior:none;
}
body.fp-editor-open .app-topbar,
body.fp-editor-open .app-tabs,
body.fp-editor-open .mobile-bottom-nav,
body.fp-editor-open .sidebar,
body.fp-editor-open #trialBannerTop,
body.fp-editor-open #supportAccessBannerTop,
body.fp-editor-open #mobileFAB,
body.fp-editor-open #supportChatBtn,
body.fp-editor-open #docAiToggleBtn{
  display:none !important;
}
#fpEditorOverlay{
  z-index:var(--z-floorplan-editor,120400) !important;
  isolation:isolate;
}
.fp-editor-shell{
  width:100%;
  height:100%;
  display:flex;
  flex-direction:column;
  background:#1e293b;
}
.fp-editor-topbar{
  background:#0f172a;
  padding:8px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-shrink:0;
  border-bottom:1px solid #334155;
}
.fp-editor-actions{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
  justify-content:flex-end;
  position:relative;
}
.fp-save-state{
  font-size:11px;
  color:#94a3b8;
  min-width:76px;
  text-align:right;
  font-weight:700;
}
.fp-editor-context{
  max-width:260px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:4px 9px;
  border:1px solid rgba(96,165,250,.28);
  border-radius:999px;
  background:rgba(37,99,235,.14);
  color:#bfdbfe;
  font-size:11px;
  font-weight:800;
}
.fp-editor-main{
  flex:1;
  display:flex;
  overflow:hidden;
  min-height:0;
}
.fp-editor-toolbar{
  width:58px;
  background:#0f172a;
  border-right:1px solid #334155;
  padding:8px 6px;
  display:flex;
  flex-direction:column;
  gap:4px;
  align-items:center;
  position:relative;
  flex-shrink:0;
  overflow:visible;
}
.fp-editor-canvas-wrap{
  flex:1;
  overflow:hidden;
  position:relative;
  cursor:crosshair;
  touch-action:none;
  min-width:0;
}
.fp-editor-props{
  width:220px;
  background:#0f172a;
  border-left:1px solid #334155;
  padding:12px;
  overflow-y:auto;
  flex-shrink:0;
}
.fp-mobile-more-menu{
  position:absolute;
  top:calc(100% + 8px);
  right:0;
  z-index:4;
  width:180px;
  grid-template-columns:1fr 1fr;
  gap:6px;
  padding:10px;
  border:1px solid #334155;
  border-radius:12px;
  background:#0f172a;
  box-shadow:0 16px 36px rgba(0,0,0,.32);
}
.fp-mobile-more-menu button{
  min-height:36px;
  border:1px solid #334155;
  border-radius:8px;
  background:#1e293b;
  color:#e2e8f0;
  font-size:12px;
  font-weight:800;
  cursor:pointer;
}
@media(max-width:768px){
  .fp-editor-topbar{
    padding:6px 8px;
    align-items:center;
    gap:8px;
  }
  .fp-editor-titlebar{
    flex:1;
    min-width:0;
    gap:8px !important;
  }
  #fpEditorName{
    width:100% !important;
    min-width:0;
    height:34px;
    font-size:12px !important;
    padding:5px 8px !important;
  }
  .fp-editor-back-btn{
    padding:6px 9px !important;
    white-space:nowrap;
  }
  .fp-editor-context{
    display:none;
  }
  .fp-editor-actions{
    flex:0 0 auto;
    max-width:none;
    gap:5px;
    flex-wrap:nowrap;
  }
  .fp-save-state,
  .fp-editor-secondary-action,
  .fp-editor-zoom-action,
  .fp-editor-grid-action,
  .fp-editor-separator{
    display:none;
  }
  .fp-mobile-more-btn{
    display:inline-flex !important;
    align-items:center;
    justify-content:center;
    min-height:34px;
  }
  .fp-editor-primary-action,
  .fp-editor-export-action,
  .fp-editor-save-action{
    min-height:34px;
    padding:6px 9px !important;
    font-size:11px !important;
    white-space:nowrap;
  }
  .fp-editor-toolbar{
    width:54px;
    padding:6px 4px;
  }
  .fp-editor-props{
    position:absolute;
    left:54px;
    right:0;
    bottom:0;
    width:auto;
    max-height:34vh;
    border-left:none;
    border-top:1px solid #334155;
    box-shadow:0 -14px 36px rgba(15,23,42,.24);
  }
}

/* ===== LOGIN: SPLIT SCREEN ===== */
.auth-bg{min-height:100vh;display:flex;background:#fff;position:fixed;inset:0;z-index:500;overflow-y:auto}

/* Left: Brand Panel */
.auth-brand{
  width:44%;
  background:
    linear-gradient(135deg,rgba(16,185,129,.08),transparent 34%),
    linear-gradient(160deg,#07111f 0%,#0b1220 58%,#111827 100%);
  display:flex;align-items:center;justify-content:center;
  padding:64px 52px;position:relative;overflow:hidden;flex-shrink:0;
  border-right:1px solid rgba(255,255,255,.06);
}

/* Mobile: Stack auth screens */
@media(max-width:768px){
  .auth-bg{
    flex-direction:column;
  }
  .auth-brand{
    width:100%;
    min-height:auto;
    padding:40px 24px;
    flex-shrink:1;
  }
  .auth-brand-inner{
    max-width:100% !important;
  }
  .auth-brand-tagline h2{
    font-size:20px !important;
  }
  .auth-brand-tagline p{
    font-size:12px !important;
  }
  .auth-form-panel{
    width:100%;
    padding:40px 24px 60px !important;
    min-height:auto;
  }
  .auth-form-inner{
    max-width:100% !important;
    width:100%;
  }
}

@media(max-width:600px){
  .auth-brand{
    padding:32px 16px;
  }
  .auth-form-panel{
    padding:32px 16px 60px !important;
  }
  .auth-form-inner{
    max-width:100%;
  }
  .auth-form-head h2{
    font-size:20px !important;
  }
}
.auth-brand::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:44px 44px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.8),rgba(0,0,0,.18));
  pointer-events:none;
}
.auth-brand::after{
  content:'';position:absolute;left:0;right:0;bottom:0;height:2px;
  background:linear-gradient(90deg,transparent,rgba(16,185,129,.72),rgba(14,165,233,.5),transparent);
  pointer-events:none;
}
.auth-brand-inner{position:relative;z-index:1;width:100%;max-width:360px}
.auth-brand-inner::before{
  content:none;
}
.auth-brand-logo{display:flex;align-items:center;gap:12px;margin-bottom:56px}
.auth-brand-logo .logo-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:10px;
  background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary) 100%);
  color:#fff;font-weight:900;font-family:var(--font-en);font-size:16px;
  box-shadow:0 8px 24px -8px rgba(16,185,129,.45),inset 0 1px 0 rgba(255,255,255,.18);
  flex-shrink:0;
}
.auth-brand-logo-name{
  font-size:22px;font-weight:900;color:#fff;letter-spacing:-0.5px;
  font-family:var(--font-en);
  background:linear-gradient(90deg,#fff 0%,#e2e8f0 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.auth-brand-tagline h2{
  font-size:28px;font-weight:900;color:#fff;line-height:1.4;
  letter-spacing:-0.6px;margin-bottom:16px;font-family:var(--font-jp);
}
.auth-brand-tagline h2 .accent{
  background:linear-gradient(90deg,var(--primary-500) 0%,var(--accent) 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.auth-brand-tagline p{
  font-size:13.5px;color:rgba(255,255,255,0.6);line-height:1.8;margin-bottom:40px;
}
.auth-brand-feat{
  font-size:13px;color:rgba(255,255,255,0.72);
  padding:12px 0;border-top:1px solid rgba(255,255,255,0.08);
  display:flex;align-items:center;gap:10px;font-weight:500;
}
.auth-brand-feat:last-child{border-bottom:1px solid rgba(255,255,255,0.08)}
.auth-brand-feat-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--accent);flex-shrink:0;
  box-shadow:0 0 0 3px rgba(234,179,8,.18);
}
.auth-brand-product{max-width:430px}
.auth-logo-lockup{display:flex;align-items:center;gap:14px;margin-bottom:34px}
.auth-logo-mark{
  width:50px;height:50px;border-radius:14px;
  background:linear-gradient(135deg,#10b981,#14b8a6);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 10px 26px -14px rgba(16,185,129,.85),inset 0 1px 0 rgba(255,255,255,.22);
}
.auth-logo-name{
  font-size:24px;font-weight:900;letter-spacing:2.8px;line-height:1;color:#d1fae5;
  font-family:var(--font-en);
}
.auth-logo-subtitle{
  font-size:10px;color:rgba(255,255,255,.56);letter-spacing:1.2px;font-weight:700;margin-top:6px;
}
.auth-ops-copy{margin-bottom:22px}
.auth-ops-eyebrow{
  color:#5eead4;font-size:10px;letter-spacing:1.8px;font-weight:800;margin-bottom:10px;
}
.auth-workflow-board{
  background:rgba(15,23,42,.74);
  border:1px solid rgba(148,163,184,.22);
  border-radius:14px;
  padding:14px;
  box-shadow:0 18px 34px -24px rgba(0,0,0,.65),inset 0 1px 0 rgba(255,255,255,.06);
  backdrop-filter:blur(10px);
}
.auth-workflow-topbar{
  display:flex;align-items:center;justify-content:space-between;
  color:#e2e8f0;font-size:12px;font-weight:800;margin-bottom:12px;
}
.auth-workflow-topbar strong{
  color:#5eead4;font-size:11px;padding:4px 8px;border-radius:999px;background:rgba(20,184,166,.12);
}
.auth-workflow-list{display:grid;gap:8px}
.auth-workflow-item{
  display:grid;grid-template-columns:52px minmax(0,1fr) auto;gap:10px;align-items:center;
  padding:10px 11px;border-radius:10px;background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.07);
}
.auth-workflow-item span{
  color:#94a3b8;font-size:11px;font-weight:800;
}
.auth-workflow-item strong{
  color:#f8fafc;font-size:13px;font-weight:850;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.auth-workflow-item em{
  color:#34d399;font-size:10px;font-style:normal;font-weight:800;
  padding:4px 7px;border-radius:999px;background:rgba(16,185,129,.12);white-space:nowrap;
}
.auth-workflow-item.is-hot{border-color:rgba(52,211,153,.34);background:rgba(16,185,129,.105)}
.auth-proof-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:10px}
.auth-proof-card{
  padding:9px 8px;border-radius:9px;background:rgba(2,6,23,.28);border:1px solid rgba(148,163,184,.18);
  min-width:0;
}
.auth-proof-card span{display:block;color:#94a3b8;font-size:10px;font-weight:800;margin-bottom:3px}
.auth-proof-card strong{display:block;color:#e2e8f0;font-size:11px;font-weight:850;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
body.auth-screen-active #mobileHamburger,
body.auth-screen-active #mobileFAB,
body.auth-screen-active #fabMenu,
body.auth-screen-active #supportChatBtn,
body.auth-screen-active #supportChatModal,
body.auth-screen-active #docAiToggleBtn,
body.auth-screen-active #docAiPanel{
  display:none!important;
  opacity:0!important;
  pointer-events:none!important;
}
/* Hide Chrome native password reveal */
input::-ms-reveal,input::-ms-clear{display:none!important}
input::-webkit-credentials-auto-fill-button{visibility:hidden;width:0;height:0}
.pwd-toggle{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  background:none;border:none;cursor:pointer;padding:4px;
  color:#9ca3af;display:flex;align-items:center;justify-content:center;
  width:28px;height:28px;z-index:1;
  transition:color 0.2s;
}
.pwd-toggle:hover{color:var(--primary)}
.pwd-toggle svg{width:20px;height:20px;flex-shrink:0}
/* パスワード入力欄: トグルボタン分の余白 */
input[type="password"].auth-input,
input[type="text"].auth-input[data-pw-field]{padding-right:44px}

/* Right: Form Panel */
.auth-form-panel{
  flex:1;display:flex;align-items:center;justify-content:center;
  padding:60px 48px;background:#fff;
}
/* Company signup right panel */
.auth-form-wrap{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:40px 40px 100px;background:#fff;overflow-y:auto}
.auth-form-inner{width:100%;max-width:360px}
.auth-form-head{margin-bottom:36px}
.auth-form-head h2{font-size:24px;font-weight:800;color:var(--ink);letter-spacing:-0.4px;font-family:var(--font-jp)}
.auth-form-head p{font-size:13px;color:#94a3b8;margin-top:6px}

.auth-form-box{width:100%}
.auth-form-title{font-size:22px;font-weight:900;color:var(--ink);margin-bottom:6px;letter-spacing:-0.5px;line-height:1.3;font-family:var(--font-jp)}
.auth-form-group{margin-bottom:18px;max-width:100%}
.auth-label{display:block;font-size:13px;font-weight:600;color:var(--ink-2);margin-bottom:6px;letter-spacing:.01em}
.auth-input{
  width:100%;max-width:100%;padding:12px 14px;background:#fff;
  border:1.5px solid #e2e8f0;border-radius:10px;
  color:var(--ink);font-size:14px;font-family:var(--font-jp);
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease);outline:none;
  box-sizing:border-box;
  min-height:44px;
}

@media(max-width:768px){
  .auth-input{
    font-size:16px;
  }
}
select.auth-input{
  appearance:auto;box-sizing:border-box;
}
.auth-input::placeholder{color:#cbd5e1}
.auth-input:hover{border-color:#cbd5e1}
.auth-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(5,150,105,.14)}
.auth-btn{
  width:100%;max-width:100%;padding:13px;border:none;border-radius:10px;cursor:pointer;
  background:linear-gradient(180deg,var(--ink) 0%,#111831 100%);color:#fff;
  font-size:14.5px;font-weight:700;font-family:var(--font-jp);
  letter-spacing:0;transition:transform .2s var(--ease),box-shadow .2s var(--ease),opacity .15s;
  margin-top:6px;box-sizing:border-box;min-height:46px;
  box-shadow:0 1px 2px rgba(10,14,39,.18),inset 0 1px 0 rgba(255,255,255,.08),0 6px 16px -8px rgba(10,14,39,.45);
  position:relative;overflow:hidden;
}
.auth-btn::after{
  content:'';position:absolute;left:0;right:0;bottom:0;height:2px;
  background:linear-gradient(90deg,var(--primary-500),var(--accent));
  opacity:.8;
}

@media(max-width:768px){
  .auth-btn{
    font-size:14px;
    padding:14px 12px;
  }
}
.auth-btn:hover{transform:translateY(-1px);box-shadow:0 1px 2px rgba(10,14,39,.22),inset 0 1px 0 rgba(255,255,255,.1),0 12px 22px -10px rgba(10,14,39,.5)}
.auth-btn:active{transform:translateY(0)}
.auth-btn:disabled{opacity:0.45;cursor:not-allowed;transform:none}
.auth-link{text-align:center;margin-top:22px;font-size:13px;color:#94a3b8}
.auth-link a{color:var(--primary-dark);text-decoration:none;font-weight:700;transition:color .15s}
.auth-link a:hover{color:var(--primary)}
.auth-error{
  background:#fef2f2;border:1px solid #fecaca;
  border-radius:10px;padding:10px 14px;color:#dc2626;font-size:13px;
  margin-bottom:16px;display:none;
}
.auth-error.show{display:block}
/* legacy .auth-card compat */
.auth-card{width:100%}

/* ===== APP SHELL ===== */
#appShell{display:flex;height:100vh;overflow:hidden}

/* ===== PC TOP BAR (product / LP style) ===== */
.app-topbar{
  display:none;
  background:linear-gradient(160deg,var(--ink) 0%,#0f172a 60%,#111831 100%);
  padding:12px 32px;
  align-items:center;justify-content:space-between;position:sticky;top:0;z-index:200;
  box-shadow:0 4px 20px rgba(10,14,39,.22);flex-shrink:0;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.app-topbar-logo{display:flex;align-items:center;gap:12px;cursor:pointer;transition:opacity .15s}
.app-topbar-logo:hover{opacity:.85}
.app-topbar-logo-icon{
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary) 100%);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 6px 16px -6px rgba(16,185,129,.5),inset 0 1px 0 rgba(255,255,255,.2);
}
.app-topbar-logo-text{
  font-size:18px;font-weight:900;letter-spacing:1.4px;font-family:var(--font-en);
  background:linear-gradient(90deg,#fff 0%,#d1fae5 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.app-topbar-logo-sub{font-size:9px;color:rgba(255,255,255,.4);font-weight:600;letter-spacing:1px}
.app-topbar-right{display:flex;align-items:center;gap:14px}
.app-topbar-user{display:flex;align-items:center;gap:10px;padding:5px 10px;border-radius:10px;cursor:default}
.app-topbar-avatar{
  width:30px;height:30px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary-500),var(--primary-dark));
  display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;flex-shrink:0;
  box-shadow:0 4px 12px -4px rgba(16,185,129,.5);font-family:var(--font-en);
}
.app-topbar-uname{font-size:12.5px;font-weight:600;color:#e4e4e7;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.app-topbar-urole{font-size:9.5px;color:rgba(255,255,255,0.4);font-weight:500;letter-spacing:.02em}
.app-topbar-clock{font-size:11px;color:#94a3b8;white-space:nowrap;font-family:var(--font-en);font-variant-numeric:tabular-nums}
.app-topbar-logout{
  padding:6px 14px;background:rgba(255,255,255,0.06);color:#e2e8f0;
  border:1px solid rgba(255,255,255,0.12);border-radius:8px;font-size:11.5px;
  font-weight:600;cursor:pointer;transition:all .18s var(--ease);font-family:inherit;
}
.app-topbar-logout:hover{background:rgba(239,68,68,0.15);color:#fca5a5;border-color:rgba(239,68,68,0.3)}
.app-tabs{
  display:none;gap:4px;background:#f1f5f9;border-radius:0;padding:8px 32px;
  overflow-x:auto;-webkit-overflow-scrolling:touch;flex-shrink:0;
  scrollbar-width:none;border-bottom:1px solid #e2e8f0;
}
.app-tabs::-webkit-scrollbar{display:none}
.app-tab{
  padding:9px 16px;border:none;border-radius:10px;font-size:12.5px;font-weight:600;
  cursor:pointer;background:transparent;color:#64748b;white-space:nowrap;
  transition:all .18s var(--ease);position:relative;font-family:inherit;letter-spacing:.01em;
}
.app-tab:hover{color:var(--ink);background:rgba(255,255,255,.7)}
.app-tab.active{
  background:#fff;color:var(--ink);
  box-shadow:0 2px 8px rgba(10,14,39,.08),0 0 0 1px rgba(10,14,39,.04);
  font-weight:700;
}
.app-tab.active::after{
  content:'';position:absolute;left:14px;right:14px;bottom:3px;height:2px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  border-radius:2px;
}
.app-tab .tab-badge{position:absolute;top:2px;right:2px;background:#ef4444;color:#fff;font-size:8px;font-weight:700;padding:1px 4px;border-radius:99px;min-width:12px;text-align:center;line-height:1.3;font-family:var(--font-en)}
.app-tab-sep{width:1px;background:#cbd5e1;margin:6px 4px;flex-shrink:0}
/* R-NEW76: トップナビをモーダル overlay (z:100000) より上に置く。
   顧客詳細等のモーダル開いた状態でも、直接トップタブをクリックして
   別画面に遷移できるようにする (navigate() が自動でモーダルを閉じる)。
   また、メインヘッダー全体 (.compare-row.header) も同様に上に置く。 */
.compare-row.header{position:relative;z-index:var(--z-nav);background:#fff}
#appTabs{position:relative;z-index:var(--z-nav);background:#f1f5f9}
body.uls-modal-open .compare-row.header,
body.uls-modal-open #appTabs{
  z-index:var(--z-nav) !important;
}
#trialBannerTop{display:none}
#trialBannerTop.show{display:flex;align-items:center;gap:8px;padding:10px 32px;background:linear-gradient(90deg,var(--primary-50),#f0fdf4);border-bottom:1px solid var(--primary-light);font-size:12.5px;color:var(--primary-dark);font-weight:600;flex-shrink:0}

/* ===== SIDEBAR (product / LP style) ===== */
.sidebar{
  width:240px;min-width:240px;height:100vh;
  background:linear-gradient(180deg,var(--ink) 0%,#0b1028 100%);
  display:flex;flex-direction:column;
  border-right:1px solid rgba(255,255,255,0.06);
  position:relative;z-index:100;
  will-change:transform;transform:translateZ(0);
  overflow:hidden;
}
.sidebar::before{
  content:'';position:absolute;top:-120px;left:-80px;
  width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle,rgba(16,185,129,.16) 0%,transparent 70%);
  pointer-events:none;
}
.sidebar-logo{
  padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,0.08);
  position:relative;z-index:1;
}
.sidebar-logo-inner{display:flex;align-items:flex-start;gap:12px}
.sb-logo-icon{
  padding-top:2px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.sb-logo-text{
  font-size:26px;font-weight:900;letter-spacing:-1px;
  color:#ffffff;line-height:1;font-family:var(--font-en);
  background:linear-gradient(90deg,#fff 0%,#d1fae5 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.sb-logo-tagline{
  font-size:10px;color:rgba(255,255,255,0.45);letter-spacing:0.6px;
  font-weight:500;margin-top:3px;
}
.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto;overscroll-behavior-y:contain;position:relative;z-index:1}
.nav-section-label{
  font-size:10px;font-weight:700;color:rgba(255,255,255,0.28);
  text-transform:uppercase;letter-spacing:1.2px;padding:0 10px;margin-bottom:6px;margin-top:16px;
}
.nav-section-label:first-child{margin-top:0}
.nav-item{
  display:flex;align-items:center;gap:10px;padding:9px 12px;
  border-radius:10px;cursor:pointer;color:var(--sidebar-text);
  font-size:13.5px;font-weight:500;transition:all .2s var(--ease);margin-bottom:2px;
  user-select:none;position:relative;
}
.nav-item:hover{color:#e4e4e7;background:rgba(255,255,255,0.06);transform:translateX(2px)}
.nav-item.active{
  color:#fff;
  background:linear-gradient(135deg,rgba(16,185,129,.22) 0%,rgba(5,150,105,.08) 100%);
  font-weight:700;
  box-shadow:inset 3px 0 0 var(--accent),0 2px 12px rgba(16,185,129,.18);
  border:1px solid rgba(16,185,129,.22);
}
.nav-item.active .nav-icon{color:var(--accent-2)}
.nav-item .nav-icon{font-size:16px;flex-shrink:0;width:20px;text-align:center;display:inline-flex;align-items:center;justify-content:center;transition:color .15s}
.sidebar-bottom{
  padding:16px 12px;border-top:1px solid rgba(255,255,255,0.06);
  position:relative;z-index:1;
}
.user-info{
  display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;
  margin-bottom:4px;
}
.user-avatar{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary-500),var(--primary-dark));
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:800;color:#fff;flex-shrink:0;
  box-shadow:0 4px 12px -4px rgba(16,185,129,.5);font-family:var(--font-en);
}
.user-details{flex:1;min-width:0}
.user-name{font-size:13px;font-weight:600;color:#e4e4e7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:10px;color:rgba(255,255,255,0.38);font-weight:500;letter-spacing:.02em}
.role-badge{
  display:inline-block;padding:2px 7px;border-radius:4px;font-size:9px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.5px;font-family:var(--font-en);
}
.role-badge.admin{background:rgba(234,179,8,.18);color:var(--accent-2);border:1px solid rgba(234,179,8,.22)}
.role-badge.agent{background:rgba(16,185,129,.18);color:#86efac;border:1px solid rgba(16,185,129,.22)}
.logout-btn{
  display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:10px;
  color:rgba(255,255,255,0.42);font-size:13px;cursor:pointer;
  transition:all .18s var(--ease);border:none;background:none;width:100%;font-family:var(--font-jp);
}
.logout-btn:hover{color:#fca5a5;background:rgba(239,68,68,0.12)}

/* ===== MAIN CONTENT ===== */
.main-content{flex:1;overflow-y:auto;background:var(--main-bg);will-change:transform;transform:translateZ(0);-webkit-overflow-scrolling:touch;scroll-behavior:smooth;overscroll-behavior-y:contain}
.view{display:none;padding:40px 44px;min-height:100vh;content-visibility:auto;contain-intrinsic-size:auto 500px}
.view.active{display:block;opacity:1;animation:viewFadeIn 0.22s ease;animation-fill-mode:forwards;will-change:opacity,transform;contain:layout style paint;content-visibility:visible}

@media(max-width:768px){
  .view{
    padding:24px 16px;
  }
}

@media(max-width:480px){
  .view{
    padding:16px 12px;
  }
}
@keyframes viewFadeIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
@keyframes typingDot{0%,60%,100%{opacity:0.15}30%{opacity:1}}
.sidebar-nav{
  -webkit-overflow-scrolling:touch;
  scroll-behavior:smooth;
  overscroll-behavior-y:contain;
}
.view{
  contain:layout style;
}

/* ===== VIEW HEADER ===== */
.view-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}
.view-title{font-size:28px;font-weight:900;color:var(--ink);letter-spacing:-1px;font-family:var(--font-jp)}
.view-subtitle{font-size:13px;color:#94a3b8;margin-top:4px;font-weight:400}

@media(max-width:768px){
  .view-header{
    flex-direction:column;
    align-items:flex-start;
    margin-bottom:24px;
  }
  .view-title{
    font-size:22px;
  }
  .view-subtitle{
    font-size:12px;
  }
}

/* ===== CARDS ===== */
.card{background:#fff;border:none;border-radius:14px;box-shadow:0 1px 3px rgba(0,0,0,0.06),0 4px 16px rgba(0,0,0,0.04)}
.card-header{padding:22px 26px 0;margin-bottom:16px}
.card-title{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:-0.2px}
.card-body{padding:0 26px 26px}

@media(max-width:768px){
  .card{
    border-radius:10px;
  }
  .card-header{
    padding:16px 20px 0;
  }
  .card-body{
    padding:0 20px 20px;
  }
  .card-title{
    font-size:13px;
  }
}

/* ===== KPI CARDS ===== */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}

@media(max-width:1024px){
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:768px){
  .kpi-grid{grid-template-columns:1fr;gap:12px}
}
.kpi-card{
  background:#fff;border:none;border-radius:14px;
  padding:26px 26px 22px;box-shadow:0 1px 3px rgba(0,0,0,0.06),0 4px 16px rgba(0,0,0,0.04);
  position:relative;overflow:hidden;transition:box-shadow 0.2s,transform 0.2s;
}
.kpi-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary) 0%,var(--primary-500) 50%,var(--accent) 100%);border-radius:14px 14px 0 0;
}
.kpi-card:hover{box-shadow:0 4px 12px rgba(10,14,39,.08),0 12px 28px rgba(10,14,39,.06);transform:translateY(-2px)}
/* .kpi-card::after is styled in PREMIUM QUALITY section below */
.kpi-label{font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:1.4px;margin-bottom:14px;font-family:var(--font-en)}
.kpi-value{font-size:44px;font-weight:900;color:var(--ink);letter-spacing:-2.5px;line-height:1;font-variant-numeric:tabular-nums;font-family:var(--font-en)}
.kpi-sub{font-size:11px;color:#d1d5db;margin-top:12px;letter-spacing:0}
.kpi-icon{display:none}

/* ===== TABLES ===== */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse}

@media(max-width:768px){
  .table-wrap{
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch !important;
    font-size:12px;
  }
  th{
    font-size:10px !important;
    padding:8px 12px !important;
  }
  td{
    font-size:11px !important;
    padding:10px 12px !important;
  }
}
th{font-size:10px;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:1px;padding:10px 16px;background:#fff;border-bottom:1.5px solid #e5e7eb;text-align:left;white-space:nowrap}
td{padding:14px 16px;border-bottom:1px solid #f5f5f5;color:#09090b;font-size:13.5px}
tr:last-child td{border-bottom:none}
tr:hover td{background:#f9f9f9}
tbody tr{cursor:pointer;transition:background 0.1s}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;gap:6px;padding:8px 16px;
  border-radius:8px;border:none;cursor:pointer;font-size:13.5px;font-weight:600;
  font-family:'Inter',sans-serif;transition:all 0.15s;text-decoration:none;
  white-space:nowrap;min-width:fit-content;
  min-height:44px;
}

@media(max-width:768px){
  .btn{
    font-size:12px;
    padding:10px 14px;
  }
  .btn-lg{
    padding:12px 20px;
    font-size:14px;
  }
}
.btn-primary{background:#09090b;color:#fff;box-shadow:none}
.btn-primary:hover{background:#27272a;box-shadow:none;transform:none}
.btn-secondary{background:var(--card-bg);color:var(--text-primary);border:1px solid var(--border)}
.btn-secondary:hover{background:#f4f4f5;border-color:#d4d4d8}
.btn-danger{background:#ef4444;color:#fff}
.btn-danger:hover{background:#dc2626}
.btn-success{background:#22c55e;color:#fff}
.btn-success:hover{background:#16a34a}
.btn-sm{padding:5px 12px;font-size:12.5px;border-radius:6px}
.btn-lg{padding:12px 24px;font-size:15px;border-radius:10px}
.btn:disabled{opacity:0.5;cursor:not-allowed;transform:none!important}
.btn-indigo{background:#10b981;color:#fff}
.btn-indigo:hover{background:#059669}
.btn-brand{background:#1F3864;color:#fff}
.btn-brand:hover{background:#162b4d}
.btn-warning{background:#f59e0b;color:#fff}
.btn-warning:hover{background:#d97706}
.btn-dark{background:#0f172a;color:#fff}
.btn-dark:hover{background:#1e293b}
.btn-outline-danger{background:#fff;color:#dc2626;border:1.5px solid #dc2626}
.btn-outline-danger:hover{background:#fef2f2}
.btn-xs{padding:3px 10px;font-size:10px;font-weight:700;border-radius:6px}
.btn-md{padding:10px 24px;font-size:13px;font-weight:700;border-radius:8px}

/* ===== BADGES ===== */
.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.badge-slate{background:#f1f5f9;color:#475569}
.badge-blue{background:#eff6ff;color:#2563eb}
.badge-indigo{background:#eef2ff;color:#4338ca}
.badge-amber{background:#fffbeb;color:#92400e}
.badge-green{background:#f0fdf4;color:#15803d}
.badge-emerald{background:#ecfdf5;color:#065f46}
.badge-red{background:#fef2f2;color:#991b1b}
.badge-purple{background:#faf5ff;color:#6b21a8}
.badge-pill{display:inline-flex;align-items:center;border-radius:999px;font-weight:700;white-space:nowrap}
.badge-pill-sm{padding:1px 7px;font-size:9px}
.badge-pill-md{padding:2px 8px;font-size:10px}
.badge-pill-lg{padding:3px 10px;font-size:10px}

/* ===== CARDS ===== */
.u-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px}
.u-card-sm{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:12px 14px}
.u-card-compact{background:#fff;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden}

/* ===== ALERTS ===== */
.u-alert{border-radius:10px;padding:12px 14px;font-size:12px}
.u-alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d}
.u-alert-info{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}
.u-alert-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}
.u-alert-warning{background:#fffbeb;border:1px solid #fcd34d;color:#92400e}
.u-alert-indigo{background:#eef2ff;border:1px solid #c7d2fe;color:#4338ca}

/* ===== FORM ELEMENTS ===== */
.form-group{margin-bottom:18px;min-width:0}
.form-label{display:block;font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:6px}
.form-label span{color:var(--red-500);margin-left:2px}
.form-control{
  width:100%;padding:9px 13px;border:1.5px solid var(--border);border-radius:8px;
  font-size:14px;font-family:'Inter',sans-serif;color:var(--text-primary);
  background:#fff;transition:border-color 0.2s,box-shadow 0.2s;outline:none;
}
.form-control:focus{border-color:var(--indigo-500);box-shadow:0 0 0 3px rgba(16,185,129,0.1)}
.form-control.error{border-color:var(--red-500);box-shadow:0 0 0 3px rgba(239,68,68,0.1)}
select.form-control{cursor:pointer}
.form-hint{font-size:12px;color:var(--text-muted);margin-top:4px}
.form-error{font-size:12px;color:var(--red-500);margin-top:4px;display:none}
.form-error.show{display:block}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;align-items:start}
.form-row{
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
}
.form-row-3{
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr);
}
.form-row > *,
.form-row-3 > *{
  min-width:0;
}

@media(max-width:768px){
  .form-row{
    grid-template-columns:1fr !important;
  }
  .form-row-3{
    grid-template-columns:1fr !important;
  }
}
.form-group .form-control,
.form-group select.form-control,
.form-group textarea.form-control{
  display:block;
  width:100%;
  max-width:100%;
  min-width:0;
  box-sizing:border-box;
}

/* ===== RENT APPRAISAL DESKTOP FIX ===== */
#view-rentAppraisal > div[style*="grid-template-columns:1fr 1fr"]{
  grid-template-columns:minmax(0, 1.15fr) minmax(0, 0.85fr) !important;
  align-items:start !important;
  gap:20px !important;
}
#view-rentAppraisal > div[style*="grid-template-columns:1fr 1fr"] > div{
  min-width:0 !important;
}
#view-rentAppraisal{
  overflow-x:hidden;
}
#view-rentAppraisal .card{
  min-width:0;
}
#view-rentAppraisal [style*="border-radius:20px"]{
  min-width:0 !important;
}
#view-rentAppraisal .form-control{
  min-width:0;
}
#view-rentAppraisal #rentAppraisalHistoryList{
  max-width:100%;
}
#view-rentAppraisal [style*="grid-template-columns:1fr 1fr 1fr"]{
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) !important;
}
#view-rentAppraisal [style*="grid-template-columns:1fr 1fr"]{
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important;
}
#view-rentAppraisal [style*="grid-template-columns:1fr 1fr 1fr"] > *,
#view-rentAppraisal [style*="grid-template-columns:1fr 1fr"] > *{
  min-width:0 !important;
}
#view-rentAppraisal input,
#view-rentAppraisal select,
#view-rentAppraisal .form-group{
  min-width:0 !important;
  width:100%;
  box-sizing:border-box;
}
@media (max-width: 1440px){
  #view-rentAppraisal > div[style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns:minmax(0,1fr) !important;
  }
}


/* ===== WIZARD ===== */
.wizard-progress{display:flex;align-items:center;margin-bottom:32px;padding:20px 24px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.wizard-step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}
.wizard-step:not(:last-child)::after{content:'';position:absolute;top:18px;left:calc(50% + 20px);right:calc(-50% + 20px);height:2px;background:var(--border);z-index:0}
.wizard-step.done:not(:last-child)::after{background:var(--indigo-500)}
.step-circle{
  width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;border:2px solid var(--border);background:#fff;
  color:var(--text-muted);position:relative;z-index:1;transition:all 0.3s;
}
.wizard-step.active .step-circle{border-color:var(--indigo-500);background:linear-gradient(135deg,#10b981,#8b5cf6);color:#fff;box-shadow:0 4px 12px rgba(16,185,129,0.45);animation:wizardPulse 2s ease-in-out infinite}
.wizard-step.done .step-circle{border-color:#059669;background:linear-gradient(135deg,#22c55e,#059669);color:#fff;box-shadow:0 2px 8px rgba(34,197,94,0.35)}
@keyframes wizardPulse{0%,100%{box-shadow:0 4px 12px rgba(16,185,129,0.45)}50%{box-shadow:0 4px 20px rgba(16,185,129,0.7),0 0 0 6px rgba(16,185,129,0.12)}}
.step-label{font-size:11px;font-weight:600;color:var(--text-muted);margin-top:6px;text-align:center;transition:color 0.3s,font-weight 0.3s}
.wizard-step.active .step-label{color:var(--indigo-500);font-weight:700}
.wizard-step.done .step-label{color:#059669;font-weight:700}
.wizard-step-content{display:none}
.wizard-step-content.active{display:block;animation:wizardFadeIn 0.15s ease-out}
@keyframes wizardFadeIn{from{opacity:0.3;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.fav-star-btn{background:none;border:none;cursor:pointer;font-size:16px;transition:transform 0.2s;padding:2px 4px;line-height:1}.fav-star-btn:hover{transform:scale(1.3)}
.loan-type-switch{transition:background 0.3s ease,color 0.3s ease,border-color 0.3s ease}
.loan-slider-group{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}
.loan-slider-group label{font-size:11px;font-weight:700;color:#374151;display:flex;justify-content:space-between}
.loan-slider-group input[type=range]{-webkit-appearance:none;width:100%;height:6px;border-radius:3px;background:#e2e8f0;outline:none}
.loan-slider-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#10b981,#8b5cf6);cursor:pointer;box-shadow:0 2px 6px rgba(16,185,129,0.4)}
.score-tooltip-wrap{position:relative;display:inline-block;cursor:help}
.score-tooltip-wrap .score-tooltip-box{display:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:#1e293b;color:#fff;padding:10px 12px;border-radius:8px;font-size:10px;line-height:1.6;white-space:nowrap;z-index:100;box-shadow:0 4px 12px rgba(0,0,0,0.25);pointer-events:none}
.score-tooltip-wrap .score-tooltip-box::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:#1e293b}
.score-tooltip-wrap:hover .score-tooltip-box{display:block}

/* ===== DOCUMENT AI ===== */
.doc-section{position:relative}
.doc-section:hover>.doc-edit-btn{opacity:1}
.doc-edit-btn{position:absolute;top:4px;right:6px;opacity:0;background:linear-gradient(135deg,#10b981,#8b5cf6);color:#fff;border:none;border-radius:6px;padding:3px 9px;font-size:10px;font-weight:700;cursor:pointer;transition:opacity 0.18s;z-index:2;white-space:nowrap}
.doc-chat-user{background:linear-gradient(135deg,#10b981,#8b5cf6);color:#fff;border-radius:10px 10px 2px 10px;padding:9px 12px;font-size:11px;line-height:1.7;max-width:90%;align-self:flex-end}
.doc-chat-ai{background:#fff;border:1px solid #e2e8f0;border-radius:10px 10px 10px 2px;padding:10px 12px;font-size:11px;line-height:1.7;color:#374151;max-width:95%}
.doc-chat-typing{background:#f1f5f9;border-radius:10px 10px 10px 2px;padding:10px 12px;font-size:11px;color:#94a3b8;animation:pulse 1.2s infinite}
.clause-card{border:1.5px solid #e2e8f0;border-radius:10px;padding:10px 12px;cursor:pointer;transition:all 0.15s;background:#fff;display:flex;align-items:flex-start;gap:8px}
.clause-card:hover{border-color:#10b981;background:#eef2ff}
.clause-card.selected{border-color:#22c55e;background:#f0fdf4}
.clause-card.selected .clause-check{opacity:1}
.clause-check{width:18px;height:18px;border-radius:50%;background:#22c55e;color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:900;flex-shrink:0;opacity:0;transition:opacity 0.15s;margin-top:1px}

/* ===== DOC TEMPLATE CARDS (Enhanced) ===== */
.doc-tmpl-card{border:1.5px solid #e2e8f0;border-radius:12px;padding:14px;cursor:pointer;transition:all 0.18s;background:#fff;display:flex;align-items:flex-start;gap:12px;position:relative}
.doc-tmpl-card:hover{border-color:#10b981;background:#fafaff;box-shadow:0 4px 16px rgba(16,185,129,0.08);transform:translateY(-1px)}
.doc-tmpl-card.pinned{border-color:#f59e0b;background:#fffdf7}
.doc-tmpl-card .tmpl-pin-btn{position:absolute;top:8px;right:8px;background:none;border:none;cursor:pointer;font-size:14px;opacity:0.3;transition:opacity 0.15s;padding:2px}
.doc-tmpl-card:hover .tmpl-pin-btn,.doc-tmpl-card.pinned .tmpl-pin-btn{opacity:1}
.doc-tmpl-card .tmpl-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.doc-tmpl-card .tmpl-usage{font-size:9px;font-weight:700;padding:2px 7px;border-radius:10px;white-space:nowrap}
/* ===== DOC A4 PREVIEW FRAME ===== */
.doc-a4-frame{background:linear-gradient(180deg,#f8fafc,#eef2f7);border:1px solid #dbe3ef;border-radius:12px;box-shadow:inset 0 1px 0 rgba(255,255,255,0.8);padding:24px;min-height:560px;font-family:'Hiragino Kaku Gothic ProN','Noto Sans JP',sans-serif;position:relative;max-width:100%;margin:0;overflow-y:auto}
.doc-a4-frame::before{content:'A4 PREVIEW';position:absolute;top:8px;right:12px;font-size:9px;color:#94a3b8;font-weight:900;letter-spacing:0.08em}
.doc-paper-meta{width:min(100%,794px);margin:0 auto 10px;display:flex;align-items:center;justify-content:space-between;gap:10px;color:#64748b;font-size:10px;font-weight:800;letter-spacing:.04em}
.doc-page-paper{width:min(100%,794px);min-height:1123px;margin:0 auto 6px;background:#fff;border:1px solid #e5e7eb;box-shadow:0 18px 42px rgba(15,23,42,.14),0 1px 0 rgba(255,255,255,.9) inset;padding:54px 46px;position:relative;color:#111827}
.doc-page-paper::after{content:'';position:absolute;left:46px;right:46px;bottom:28px;border-top:1px solid #e5e7eb}
.doc-page-watermark{position:absolute;right:44px;top:28px;font-size:10px;font-weight:900;color:#cbd5e1;letter-spacing:.16em}
.doc-case-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:12px;box-shadow:0 8px 20px rgba(15,23,42,.04)}
.doc-case-card{transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
.doc-case-card:hover{transform:translateY(-1px);box-shadow:0 12px 26px rgba(15,23,42,.08)}
.doc-case-card button{transition:background .12s ease,transform .12s ease}
.doc-case-card button:hover{transform:translateY(-1px)}
.doc-case-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:999px;font-size:10px;font-weight:900;white-space:nowrap}
/* R-NEW130: 旧 width:100% は doc-hist-row の flex 親で全幅を要求し、
   中央テキスト列を 10px 程度に圧縮、CJK 1文字/行折返し ("顧/客/未/選/択") を発生させていた。
   140px 固定 + flex-shrink:0 で右側カラムを安定化 */
.doc-status-select{width:140px;max-width:100%;height:28px;border:1px solid #dbe3ef;border-radius:8px;background:#fff;color:#334155;font-size:11px;font-weight:800;padding:0 8px;outline:none;cursor:pointer;flex-shrink:0}
.doc-status-select:focus{border-color:#10b981;box-shadow:0 0 0 3px rgba(16,185,129,.1)}
@media (max-width: 760px){
  .doc-readiness-panel{grid-template-columns:1fr!important}
  .doc-case-dashboard{padding:12px!important}
  .doc-page-paper{min-height:auto;padding:34px 22px}
  .doc-paper-meta{display:block;line-height:1.7}
  .doc-hist-row{align-items:flex-start;flex-wrap:wrap}
  .doc-hist-row .doc-status-select{width:140px}
}
/* ===== DOC HISTORY TABLE ===== */
.doc-hist-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid #f1f5f9;transition:background 0.12s;cursor:pointer}
.doc-hist-row:hover{background:#f8fafc}
/* R-NEW130: バッジに flex-shrink:0 を追加して中央テキストを潰さない */
.doc-hist-row .hist-badge{font-size:9px;font-weight:700;padding:2px 8px;border-radius:10px;white-space:nowrap;flex-shrink:0}
/* ===== CLAUSE SEARCH ===== */
.clause-search-input{width:100%;font-size:12px;padding:8px 12px 8px 32px;border:1.5px solid #e2e8f0;border-radius:8px;outline:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E") 10px center no-repeat;transition:border-color 0.15s}
.clause-search-input:focus{border-color:#10b981;box-shadow:0 0 0 3px rgba(16,185,129,0.08)}
/* ===== BANK CARDS ===== */
.bank-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;align-items:start}
.bank-card{
  background:var(--card-bg);border:2px solid var(--border);border-radius:var(--radius);
  padding:18px;cursor:pointer;transition:all 0.2s;position:relative;min-width:0;
}
.bank-grid > *, .analysis-grid > *{min-width:0}
.bank-grid .loan-grid-meta{
  grid-column:1 / -1;
  justify-self:end;
  width:100%;
  text-align:right;
  margin-bottom:4px;
}
.bank-card:hover{border-color:#c7d2fe;box-shadow:var(--shadow-md)}
.bank-card.selected{border-color:var(--indigo-500);background:#fafbff;box-shadow:0 0 0 3px rgba(16,185,129,0.1)}
.bank-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px;gap:12px}
.bank-card-header > *{min-width:0}
.bank-name{font-size:14px;font-weight:700;color:var(--text-primary);display:flex;align-items:center;flex-wrap:wrap;gap:5px}
.regional-badge{display:inline-flex;align-items:center;gap:2px;background:#dbeafe;color:#1d4ed8;border:1px solid #93c5fd;border-radius:4px;padding:1px 5px;font-size:9px;font-weight:700;letter-spacing:0.3px;white-space:nowrap;flex-shrink:0}
.bank-rate-main{font-size:24px;font-weight:800;color:var(--indigo-600);line-height:1}
.bank-rate-label{font-size:10px;color:var(--text-muted);font-weight:500}
.bank-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.bank-stat-item{text-align:center;min-width:0}
.bank-stat-val{font-size:15px;font-weight:700;color:var(--text-primary)}
.bank-stat-lab{font-size:10px;color:var(--text-muted);font-weight:500}
.bank-select-check{
  position:absolute;top:12px;right:12px;width:22px;height:22px;
  border-radius:50%;border:2px solid var(--border);background:#fff;
  display:flex;align-items:center;justify-content:center;transition:all 0.2s;
}
.bank-card.selected .bank-select-check{border-color:var(--indigo-500);background:var(--indigo-500)}
.bank-card.selected .bank-select-check::after{content:'\2713';font-size:12px;color:#fff;font-weight:700}
.bank-filter-sidebar{
  width:220px;flex-shrink:0;background:var(--card-bg);border:1px solid var(--border);
  border-radius:var(--radius);padding:20px;height:fit-content;position:sticky;top:0;
}
.bank-filter-title{font-size:13px;font-weight:700;color:var(--text-primary);margin-bottom:16px}
.filter-group{margin-bottom:18px}
.filter-label{font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:8px}
.filter-option{display:flex;align-items:center;gap:8px;padding:5px 0;cursor:pointer;font-size:13px;color:var(--text-primary)}
.filter-option input{cursor:pointer;accent-color:var(--indigo-500)}
.step2-layout{display:flex;gap:20px;align-items:flex-start}
.step2-banks{flex:1}

/* ===== RANK STAR BADGE ===== */
.bank-rank-star{
  position:absolute;top:-18px;left:14px;
  display:flex;align-items:center;justify-content:center;
  width:52px;height:52px;z-index:3;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,0.3));
}
.bank-rank-star svg{position:absolute;top:0;left:0;width:52px;height:52px}
.bank-rank-star .rnum{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  margin-top:2px;
}
.bank-rank-star .rnum .rn{font-size:16px;font-weight:900;line-height:1;letter-spacing:-0.5px}
.bank-rank-star .rnum .ri{font-size:9px;font-weight:700;line-height:1;margin-top:1px;letter-spacing:0}
.bank-rank-star.r1{color:#f59e0b}.bank-rank-star.r1 .rnum{color:#78350f}
.bank-rank-star.r2{color:#94a3b8}.bank-rank-star.r2 .rnum{color:#fff}
.bank-rank-star.r3{color:#b45309}.bank-rank-star.r3 .rnum{color:#fff}
/* Top-3 card accent top border */
.bank-card.rank-1{border-top:3px solid #f59e0b!important;padding-top:36px!important}
.bank-card.rank-2{border-top:3px solid #9ca3af!important;padding-top:36px!important}
.bank-card.rank-3{border-top:3px solid #b45309!important;padding-top:36px!important}

/* ===== TOOLTIPS ===== */
.tt{display:inline-flex;align-items:center;gap:3px;cursor:default}
/* tt-box is now driven by JS global tooltip — legacy .tt-box hidden */
.tt .tt-box{display:none}
.tt-q{
  display:inline-flex;align-items:center;justify-content:center;
  width:16px;height:16px;border-radius:50%;
  background:#10b981;color:#fff;
  font-size:9.5px;font-weight:800;flex-shrink:0;
  cursor:help;transition:background 0.15s;
}
.tt-q:hover{background:#059669}
/* Global fixed tooltip — never clipped by overflow:hidden */
#gTip{
  position:fixed;z-index:999999;
  background:#1e293b;color:#f1f5f9;
  font-size:13px;font-weight:400;line-height:1.65;
  padding:10px 14px;border-radius:9px;
  max-width:270px;width:max-content;
  box-shadow:0 8px 28px rgba(0,0,0,0.32);
  pointer-events:none;
  opacity:0;transition:opacity 0.15s;
}
#gTip.show{opacity:1}
#gTip.show-above::after{
  content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:6px solid transparent;border-top-color:#1e293b;
}
#gTip.show-below::after{
  content:'';position:absolute;bottom:100%;left:50%;transform:translateX(-50%);
  border:6px solid transparent;border-bottom-color:#1e293b;
}

/* ===== ANALYSIS CARDS ===== */
.analysis-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px}
.analysis-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);min-width:0}
.analysis-card-header{padding:16px 20px;background:linear-gradient(135deg,#f8faff,#f0f3ff);border-bottom:1px solid var(--border)}
.analysis-card-body{padding:20px}
.score-section{display:flex;align-items:center;gap:20px;margin-bottom:20px}
.score-circle-wrap{flex-shrink:0}
.score-info{flex:1}
.score-title{font-size:16px;font-weight:700;color:var(--text-primary)}
.score-monthly{font-size:22px;font-weight:800;color:var(--indigo-600)}
.score-monthly-label{font-size:11px;color:var(--text-muted)}
.score-breakdown{width:100%;border-collapse:collapse;margin-bottom:16px}
.score-breakdown th{font-size:10px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.5px;padding:6px 8px;background:#f9f9fb;border-bottom:1px solid var(--border)}
.score-breakdown td{padding:7px 8px;font-size:12.5px;border-bottom:1px solid #f4f4f5}
.score-breakdown tr:last-child td{border-bottom:none}
.score-bar-wrap{width:80px;height:6px;background:#e4e4e7;border-radius:3px;overflow:hidden}
.score-bar{height:100%;border-radius:3px;transition:width 0.5s}

.strategy-block{border-radius:8px;padding:14px;margin-top:16px}
.strategy-block.green{background:#f0fdf4;border:1px solid #bbf7d0}
.strategy-block.amber{background:#fffbeb;border:1px solid #fde68a}
.strategy-block.red{background:#fef2f2;border:1px solid #fecaca}
.strategy-fit{font-size:12px;font-weight:700;margin-bottom:8px}
.strategy-fit.green{color:#15803d}
.strategy-fit.amber{color:#92400e}
.strategy-fit.red{color:#991b1b}
.strategy-actions{list-style:none;padding:0}
.strategy-actions li{font-size:12.5px;color:var(--text-primary);padding:3px 0;padding-left:16px;position:relative}
.strategy-actions li::before{content:'→';position:absolute;left:0;color:var(--text-muted)}

/* ===== TOP 3 ===== */
.top3-section{background:linear-gradient(135deg,#1e1b4b,#312e81);border-radius:var(--radius);padding:24px;margin-bottom:24px;color:#fff}
.top3-title{font-size:16px;font-weight:800;margin-bottom:16px;color:#e0e7ff}
.top3-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.top3-card{background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);border-radius:10px;padding:16px;position:relative}
.top3-rank{
  position:absolute;top:-8px;left:16px;
  font-size:11px;font-weight:800;padding:2px 10px;border-radius:20px;
}
.top3-rank.r1{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#78350f}
.top3-rank.r2{background:linear-gradient(135deg,#94a3b8,#64748b);color:#fff}
.top3-rank.r3{background:linear-gradient(135deg,#d97706,#b45309);color:#fff}
.top3-bank{font-size:14px;font-weight:700;color:#fff;margin-top:10px;margin-bottom:6px}
.top3-score{font-size:28px;font-weight:800;color:#c7d2fe}
.top3-score-label{font-size:10px;color:rgba(255,255,255,0.5)}
.top3-reason{font-size:11.5px;color:rgba(255,255,255,0.6);margin-top:8px;line-height:1.5}
.top3-rate{font-size:13px;font-weight:600;color:#a5b4fc;margin-top:6px}

/* ===== COMPARISON TABLE ===== */
.compare-table{width:100%;border-collapse:collapse}
.compare-table th{background:#f9f9fb;padding:10px 14px;font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;border-bottom:2px solid var(--border)}
.compare-table td{padding:11px 14px;border-bottom:1px solid var(--border);font-size:13px}
.compare-table .row-label{font-weight:600;color:var(--text-primary);background:#f9f9fb;width:160px}

/* ===== CRM ===== */
.status-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:20px}
.status-tab{
  padding:6px 14px;border-radius:20px;font-size:12.5px;font-weight:600;
  cursor:pointer;border:1.5px solid var(--border);color:var(--text-secondary);
  background:#fff;transition:all 0.15s;
}
.status-tab.active{border-color:var(--indigo-500);color:#fff;background:var(--indigo-500);box-shadow:0 2px 8px rgba(16,185,129,0.35);transform:translateY(-1px)}
.status-tab:hover:not(.active){border-color:#d4d4d8;background:#f4f4f5}

/* ===== MODAL ===== */
#modalOverlay{
  position:fixed;inset:0;background:rgba(15,23,42,0.3);backdrop-filter:blur(4px);
  /* [FIX 2026-06-10 案B] 旧モーダル経路(#modalOverlay, 全28モーダル)が z-index 100000 で
     トップナビ(#appTabs, z 100001)より下にあり、背の高いモーダルの上端がタブバーに被っていた
     (物件登録モーダル等)。オーバーレイをナビより前面(--z-nav+3)に出し、表示中はナビを
     暗幕で覆う標準的なモーダル挙動に統一してこのクラスのバグを一掃する。背の高いモーダルの
     上端クリップ/スクロール不能を防ぐため flex-start + overflow-y:auto、短いモーダルは
     子要素の margin:auto で中央寄せを維持する。 */
  z-index:calc(var(--z-nav) + 3);display:none;align-items:flex-start;justify-content:center;padding:20px;overflow-y:auto;
  will-change:opacity,transform;transform:translateZ(0);transition:opacity 0.2s ease;
}
#modalOverlay.show{display:flex}
#modalOverlay > .modal,
#modalOverlay > #dynamicModal{margin:auto}
#modalOverlay:not(.show),
#modalOverlay:not(.show) *{
  pointer-events:none !important;
}
#modalOverlay:not(.show) .modal,
#modalOverlay:not(.show) .modal *{
  display:none !important;
  visibility:hidden !important;
}
#modalOverlay .modal[hidden],
#modalOverlay .modal[aria-hidden="true"]{
  display:none !important;
  visibility:hidden !important;
  pointer-events:none !important;
  position:absolute !important;
  left:-200vw !important;
  top:-200vh !important;
}
#modalActiveHost{
  position:fixed;
  inset:0;
  width:100%;
  max-width:100%;
  max-height:100%;
  display:grid;
  place-items:center;
  pointer-events:none;
  /* FIX: 顧客追加等のモーダルがホストに z-index が無く、sticky なトップナビ(.app-topbar)に
     上部を隠されていた。--z-nav より前面へ。pointer-events:none は維持しているので
     モーダル外のナビはクリック可能なまま（ナビ可用の意図を保つ）。 */
  z-index:calc(var(--z-nav) + 1);
  overflow:auto;            /* 縦長モーダルはスクロールで全体閲覧可能に */
  padding:76px 16px 24px;   /* 固定トップナビ(約60px)の下に収める */
}
#modalActiveHost > .modal{
  pointer-events:auto;
  /* FIX(2026-06-05): margin:0 + place-items:center だと「ビューポートより縦長のモーダル」が
     上下対称にはみ出し、上端が padding を突き破ってトップナビの裏に隠れていた（顧客詳細等）。
     margin:auto は短いモーダルは中央寄せのまま、縦長時はマージンが0に潰れて上詰め＋
     スクロールで全体に届く（auto margin が alignment より優先される仕様を利用）。 */
  margin:auto;
}
body.uls-modal-open .modal{
  display:none !important;
  visibility:hidden !important;
  pointer-events:none !important;
  position:absolute !important;
  left:-200vw !important;
  top:-200vh !important;
}
body.uls-modal-open .modal-overlay,
body.uls-modal-open .bb-modal-overlay,
body.uls-modal-open #customerUpdateOverlay,
body.uls-modal-open #paymentEntryOverlay,
body.uls-modal-open #ulsModalOverlay,
body.uls-modal-open .cs-accordion-header,
body.uls-modal-open .cs-accordion-body{
  visibility:hidden !important;
  pointer-events:none !important;
}
body.uls-modal-open .modal-overlay,
body.uls-modal-open .bb-modal-overlay,
body.uls-modal-open #customerUpdateOverlay,
body.uls-modal-open #paymentEntryOverlay,
body.uls-modal-open #ulsModalOverlay{
  opacity:0 !important;
}
/* スタンドアロンモーダルが明示的に表示されている場合の例外 */
#newsletterModal.standalone-visible,
#groupManagerModal.standalone-visible,
#groupFormModal.standalone-visible,
#groupNewsletterModal.standalone-visible{
  visibility:visible !important;
  pointer-events:auto !important;
  opacity:1 !important;
  display:flex !important;
}
#newsletterModal.standalone-visible > .modal,
#groupManagerModal.standalone-visible > .modal,
#groupFormModal.standalone-visible > .modal,
#groupNewsletterModal.standalone-visible > .modal{
  display:block !important;
  visibility:visible !important;
  pointer-events:auto !important;
  position:relative !important;
  left:auto !important;
  top:auto !important;
  opacity:1 !important;
}
body.uls-modal-open #modalActiveHost > .modal.is-active-modal{
  display:block !important;
  visibility:visible !important;
  pointer-events:auto !important;
  position:relative !important;
  left:auto !important;
  top:auto !important;
}
body.uls-modal-open #modalActiveHost > #dynamicModal.is-active-modal{
  display:flex !important;
}
#modalOverlay[data-active-modal] > .modal{
  display:none !important;
  visibility:hidden !important;
  pointer-events:none !important;
  position:absolute !important;
  left:-200vw !important;
  top:-200vh !important;
}
#modalOverlay[data-active-modal] > .modal.is-active-modal{
  display:block !important;
  visibility:visible !important;
  pointer-events:auto !important;
  position:relative !important;
  left:auto !important;
  top:auto !important;
}
#modalOverlay[data-active-modal] > #dynamicModal.is-active-modal{display:flex !important}
#modalOverlay[data-active-modal] > #editCustomerModal.is-active-modal,
#modalActiveHost > #editCustomerModal.is-active-modal{
  display:flex !important;
  flex-direction:column !important;
  overflow:hidden !important;
}
#editCustomerModal:not(.is-active-modal),
#customerDetailModal:not(.is-active-modal),
#newCustomerModal:not(.is-active-modal),
#newUserModal:not(.is-active-modal),
#resetPasswordModal:not(.is-active-modal),
#loanResultModal:not(.is-active-modal),
#formIssueModal:not(.is-active-modal),
#dynamicModal:not(.is-active-modal){
  display:none !important;
  visibility:hidden !important;
  pointer-events:none !important;
  position:absolute !important;
  left:-200vw !important;
  top:-200vh !important;
}
.modal[hidden],
.modal[hidden] *,
.modal[aria-hidden="true"],
.modal[aria-hidden="true"] *{
  visibility:hidden !important;
  pointer-events:none !important;
}
.modal[hidden] .modal-footer,
.modal[aria-hidden="true"] .modal-footer,
.modal[hidden] .cs-accordion-header,
.modal[hidden] .cs-accordion-body,
.modal[aria-hidden="true"] .cs-accordion-header,
.modal[aria-hidden="true"] .cs-accordion-body{
  display:none !important;
}
body.uls-modal-open .modal:not(.is-active-modal) .modal-footer,
body.uls-modal-open .modal:not(.is-active-modal) .cs-accordion-header,
body.uls-modal-open .modal:not(.is-active-modal) .cs-accordion-body{
  display:none !important;
  visibility:hidden !important;
  pointer-events:none !important;
}
body.uls-modal-open .modal.is-active-modal .modal-footer{
  display:flex !important;
  visibility:visible !important;
  pointer-events:auto !important;
}
#editCustomerModal.is-active-modal{
  display:flex !important;
  flex-direction:column !important;
  overflow:hidden !important;
  max-height:90vh !important;
  visibility:visible !important;
  pointer-events:auto !important;
  position:relative !important;
  left:auto !important;
  top:auto !important;
}
#editCustomerModal.is-active-modal > .modal-body{
  flex:1 !important;
  overflow-y:auto !important;
  min-height:0 !important;
}
#editCustomerModal.is-active-modal > .modal-footer{
  flex-shrink:0 !important;
  display:flex !important;
  visibility:visible !important;
  pointer-events:auto !important;
  position:relative !important;
  left:auto !important;
  top:auto !important;
  opacity:1 !important;
}
.modal{
  background:#fff;border-radius:16px;box-shadow:var(--shadow-xl);
  max-height:90vh;overflow-y:auto;position:relative;width:100%;
}
#dynamicModal{flex-direction:column;overflow:hidden}
.modal > #modal-body{
  display:flex;flex-direction:column;overflow:hidden;flex:1;min-height:0;
}
.modal > #modal-body > .modal-header{
  flex-shrink:0;
}
.modal > #modal-body > .modal-body{
  flex:1;overflow-y:auto;min-height:0;
}
.modal-sm{max-width:440px}
.modal-md{max-width:600px}
.modal-lg{max-width:760px}
.modal-xl{max-width:960px}
.modal-header{padding:20px 24px 0;display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.modal-title{font-size:17px;font-weight:800;color:var(--text-primary)}
.modal-close{
  width:44px;height:44px;border-radius:8px;border:none;background:#f4f4f5;cursor:pointer;
  font-size:16px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);
}
.modal-close:hover{background:#e4e4e7}
.modal-body{padding:0 24px 24px}
.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}
#ulsModalOverlay .uls-modal-shell,
#ulsModalOverlay .uls-modal-header,
#ulsModalOverlay .uls-modal-body,
#ulsModalOverlay .uls-modal-body > *,
#ulsModalOverlay .uls-modal-body [style*="display:grid"] > *,
#ulsModalOverlay .uls-modal-body [style*="display:flex"] > *,
#ulsModalOverlay .uls-modal-footer,
#ulsModalOverlay .uls-modal-footer > *{
  min-width:0;
  max-width:100%;
  box-sizing:border-box;
}
#ulsModalOverlay .uls-modal-shell{
  display:flex !important;
  flex-direction:column !important;
  flex-wrap:nowrap !important;
  overflow:hidden;
  max-height:calc(100dvh - 40px);
  min-height:0;
}
#ulsModalOverlay{
  flex-wrap:nowrap !important;
}
#ulsModalOverlay .uls-modal-header,
#ulsModalOverlay .uls-modal-body,
#ulsModalOverlay .uls-modal-footer{
  width:100% !important;
}
#ulsModalOverlay .uls-modal-body{
  width:100%;
  flex:1 1 auto;
  min-height:0;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
  padding-bottom:calc(20px + env(safe-area-inset-bottom));
}
#ulsModalOverlay .uls-modal-header,
#ulsModalOverlay .uls-modal-footer{
  flex-shrink:0;
}
#ulsModalOverlay .uls-modal-footer{
  position:sticky;
  bottom:0;
  z-index:5;
  box-shadow:0 -8px 20px rgba(15,23,42,.06);
}
#ulsModalOverlay.esign-wizard-overlay .esign-step-panel .esign-action-row,
#ulsModalOverlay.esign-wizard-overlay .esign-step-panel .esign-nav-row{
  display:none !important;
}
#ulsModalOverlay .esign-wizard-footer-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  width:100%;
}
#ulsModalOverlay .esign-wizard-footer-left,
#ulsModalOverlay .esign-wizard-footer-actions{
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
  flex-wrap:wrap;
}
#ulsModalOverlay .esign-wizard-footer-actions{
  justify-content:flex-end;
}
#ulsModalOverlay .esign-wizard-footer-inner button{
  min-height:40px;
}
#ulsModalOverlay .uls-modal-body .esign-create-flow{
  flex-direction:column !important;
  flex-wrap:nowrap !important;
  align-items:stretch !important;
  overflow:visible !important;
  width:auto !important;
}
#ulsModalOverlay .uls-modal-body .esign-create-flow > *{
  width:100% !important;
  max-width:100% !important;
  flex:0 0 auto !important;
}
#ulsModalOverlay .uls-modal-body .esign-step-panel{
  flex:0 0 auto !important;
}
#ulsModalOverlay .uls-modal-body .u-d-none,
#ulsModalOverlay .uls-modal-body input.u-d-none,
#ulsModalOverlay .uls-modal-body select.u-d-none,
#ulsModalOverlay .uls-modal-body textarea.u-d-none{
  display:none !important;
}
#ulsModalOverlay .esign-step-panel .esign-action-row,
#ulsModalOverlay .esign-step-panel .esign-nav-row{
  position:sticky;
  bottom:0;
  z-index:4;
  padding-top:12px;
  background:linear-gradient(180deg, rgba(255,255,255,.82) 0%, #fff 32%);
  box-shadow:0 -10px 18px rgba(15,23,42,.04);
}
#ulsModalOverlay .uls-modal-body .form-group,
#ulsModalOverlay .uls-modal-body .form-row,
#ulsModalOverlay .uls-modal-body .form-row-3,
#ulsModalOverlay .uls-modal-body label,
#ulsModalOverlay .uls-modal-body [style*="display:grid"],
#ulsModalOverlay .uls-modal-body [style*="display:flex"]{
  min-width:0;
  max-width:100%;
  box-sizing:border-box;
}
#ulsModalOverlay .uls-modal-body .form-row{
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
}
#ulsModalOverlay .uls-modal-body .form-row-3{
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr);
}
#ulsModalOverlay .uls-modal-body [style*="display:flex"]{
  flex-wrap:wrap;
}
#ulsModalOverlay .uls-modal-body [style*="display:flex"] > *{
  min-width:0;
  max-width:100%;
  box-sizing:border-box;
}
#ulsModalOverlay .uls-modal-body [style*="grid-template-columns:1fr 1fr"]{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important;
}
#ulsModalOverlay .uls-modal-body [style*="grid-template-columns: 1fr 1fr"]{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important;
}
#ulsModalOverlay .uls-modal-body [style*="grid-template-columns:1fr 1fr 1fr"]{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) !important;
}
#ulsModalOverlay .uls-modal-body [style*="grid-template-columns: 1fr 1fr 1fr"]{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) !important;
}
#ulsModalOverlay .uls-modal-body input,
#ulsModalOverlay .uls-modal-body select,
#ulsModalOverlay .uls-modal-body textarea,
#ulsModalOverlay .uls-modal-body .form-control{
  display:block;
  width:100%;
  max-width:100%;
  min-width:0;
  box-sizing:border-box;
}
@media (max-width: 768px){
  #ulsModalOverlay{
    padding:8px !important;
  }
  #ulsModalOverlay .uls-modal-shell{
    max-height:calc(100dvh - 16px) !important;
    border-radius:12px !important;
  }
  #ulsModalOverlay .uls-modal-header{
    padding:14px 16px !important;
  }
  #ulsModalOverlay .uls-modal-body{
    padding:16px !important;
    padding-bottom:calc(18px + env(safe-area-inset-bottom)) !important;
    overflow-x:hidden !important;
  }
  #ulsModalOverlay.esign-wizard-overlay #esignSteps{
    overflow-x:auto !important;
    overflow-y:hidden !important;
    flex-wrap:nowrap !important;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  #ulsModalOverlay.esign-wizard-overlay #esignSteps::-webkit-scrollbar{
    display:none;
  }
  #ulsModalOverlay.esign-wizard-overlay #esignSteps .esign-step{
    flex:0 0 112px !important;
    min-width:112px !important;
    white-space:normal !important;
  }
  #ulsModalOverlay.esign-wizard-overlay .esign-step-split{
    display:flex !important;
    flex-direction:column !important;
    gap:12px !important;
    min-height:0 !important;
    max-height:none !important;
  }
  #ulsModalOverlay.esign-wizard-overlay .esign-step-split > *{
    width:100% !important;
    max-width:100% !important;
    flex:0 0 auto !important;
  }
  #ulsModalOverlay.esign-wizard-overlay #esignFieldPalette{
    position:relative !important;
    top:auto !important;
    align-self:stretch !important;
  }
  #ulsModalOverlay.esign-wizard-overlay #esignDocOuter{
    width:100% !important;
    max-height:420px !important;
    min-height:360px !important;
  }
  #ulsModalOverlay.esign-wizard-overlay #esignDocCanvas{
    width:100% !important;
    min-height:560px !important;
  }
  #ulsModalOverlay .uls-modal-footer{
    padding:12px 16px !important;
    padding-bottom:calc(12px + env(safe-area-inset-bottom)) !important;
  }
  #ulsModalOverlay .esign-step-panel .esign-action-row,
  #ulsModalOverlay .esign-step-panel .esign-nav-row{
    align-items:stretch !important;
    gap:8px !important;
  }
  #ulsModalOverlay .esign-step-panel .esign-action-row button,
  #ulsModalOverlay .esign-step-panel .esign-nav-row button{
    min-height:44px;
  }
  #ulsModalOverlay .esign-wizard-footer-inner{
    align-items:stretch;
    flex-direction:column;
  }
  #ulsModalOverlay .esign-wizard-footer-left,
  #ulsModalOverlay .esign-wizard-footer-actions,
  #ulsModalOverlay .esign-wizard-footer-inner button{
    width:100%;
  }
  #ulsModalOverlay .esign-wizard-footer-left,
  #ulsModalOverlay .esign-wizard-footer-actions{
    justify-content:stretch;
  }
}
@media (max-width: 768px){
  .admin-tabs{
    overflow-x:auto !important;
    overflow-y:hidden !important;
    flex-wrap:nowrap !important;
    gap:0 !important;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .admin-tabs::-webkit-scrollbar{
    display:none;
  }
  .admin-tab{
    flex:0 0 auto !important;
    min-width:max-content !important;
    padding:12px 16px !important;
    white-space:nowrap !important;
    writing-mode:horizontal-tb !important;
    line-height:1.2 !important;
  }
  #adminTab-users .table-wrap{
    overflow-x:visible !important;
  }
  #adminTab-users .admin-users-table{
    min-width:0 !important;
    width:100% !important;
    border-collapse:separate !important;
    border-spacing:0 10px !important;
  }
  #adminTab-users .admin-users-table thead{
    display:none !important;
  }
  #adminTab-users .admin-users-table tbody,
  #adminTab-users .admin-users-table tr,
  #adminTab-users .admin-users-table td{
    display:block !important;
    width:100% !important;
    box-sizing:border-box !important;
  }
  #adminTab-users .admin-users-table tr{
    border:1px solid #e2e8f0 !important;
    border-radius:14px !important;
    background:#fff !important;
    padding:8px 12px !important;
    box-shadow:0 8px 18px rgba(15,23,42,.04) !important;
  }
  #adminTab-users .admin-users-table td{
    border:0 !important;
    padding:9px 0 !important;
    min-width:0 !important;
  }
  #adminTab-users .admin-users-table td:not([colspan]){
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:12px !important;
    border-bottom:1px solid #f1f5f9 !important;
    text-align:right !important;
  }
  #adminTab-users .admin-users-table td:not([colspan])::before{
    content:attr(data-label);
    color:#64748b;
    font-size:11px;
    font-weight:900;
    letter-spacing:.03em;
    white-space:nowrap;
    flex:0 0 auto;
  }
  #adminTab-users .admin-users-table td > *{
    min-width:0;
    max-width:100%;
    overflow-wrap:anywhere;
  }
  #adminTab-users .admin-users-table td:last-child{
    border-bottom:0 !important;
  }
  #adminTab-users .admin-users-table td[colspan]{
    padding:24px 10px !important;
    text-align:center !important;
  }
  #view-documents [style*="grid-template-columns:280px"]{
    display:grid !important;
    grid-template-columns:minmax(0,1fr) !important;
    gap:12px !important;
  }
  #view-documents [style*="min-height:540px"]{
    min-height:360px !important;
  }
  #view-documents #docPreviewBody{
    min-height:320px !important;
    max-height:70dvh !important;
    overflow:auto !important;
  }
  #view-documents #docPreviewActions{
    width:100% !important;
    justify-content:flex-start !important;
  }
  #view-esign [style*="grid-template-columns:minmax(220px,1.5fr)"]{
    display:grid !important;
    grid-template-columns:minmax(0,1fr) !important;
  }
  #view-admin .card{
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch;
  }
  #view-admin table{
    min-width:640px;
  }
}
#newUserModal .form-row{
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:12px;
}
#newUserModal .form-group,
#newUserModal .form-control,
#newUserModal select.form-control{
  min-width:0;
  width:100%;
  max-width:100%;
  box-sizing:border-box;
}

/* ===== E-SIGN TABLE & VIEW ===== */
#esignViewContent table,
#rmTabPanel-esign table{
  border-collapse:separate;
  border-spacing:0;
  border:1px solid #e2e8f0;
  border-radius:10px;
  overflow:hidden;
}
#esignViewContent thead tr,
#rmTabPanel-esign thead tr{
  background:#f8fafc !important;
}
#esignViewContent th,
#rmTabPanel-esign th{
  padding:12px !important;
  font-size:11px !important;
  font-weight:600 !important;
  color:#64748b !important;
  text-transform:uppercase;
  letter-spacing:0.5px;
  border-bottom:1px solid #e2e8f0 !important;
}
#esignViewContent tbody tr,
#rmTabPanel-esign tbody tr{
  background:#fff;
}
#esignViewContent tbody tr:last-child td,
#rmTabPanel-esign tbody tr:last-child td{
  border-bottom:none !important;
}

/* ===== E-SIGN FORM LAYOUT ===== */
.esign-create-flow,
.esign-step-panel,
.esign-signer-list,
.esign-signer-card,
.esign-signer-card-header,
.esign-signer-grid,
.esign-settings-grid,
.esign-step-toolbar,
.esign-step-split,
.esign-step-panel > div,
.esign-file-drop,
.esign-action-row,
.esign-nav-row{
  width:100%;
  max-width:100%;
  min-width:0;
  box-sizing:border-box;
}
.esign-step-panel{
  min-width:0;
}
.esign-step-toolbar{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:12px;
}
.esign-step-split{
  display:flex;
  align-items:flex-start;
  gap:16px;
  width:100%;
  max-width:100%;
  min-width:0;
  min-height:700px;
}
.esign-step-split > *{
  min-width:0;
  max-width:100%;
  box-sizing:border-box;
}
.esign-step-split > :first-child{
  flex:0 0 180px;
  width:180px;
}
.esign-step-split > :last-child{
  flex:1 1 auto;
}
.esign-step-panel .form-group,
.esign-step-panel .form-label{
  min-width:0;
}
.esign-step-panel .form-group{
  display:flex;
  flex-direction:column;
}
.esign-step-panel .form-row,
.esign-step-panel .form-row-3{
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
}
.esign-step-panel .form-row-3{
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr);
}
.esign-step-panel .form-control,
.esign-step-panel select.form-control,
.esign-step-panel textarea.form-control{
  display:block;
  width:100%;
  max-width:100%;
  min-width:0;
  box-sizing:border-box;
}
.esign-step-panel textarea.form-control{
  resize:vertical;
}
.esign-signer-grid,
.esign-settings-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:12px;
  align-items:start;
}
.esign-signer-card{
  overflow:hidden;
}
.esign-signer-card-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:10px;
}
.esign-signer-card > div{
  min-width:0;
}
.esign-signer-grid > *,
.esign-settings-grid > *,
.esign-action-row > *,
.esign-nav-row > *{
  min-width:0;
}
.esign-signer-grid .form-group,
.esign-settings-grid .form-group{
  width:100%;
  max-width:100%;
  min-width:0;
}
.esign-signer-grid .form-control,
.esign-settings-grid .form-control,
.esign-signer-grid select.form-control,
.esign-settings-grid select.form-control{
  width:100%;
  max-width:100%;
  min-width:0;
}
.esign-step-panel [style*="grid-template-columns:1fr 1fr"]{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important;
}
.esign-step-panel [style*="grid-template-columns:1fr 1fr 1fr"]{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) !important;
}
.esign-step-panel [style*="display:flex"][style*="gap:16px"] > *{
  min-width:0;
}
.esign-action-row,
.esign-nav-row{
  display:flex;
  gap:8px;
  align-items:center;
}
.esign-action-row{
  justify-content:flex-end;
}
.esign-nav-row{
  justify-content:space-between;
}
.esign-file-drop{
  overflow:hidden;
}
.esign-file-drop *{
  max-width:100%;
}
.esign-file-drop svg{
  flex-shrink:0;
}
.esign-signer-card .form-group{
  margin-bottom:0;
}
.esign-signer-card input,
.esign-signer-card select,
.esign-signer-card textarea,
.esign-step-panel input,
.esign-step-panel select,
.esign-step-panel textarea{
  min-width:0;
  width:100%;
  max-width:100%;
  box-sizing:border-box;
}

/* ===== STATUS TIMELINE ===== */
.timeline{list-style:none;padding:0;position:relative}
.timeline::before{content:'';position:absolute;left:10px;top:0;bottom:0;width:2px;background:var(--border)}
.timeline-item{padding-left:30px;padding-bottom:16px;position:relative}
.timeline-dot{position:absolute;left:4px;top:4px;width:14px;height:14px;border-radius:50%;background:var(--indigo-500);border:2px solid #fff;box-shadow:0 0 0 2px var(--indigo-500)}
.timeline-date{font-size:11px;color:var(--text-muted);margin-bottom:3px}
.timeline-status{font-size:13px;font-weight:600;color:var(--text-primary)}
.timeline-note{font-size:12px;color:var(--text-secondary);margin-top:2px}

/* ===== ADMIN ===== */
.admin-tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:24px}
.admin-tab{
  padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer;
  color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-2px;
  transition:all 0.15s;
}
.admin-tab.active{color:var(--indigo-600);border-bottom-color:var(--indigo-500)}
.admin-tab:hover:not(.active){color:var(--text-primary)}

/* ===== ALERTS / TOAST ===== */
#toastContainer{position:fixed;bottom:20px;right:20px;z-index:var(--z-toast);display:flex;flex-direction:column;gap:8px}
.toast{
  background:rgba(255,255,255,0.98);color:#111827;padding:12px 18px;border-radius:12px;
  font-size:13.5px;font-weight:500;box-shadow:var(--shadow-lg);
  display:flex;align-items:flex-start;gap:8px;
  animation:toastIn 0.3s ease;min-width:240px;
  border:1px solid rgba(226,232,240,0.95);
  backdrop-filter:blur(8px);
}
.toast.success{border-left:4px solid #22c55e;background:rgba(240,253,244,0.98)}
.toast.error{border-left:4px solid #ef4444;background:rgba(254,242,242,0.99)}
.toast.info{border-left:4px solid #10b981;background:rgba(238,242,255,0.98)}
.toast.warn{border-left:4px solid #f59e0b;background:rgba(255,251,235,0.99)}
@keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(20px)}}
@keyframes refiPulse{0%{box-shadow:0 0 0 0 rgba(245,158,11,0.5)}50%{box-shadow:0 0 0 8px rgba(245,158,11,0)}100%{box-shadow:0 0 0 0 rgba(245,158,11,0)}}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.3);z-index:var(--z-modal);display:none;align-items:center;justify-content:center;will-change:opacity,transform;transform:translateZ(0);transition:opacity 0.2s ease}

/* ===== PREMIUM QUALITY OVERHAUL ===== */
/* Premium card hover */
.card{transition:box-shadow 0.2s ease,transform 0.15s ease}
/* KPI card glassmorphism */
.kpi-card{
  background:linear-gradient(135deg,#fff 0%,rgba(238,242,255,0.6) 100%);
  border:1px solid rgba(16,185,129,0.1);
  position:relative;overflow:hidden;transition:all 0.3s ease;
}
.kpi-card::after{
  content:'';position:absolute;top:-40px;right:-40px;width:120px;height:120px;
  background:radial-gradient(circle,rgba(16,185,129,0.08) 0%,transparent 70%);
  pointer-events:none;
}
.kpi-card:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(16,185,129,0.15)}
/* Animated number entrance */
@keyframes kpiIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.kpi-value{animation:kpiIn 0.5s cubic-bezier(0.16,1,0.3,1) both}
/* Premium button */
.btn-primary{background:linear-gradient(135deg,#10b981,#8b5cf6)!important;box-shadow:0 2px 8px rgba(16,185,129,0.3);transition:all 0.2s ease}
.btn-primary:hover{box-shadow:0 4px 20px rgba(16,185,129,0.45)!important;transform:translateY(-1px)}
/* Live pulse dot */
@keyframes livePulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.4;transform:scale(1.5)}}
.live-dot{animation:livePulse 2s ease infinite}
/* Slide up entrance */
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
/* Property card image area */
.prop-img-area{min-height:90px;display:flex;align-items:center;justify-content:center;font-size:40px;position:relative}
/* Premium badge hover */
.nav-item{transition:all 0.15s ease}
/* Smooth dashboard entrance */
#view-dashboard .card{animation:slideUp 0.4s cubic-bezier(0.16,1,0.3,1) both}
/* Dashboard pipeline bar */
.dash-pipe-bar{transition:width 0.8s cubic-bezier(0.16,1,0.3,1)}
/* Document progress bar */
#docProgressBar{transition:width 0.8s cubic-bezier(0.16,1,0.3,1)}
/* Doc checklist item */
.doc-item{transition:all 0.15s ease;cursor:pointer}
.doc-item:hover{background:#f8fafc!important;transform:translateX(2px)}

/* ===== PREPAYMENT ===== */
.sim-result{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #bbf7d0;border-radius:10px;padding:18px;margin-top:16px}
.sim-saving{font-size:28px;font-weight:800;color:#15803d}
.sim-label{font-size:12px;color:#166534;margin-top:4px}
.rate-scenario-table{width:100%;border-collapse:collapse}
.rate-scenario-table th{background:#f9f9fb;padding:8px 12px;font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;border-bottom:1px solid var(--border)}
.rate-scenario-table td{padding:9px 12px;border-bottom:1px solid var(--border);font-size:13px}

/* ===== ADVICE ===== */
.advice-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:10px}
.advice-item{
  display:flex;gap:12px;padding:14px;background:#f8faff;
  border:1px solid #e0e7ff;border-radius:8px;align-items:flex-start;
}
.advice-icon{font-size:18px;flex-shrink:0;margin-top:1px}
.advice-text{font-size:13.5px;color:var(--text-primary);line-height:1.5}

/* ===== MISC ===== */
.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}
.empty-state-icon{font-size:48px;margin-bottom:12px}
.empty-state-text{font-size:15px;font-weight:600;color:var(--text-secondary)}
.empty-state-sub{font-size:13px;margin-top:6px}
.section-divider{height:1px;background:var(--border);margin:24px 0}
.text-right{text-align:right}
.text-center{text-align:center}
.text-success{color:#16a34a}
.text-danger{color:#dc2626}
.text-muted{color:var(--text-muted)}
.fw-700{font-weight:700}
.flex{display:flex}
.flex-col{flex-direction:column}
.items-center{align-items:center}
.justify-between{justify-content:space-between}
.gap-8{gap:8px}
.gap-12{gap:12px}
.gap-16{gap:16px}
.mb-16{margin-bottom:16px}
.mb-24{margin-bottom:24px}
.mt-16{margin-top:16px}
.mt-24{margin-top:24px}
.inline-tag{
  display:inline-block;background:#f4f4f5;border:1px solid var(--border);
  border-radius:4px;padding:1px 6px;font-size:11px;font-weight:600;color:var(--text-secondary);
}
.loading-spinner{
  display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,0.3);
  border-top-color:#fff;border-radius:50%;animation:spin 0.7s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.score-circle-wrap svg text{font-family:'Inter',sans-serif}

/* ===== CUSTOMER FORM SCREEN ===== */
#customerScreen{
  min-height:100vh;
  background:linear-gradient(160deg,#f0f4ff 0%,#faf5ff 50%,#f0fdf4 100%);
  display:flex;align-items:flex-start;justify-content:center;
  padding:24px 16px 48px;
}
.cs-wrap{width:100%;max-width:520px}
.cs-header{text-align:center;padding:32px 0 28px}
.cs-logo-icon{
  width:48px;height:48px;border-radius:14px;
  background:linear-gradient(135deg,#10b981,#8b5cf6);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:800;color:#fff;
  margin:0 auto 12px;
}
.cs-title{font-size:22px;font-weight:800;color:#1e293b;margin-bottom:4px}
.cs-subtitle{font-size:13px;color:#64748b}
.cs-agent-tag{
  display:inline-flex;align-items:center;gap:6px;
  background:#dcfce7;color:#10b981;
  font-size:12px;font-weight:600;
  padding:4px 12px;border-radius:999px;margin-top:10px;
}
.cs-card{
  background:#fff;border-radius:16px;
  box-shadow:0 4px 24px rgba(0,0,0,0.08);
  padding:28px 24px;margin-bottom:16px;
}
.cs-card-title{font-size:13px;font-weight:700;color:#10b981;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:16px}
.cs-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cs-field{margin-bottom:14px}
.cs-field label{display:block;font-size:12px;font-weight:600;color:#475569;margin-bottom:5px}
.cs-field label .req{color:#ef4444;margin-left:2px}
.cs-field input,.cs-field select{
  width:100%;padding:10px 14px;
  border:1.5px solid #e2e8f0;border-radius:8px;
  font-size:15px;color:#1e293b;
  background:#fafafa;outline:none;
  transition:border-color 0.2s,box-shadow 0.2s;
}
.cs-field input:focus,.cs-field select:focus{
  border-color:#10b981;box-shadow:0 0 0 3px rgba(16,185,129,0.12);background:#fff;
}
.cs-notice{
  font-size:11px;color:#94a3b8;
  background:#f8fafc;border:1px solid #e2e8f0;
  border-radius:8px;padding:10px 14px;
  margin-bottom:16px;line-height:1.6;
}
.cs-btn{
  width:100%;padding:14px;
  background:linear-gradient(135deg,#10b981,#8b5cf6);
  color:#fff;font-size:16px;font-weight:700;
  border:none;border-radius:10px;cursor:pointer;
  box-shadow:0 4px 16px rgba(16,185,129,0.35);
  transition:opacity 0.2s,transform 0.1s;
}
.cs-btn:hover{opacity:0.92}
.cs-btn:active{transform:scale(0.98)}
.cs-accordion-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:12px 16px;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;margin-bottom:4px;user-select:none;transition:all 0.2s}
.cs-accordion-header:hover{background:#eef2ff;border-color:#c7d2fe}
.cs-accordion-header .cs-acc-title{font-size:13px;font-weight:700;color:#374151;display:flex;align-items:center;gap:8px}
.cs-accordion-header .cs-acc-arrow{font-size:14px;color:#94a3b8;transition:transform 0.25s}
.cs-accordion-header.open .cs-acc-arrow{transform:rotate(180deg)}
.cs-accordion-header.open{background:#eef2ff;border-color:#a5b4fc;border-bottom-left-radius:0;border-bottom-right-radius:0;margin-bottom:0}
.cs-accordion-body{overflow:hidden;max-height:0;opacity:0;transition:max-height 0.35s ease,opacity 0.25s ease,padding 0.25s ease;border:1.5px solid #e2e8f0;border-top:none;border-bottom-left-radius:10px;border-bottom-right-radius:10px;padding:0 16px;background:#fff}
.cs-accordion-body.open{max-height:2000px;opacity:1;padding:16px;border-color:#a5b4fc}
.cs-field.cs-invalid input,.cs-field.cs-invalid select,.form-group.cs-invalid input,.form-group.cs-invalid select{border-color:#ef4444 !important;box-shadow:0 0 0 3px rgba(239,68,68,0.12) !important}
.cs-field.cs-invalid label,.form-group.cs-invalid .form-label{color:#ef4444 !important}
.cs-helper-text{font-size:11px;color:#10b981;margin-top:4px;font-weight:600;min-height:16px;transition:opacity 0.2s}
.cs-draft-banner{background:#fef3c7;border:1.5px solid #fbbf24;border-radius:10px;padding:12px 16px;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.cs-draft-banner-text{font-size:12px;font-weight:600;color:#92400e;flex:1}
.cs-draft-banner button{padding:6px 14px;border-radius:6px;font-size:12px;font-weight:700;border:none;cursor:pointer}
.cs-draft-banner .cs-draft-restore{background:#f59e0b;color:#fff}
.cs-draft-banner .cs-draft-discard{background:#e2e8f0;color:#64748b;margin-left:6px}
.cs-diff-toast{position:fixed;bottom:24px;right:24px;z-index:var(--z-toast);background:#1e293b;color:#fff;border-radius:12px;padding:16px 20px;max-width:360px;box-shadow:0 8px 32px rgba(0,0,0,0.3);animation:csSlideUp 0.3s ease;font-size:12px;line-height:1.6}
.cs-diff-toast .cs-diff-title{font-weight:700;font-size:13px;margin-bottom:8px;color:#a5b4fc}
.cs-diff-item{display:flex;gap:6px;margin-bottom:4px}
.cs-diff-item .cs-diff-label{color:#94a3b8;min-width:70px}
.cs-diff-item .cs-diff-old{color:#fca5a5;text-decoration:line-through}
.cs-diff-item .cs-diff-new{color:#86efac;font-weight:600}
@keyframes csSlideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
/* Result screen after customer submits */
#csResult{display:none}
.cs-result-card{
  background:#fff;border-radius:16px;
  box-shadow:0 4px 24px rgba(0,0,0,0.08);
  padding:32px 24px;text-align:center;
}
.cs-result-icon{font-size:48px;margin-bottom:12px}
.cs-result-title{font-size:20px;font-weight:800;color:#1e293b;margin-bottom:6px}
.cs-result-sub{font-size:13px;color:#64748b;margin-bottom:24px}
.cs-code-box{
  background:#f1f5f9;border:2px dashed #cbd5e1;
  border-radius:12px;padding:20px;margin-bottom:20px;
}
.cs-code-label{font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:0.08em;margin-bottom:8px}
.cs-code-value{
  font-size:28px;font-weight:800;letter-spacing:4px;
  color:#10b981;font-family:'SF Mono',Consolas,monospace;
  margin-bottom:8px;word-break:break-all;
}
.cs-code-hint{font-size:12px;color:#94a3b8}
.cs-copy-btn{
  width:100%;padding:12px;
  background:#10b981;color:#fff;
  font-size:14px;font-weight:600;
  border:none;border-radius:8px;cursor:pointer;
  margin-bottom:10px;transition:opacity 0.2s;
}
.cs-copy-btn:hover{opacity:0.88}
.cs-line-btn{
  width:100%;padding:12px;
  background:#06c755;color:#fff;
  font-size:14px;font-weight:600;
  border:none;border-radius:8px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:opacity 0.2s;
}
.cs-line-btn:hover{opacity:0.88}

/* フォーム発行 & インポートモーダル */
.form-issue-url{
  background:#f1f5f9;border:1.5px solid #e2e8f0;
  border-radius:8px;padding:12px 14px;
  font-size:12px;color:#475569;
  word-break:break-all;margin-bottom:12px;
  font-family:'SF Mono',Consolas,monospace;
}
.import-preview{
  background:#f8fafc;border:1.5px solid #e2e8f0;
  border-radius:10px;padding:16px;margin:16px 0;
}
.import-preview-row{
  display:flex;justify-content:space-between;
  padding:6px 0;font-size:13px;
  border-bottom:1px solid #f1f5f9;
}
.import-preview-row:last-child{border-bottom:none}
.import-preview-label{color:#64748b;font-weight:500}
.import-preview-value{color:#1e293b;font-weight:600}

/* ===== PRINT ===== */
@media print{
  body{background:#fff}
  .sidebar,.view-header .btn,.wizard-progress,.step-nav-btns,#toastContainer,.status-tabs .btn,.modal{display:none!important}
  #appShell{display:block}
  .main-content{overflow:visible}
  .view{padding:0;min-height:auto}
  .analysis-card,.card{box-shadow:none;break-inside:avoid}
  .top3-section{background:linear-gradient(135deg,#1e1b4b,#312e81)!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .top3-grid{grid-template-columns:1fr 1fr}
}
/* ⑧ モバイル最適化 — 包括的レスポンシブ対応 */
@media (max-width: 768px) {
  body {
    --mobile-safe-bottom: calc(env(safe-area-inset-bottom, 0px) + 16px);
    --mobile-floating-size: 48px;
    --mobile-floating-gap: 12px;
    --mobile-floating-stack: calc(var(--mobile-safe-bottom) + var(--mobile-floating-size) + var(--mobile-floating-gap));
  }

  /* === PC topbar hide on mobile === */
  .app-topbar, .app-tabs, #trialBannerTop { display: none !important; }
  #appShell { flex-direction: row !important; }
  /* === サイドバー === */
  /* agent-06: navigation improvement — transform-based slide + cubic-bezier */
  .sidebar {
    position: fixed;
    left: 0;
    top: 0;
    height: 100%;
    width: 240px !important;
    min-width: 240px !important;
    z-index: 800;
    transform: none !important;
    background: transparent !important;
    border-right: none !important;
    box-shadow: none !important;
    overflow: visible !important;
    pointer-events: none;
  }
  .sidebar > :not(#mobileHamburger) {
    transform: translateX(-100%);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  }
  .sb-logo-text,.sb-logo-tagline,.nav-item span,.user-details,.role-badge,.logout-btn span{display:none}
  /* agent-06: navigation improvement — transform-based open */
  .sidebar.mobile-open {
    background: var(--sidebar-bg) !important;
    border-right: 1px solid rgba(255,255,255,0.05) !important;
    box-shadow: 0 16px 48px rgba(2,6,23,0.32) !important;
    pointer-events: auto;
  }
  .sidebar.mobile-open > :not(#mobileHamburger) {
    transform: translateX(0);
  }
  .sidebar.mobile-open .sb-logo-text,
  .sidebar.mobile-open .sb-logo-tagline,
  .sidebar.mobile-open .nav-item span,
  .sidebar.mobile-open .user-details,
  .sidebar.mobile-open .role-badge,
  .sidebar.mobile-open .logout-btn span {
    display: block !important;
  }
  .sidebar.mobile-open .nav-item {
    justify-content: flex-start !important;
    padding: 10px 20px !important;
  }
  .sidebar-toggle-mobile { display: flex !important; }
  #mobileHamburger {
    display: flex !important;
    position: fixed !important;
    top: 12px !important;
    left: 12px !important;
    z-index: 1200 !important;
    pointer-events: auto !important;
  }
  .sidebar.mobile-open + * #mobileHamburger,
  .sidebar.mobile-open ~ #mobileHamburger { display: none !important; }

  /* === メインコンテンツ === */
  .main-content {
    margin-left: 0 !important;
    padding: 56px 12px calc(var(--mobile-floating-stack) + 28px) !important;
  }
  /* agent-04: mobile view padding */
  .view { padding: 16px 12px !important; }
  body.loan-view-active .main-content {
    padding-bottom: calc(var(--mobile-floating-stack) + 84px) !important;
  }
  .view-header {
    flex-direction: column !important;
    gap: 8px !important;
    align-items: flex-start !important;
  }
  .view-title { font-size: 18px !important; }
  .view-subtitle { font-size: 12px !important; }

  /* === 認証画面（ログイン・登録・会社登録・初回セットアップ） === */
  .auth-bg {
    flex-direction: column !important;
    min-height: 100vh;
    position: relative !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
  }
  .auth-brand {
    width: 100% !important;
    padding: 28px 20px !important;
    min-height: auto !important;
  }
  .auth-brand-inner { max-width: 100% !important; }
  .auth-brand-tagline h2 { font-size: 20px !important; }
  .auth-brand-tagline p { font-size: 12px !important; margin-bottom: 16px !important; }
  .auth-brand-feat { font-size: 12px !important; padding: 8px 0 !important; }
  .auth-logo-lockup{margin-bottom:20px}
  .auth-logo-mark{width:44px;height:44px;border-radius:13px}
  .auth-logo-name{font-size:21px;letter-spacing:2px}
  .auth-logo-subtitle{font-size:9px;letter-spacing:.8px}
  .auth-ops-eyebrow{font-size:9px;margin-bottom:8px}
  .auth-workflow-board{padding:12px;border-radius:12px}
  .auth-workflow-item{
    grid-template-columns:44px minmax(0,1fr);
    gap:7px 9px;
    padding:9px 10px;
  }
  .auth-workflow-item em{
    grid-column:2;
    justify-self:start;
  }
  .auth-proof-row{grid-template-columns:minmax(0,1fr);gap:6px}
  .auth-proof-card{display:flex;justify-content:space-between;align-items:center;padding:8px 10px}
  .auth-proof-card span{margin:0}
  .auth-proof-card strong{text-align:right}
  .auth-form-panel {
    width: 100% !important;
    padding: 24px 20px !important;
  }
  .auth-form-wrap {
    padding: 20px 16px 40px !important;
    min-height: auto !important;
  }
  .auth-form-inner { max-width: 100% !important; }
  .auth-form-head h2 { font-size: 20px !important; }

  /* === 認証フォーム内の2カラム→1カラム化 === */
  .auth-form-inner [style*="grid-template-columns:1fr 1fr"],
  .auth-form-wrap [style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 10px !important;
  }

  /* === グリッド系の強制1カラム化 === */
  .form-row, .form-row-3 {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 10px !important;
  }
  .esign-signer-grid,
  .esign-settings-grid{
    grid-template-columns:1fr !important;
    gap:10px !important;
  }
  .esign-step-split{
    flex-direction:column;
    min-height:0;
  }
  .esign-step-split > :first-child,
  .esign-step-split > :last-child{
    flex:1 1 auto;
    width:100%;
  }
  .esign-step-panel .form-row,
  .esign-step-panel .form-row-3,
  .esign-step-panel [style*="grid-template-columns:1fr 1fr"],
  .esign-step-panel [style*="grid-template-columns:1fr 1fr 1fr"]{
    grid-template-columns:1fr !important;
  }
  .esign-action-row,
  .esign-nav-row{
    flex-direction:column !important;
    align-items:stretch !important;
  }
  .esign-action-row > *,
  .esign-nav-row > *{
    width:100% !important;
  }
  .kpi-grid { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
  .top3-grid { grid-template-columns: minmax(0, 1fr) !important; }
  .bank-grid { grid-template-columns: minmax(0, 1fr) !important; }
  .analysis-grid { grid-template-columns: minmax(0, 1fr) !important; }
  .bank-stats { grid-template-columns: minmax(0, 1fr) !important; }
  .step2-layout { flex-direction: column !important; }
  .bank-filter-sidebar { width: 100% !important; position: static !important; }
  .cs-row { grid-template-columns: minmax(0, 1fr) !important; }
  [style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  [style*="grid-template-columns: 1fr 1fr"] {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  [style*="grid-template-columns:repeat(4"] {
    grid-template-columns: repeat(2,1fr) !important;
  }
  [style*="grid-template-columns:repeat(3"] {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  [style*="grid-template-columns:repeat(2"] {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  /* === カード === */
  .card { padding: 12px !important; }
  .card-header { padding: 14px 14px 0 !important; }
  .card-body { padding: 0 14px 14px !important; }
  #view-dashboard > #dashOpsCommandCenter {
    display: block !important;
    width: 100% !important;
  }
  #view-analytics .an-rental-funnel-grid {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  #view-analytics .an-property-bottleneck-grid {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  #view-analytics .an-alert-detail-grid {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  #view-analytics .an-impact-grid {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  #view-analytics .an-followup-grid {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  #view-analytics .an-priority-grid {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  #view-analytics .an-learning-grid {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  #view-analytics .an-weekly-grid {
    grid-template-columns: minmax(0, 1fr) !important;
  }
	  #view-analytics .an-weekly-action-grid {
	    grid-template-columns: minmax(0, 1fr) !important;
	  }
	  #view-analytics .an-agent-risk-grid {
	    grid-template-columns: minmax(0, 1fr) !important;
	  }
	  #view-analytics .an-property-card-grid {
	    grid-template-columns: minmax(0, 1fr) !important;
	  }
	  #view-analytics .an-improvement-impact-grid {
	    grid-template-columns: minmax(0, 1fr) !important;
	  }
	  #view-analytics .an-health-grid {
	    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	  }
  #view-analytics .an-health-grid > div:first-child {
    grid-column: 1 / -1;
  }

  /* === ウィザードプログレス === */
  .wizard-progress {
    padding: 12px !important;
    gap: 4px !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    position: sticky !important;
    top: 56px !important;
    z-index: 25 !important;
    background: rgba(255,255,255,0.96) !important;
    backdrop-filter: blur(10px);
    border: 1px solid rgba(224,231,255,0.9);
    border-radius: 12px !important;
    margin-bottom: 12px !important;
  }
  .wizard-step { min-width: auto !important; }
  .step-label { font-size: 10px !important; }
  .step-circle { width: 28px !important; height: 28px !important; font-size: 12px !important; }

  /* === テーブル === */
  .table-wrap { overflow-x: auto !important; -webkit-overflow-scrolling: touch; }
  table { font-size: 12px !important; }
  th, td { padding: 8px 6px !important; white-space: nowrap; }

  /* === モーダル === */
  .modal-content {
    width: 95vw !important;
    max-width: 95vw !important;
    margin: 10px auto !important;
    max-height: 90vh !important;
  }
  .modal-sm, .modal-md, .modal-lg {
    max-width: 95vw !important;
  }

  /* === サポートチャット === */
  #supportChatBtn {
    bottom: var(--mobile-safe-bottom) !important;
    right: 12px !important;
    padding: 10px !important;
    border-radius: 50% !important;
    width: 48px !important;
    height: 48px !important;
    justify-content: center !important;
  }
  #supportChatBtn span { display: none !important; }
  #supportChatModal {
    width: calc(100vw - 24px) !important;
    max-width: none !important;
    right: 12px !important;
    left: 12px !important;
    bottom: calc(var(--mobile-safe-bottom) + 56px) !important;
    max-height: min(68vh, 560px) !important;
  }
  #mobileFAB {
    bottom: var(--mobile-safe-bottom) !important;
    right: 12px !important;
    z-index: 780 !important;
  }
  #fabMenu {
    max-height: min(56vh, 420px) !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px !important;
  }
  #docAiToggleBtn {
    bottom: calc(var(--mobile-safe-bottom) + 60px) !important;
    right: 12px !important;
    width: 48px !important;
    height: 48px !important;
  }
  #docAiPanel {
    left: 12px !important;
    right: 12px !important;
    width: auto !important;
    max-width: none !important;
    bottom: calc(var(--mobile-safe-bottom) + 116px) !important;
    max-height: min(60vh, 520px) !important;
  }

  body.mobile-sidebar-open #supportChatBtn,
  body.mobile-sidebar-open #supportChatModal,
  body.mobile-sidebar-open #mobileFAB,
  body.mobile-sidebar-open #docAiToggleBtn,
  body.mobile-sidebar-open #docAiPanel,
  body.mobile-form-active #supportChatBtn,
  body.mobile-form-active #mobileFAB,
  body.mobile-form-active #docAiToggleBtn,
  body.support-chat-open #mobileFAB,
  body.support-chat-open #docAiToggleBtn,
  body.support-chat-open #docAiPanel,
  body.doc-ai-open #supportChatBtn,
  body.doc-ai-open #supportChatModal,
  body.doc-ai-open #mobileFAB,
  body.fab-open #supportChatBtn,
  body.fab-open #docAiToggleBtn,
  body.fab-open #docAiPanel {
    opacity: 0 !important;
    pointer-events: none !important;
    transform: translateY(8px) !important;
  }

  /* === ダッシュボードヒーロー === */
  #dashHeroBar {
    padding: 16px !important;
    border-radius: 12px !important;
  }
  #dashHeroBar > div:last-child {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 14px !important;
  }
  #dashHeroBar > div:last-child > div:last-child {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    width: 100% !important;
  }
  #dashHeroBar > div:last-child > div:last-child button {
    flex: 1 1 auto !important;
    padding: 10px 12px !important;
    font-size: 12px !important;
    white-space: nowrap !important;
  }
  #dashHeroMsg { font-size: 16px !important; max-width: 100% !important; }
  /* ダッシュボード 2カラム→1カラム */
  #view-dashboard [style*="grid-template-columns:3fr 2fr"] {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  /* ダッシュボード KPIグリッド 3列→2列 */
  #dashKpiGrid {
    grid-template-columns: repeat(2,1fr) !important;
    gap: 10px !important;
  }

  /* === 収益用不動産ローン 2カラム→1カラム === */
  #investmentLoanForm > div {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  /* グリッドアイテム・カードが min-width:auto で膨張するのを防ぐ */
  #investmentLoanForm > div > div,
  #investmentLoanForm .card,
  #investmentLoanForm .form-row {
    min-width: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
  #investmentLoanForm .card-title {
    font-size: 14px !important;
    word-break: break-all !important;
  }

  /* === ビリング画面 === */
  #billingViewContent > div:first-child {
    flex-direction: column !important;
    text-align: left !important;
  }
  #billingViewContent > div:first-child > div:last-child {
    text-align: left !important;
  }

  /* === 顧客フォーム プラン選択 === */
  #companySignupScreen [style*="grid-template-columns:1fr 1fr 1fr"] {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  /* === 顧客画面 CRM KPIストリップ === */
  #crmKpiStrip {
    grid-template-columns: repeat(2,1fr) !important;
    gap: 8px !important;
  }

  /* === 物件KPI === */
  #propKPIs {
    grid-template-columns: repeat(2,1fr) !important;
    gap: 8px !important;
  }

  /* === トライアル期限切れ画面のプランカード === */
  [style*="min-width:140px"] { min-width: auto !important; flex: 1 1 100% !important; }

  /* === ボタン系 === */
  .btn { font-size: 12px !important; padding: 8px 14px !important; }
  .step-nav-btns { flex-direction: column !important; gap: 8px !important; }
  .step-nav-btns .btn { width: 100% !important; }

  /* === ステータスタブ === */
  .status-tabs {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap !important;
    gap: 4px !important;
  }
  .status-tabs .btn { font-size: 11px !important; padding: 6px 10px !important; white-space: nowrap; }

  /* === 検索バー === */
  .search-bar { flex-direction: column !important; gap: 8px !important; }
  .search-bar input { width: 100% !important; }

  /* === KPIカード内の数値 === */
  .kpi-value { font-size: 28px !important; }
  .kpi-label { font-size: 11px !important; }

  /* === フォーム === */
  .form-control, .form-select, select.form-control {
    font-size: 16px !important; /* iOS zoom防止：16px必須 */
    padding: 10px 12px !important;
  }

  /* === インラインflex要素のwrap化 === */
  [style*="display:flex"][style*="gap"] {
    flex-wrap: wrap !important;
  }

  /* === オンボーディングウィザード === */
  .onboarding-wizard-content {
    width: 95vw !important;
    max-width: 95vw !important;
    padding: 20px !important;
  }

  /* === トースト === */
  #toastContainer {
    right: 12px !important;
    left: 12px !important;
    bottom: 12px !important;
  }
  .toast { max-width: 100% !important; }

  /* agent-04: mobile typography */
  .view h2, .view h3 { font-size: 1.1rem; }
  .view table { font-size: 13px; }
  .view .card, .view .stat-card { font-size: 13px; }
  .view input, .view select, .view textarea { font-size: 16px; } /* iOS zoom防止 */

  /* agent-04: mobile table */
  .view table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
  }
  .view table th, .view table td {
    padding: 8px 10px;
    font-size: 12px;
  }

  /* agent-04: mobile modal */
  .modal-content, [class*="modal"] > div:first-child {
    width: 95vw !important;
    max-width: 95vw !important;
    max-height: 85vh !important;
    margin: auto;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* agent-04: mobile cards */
  .card, .stat-card, .kpi-card {
    padding: 12px !important;
  }

  /* agent-05: scroll optimization */
  .main-content {
    scroll-padding-top: 52px;
  }

  /* === 電子サイン モバイル対応 === */
  #esignDocCanvas {
    min-height: 500px !important;
  }
  .esign-preview-page iframe {
    min-height: 400px !important;
  }
  #esignCanvas {
    height: 140px !important;
  }
}

/* ⑨ 超小型スマホ（iPhone SE等） */
@media (max-width: 480px) {
  .auth-brand {
    padding: 20px 16px !important;
  }
  .auth-brand-tagline h2 { font-size: 18px !important; }
  .auth-brand-feat { display: none !important; }
  .auth-form-panel { padding: 20px 16px !important; }

  .kpi-grid { grid-template-columns: minmax(0, 1fr) !important; }
  .kpi-value { font-size: 24px !important; }

  /* agent-04: small mobile view padding */
  .view { padding: 12px 8px !important; }
  .main-content { padding: 52px 8px 8px !important; }
  .card { padding: 10px !important; }

  .wizard-progress { padding: 8px !important; }
  .step-label { font-size: 9px !important; }

  #dashHeroBar { padding: 12px !important; }
  #dashHeroMsg { font-size: 14px !important; }
  #dashKpiGrid { grid-template-columns: minmax(0, 1fr) !important; }

  .view-title { font-size: 16px !important; }

  .modal-content { width: 98vw !important; margin: 5px auto !important; }

  /* テーブルの最小幅保証 */
  table { min-width: 0; }
}

/* ⑩ 新規フォーム・顧客更新フォーム — モバイル最適化 */
@media (max-width: 768px) {
  #customerUpdateOverlay {
    padding: 12px !important;
  }
  #customerUpdateOverlay > div {
    padding: 20px !important;
    border-radius: 12px !important;
    margin: 20px auto !important;
  }
  #customerUpdateOverlay input,
  #customerUpdateOverlay textarea,
  #customerUpdateOverlay select {
    font-size: 16px !important; /* iOS ズーム防止 */
    padding: 12px !important;
  }
  /* グリッドを1カラム化 */
  #customerUpdateOverlay [style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: minmax(0, 1fr) !important;
  }
}

/* ⑪ ローン検索結果テーブル — モバイル横スクロール */
@media (max-width: 768px) {
  .analysis-grid { grid-template-columns: minmax(0, 1fr) !important; }
  #analysisGrid { grid-template-columns: minmax(0, 1fr) !important; }

  /* 比較テーブルは横スクロールで対応（カード変換はrow-label構造に合わないため削除） */
  #step4Content .table-wrap {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
  }
  #step4Content table {
    min-width: 600px;
    font-size: 12px !important;
  }
}

/* ⑫ 収益不動産用ローン画面 — 検索結果のモバイル最適化 */
@media (max-width: 768px) {
  #investmentPropertyResults {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  .investment-property-card {
    padding: 14px !important;
  }
  .investment-property-card h4 { font-size: 14px !important; }
  .investment-property-card p { font-size: 12px !important; }

  /* 収益計算表 → スクロール可能に */
  .billing-comparison-table,
  [id*="ComparisonTable"],
  [id*="billingTable"] {
    display: block !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    white-space: nowrap !important;
  }
}

/* ⑬ CRM顧客リスト — モバイルではカンパン表示推奨 */
@media (max-width: 768px) {
  #crmList table {
    display: block !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
  #crmList table thead {
    display: none !important;
  }
  #crmList table tr {
    display: block !important;
    margin-bottom: 12px !important;
    padding: 12px !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    background: #f8fafc !important;
  }
  #crmList table td {
    display: block !important;
    padding: 6px 0 !important;
    border: none !important;
  }
  #crmList table td::before {
    content: attr(data-label) !important;
    font-weight: 700 !important;
    color: #64748b !important;
    font-size: 10px !important;
    display: inline-block !important;
    min-width: 60px !important;
  }
}

/* ⑭ ローン検索ウィザード — ステップごとの最適化 */
@media (max-width: 768px) {
  .wizard-step-content {
    padding: 16px 12px 24px !important;
  }
  .step-nav-btns {
    flex-direction: column !important;
    gap: 8px !important;
  }
  .step-nav-btns .btn {
    width: 100% !important;
    padding: 12px !important;
    font-size: 13px !important;
  }

  /* Step 1: Form inputs full width */
  #s1Income, #s1Age, #s1Employment, #s1PropertyPrice,
  #s1DownPayment, #s1LoanAmount, #s1LoanTerm, #s1ExistingDebt,
  #s1YearsEmployed, #s1Area, #s1PropertyType, #s1SpouseIncome,
  #s1BuildingAge, #s1Structure {
    width: 100% !important;
  }

  /* Bank cards を1カラムに */
  #bankCardsContainer { grid-template-columns: minmax(0, 1fr) !important; }

  /* Step 3/4: Comparison table スクロール可能に */
  #step3Content table,
  #step4Content table {
    font-size: 12px !important;
    display: block !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
}

/* ⑮ ダッシュボード — KPI の積み重ね */
@media (max-width: 768px) {
  .kpi-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
  }
  .kpi-card {
    padding: 12px !important;
  }
  .kpi-value { font-size: 24px !important; }
  .kpi-label { font-size: 11px !important; }
  .kpi-change { font-size: 11px !important; }
}

/* ⑯ 請求・比較テーブル → カード表示 */
@media (max-width: 768px) {
  .billing-comparison-wrapper {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 12px !important;
  }
  .billing-comparison-card {
    padding: 14px !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    background: #f8fafc !important;
  }
  .billing-comparison-card h4 { font-size: 13px !important; margin-bottom: 8px !important; }
  .billing-comparison-card p { font-size: 12px !important; margin-bottom: 4px !important; }
}

/* agent-01: skeleton loading */
.skeleton-container{padding:20px}
.skeleton-line{height:14px;background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9 50%,#e2e8f0 75%);background-size:200% 100%;animation:skeletonShimmer 1.5s infinite;border-radius:6px;margin-bottom:12px}
.skeleton-line.w60{width:60%}
.skeleton-line.w80{width:80%}
.skeleton-line.w40{width:40%}
.skeleton-line.h24{height:24px}
.skeleton-line.h40{height:40px}
.skeleton-card{height:120px;background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9 50%,#e2e8f0 75%);background-size:200% 100%;animation:skeletonShimmer 1.5s infinite;border-radius:10px;margin-bottom:16px}
.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
@keyframes skeletonShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* agent-08: loan/property mobile UI */
@media(max-width:768px){
  /* ローン検索ウィザード: wizard-progress の横スクロール防止 */
  #view-loan .wizard-progress {
    gap: 4px;
  }
  #view-loan .card,
  #view-loan .wizard-step-content,
  #view-loan .card-body {
    overflow: visible !important;
  }
  #view-loan .form-group:last-child,
  #view-loan .form-row:last-child {
    margin-bottom: 0 !important;
  }
  #view-loan .card {
    margin-bottom: 20px !important;
  }
  #view-loan .wizard-step .step-label {
    font-size: 10px;
  }
  #view-loan .wizard-step .step-circle {
    width: 28px; height: 28px; font-size: 12px;
  }

  /* 収益用不動産ローンフォーム: 2カラム→1カラム */
  #investmentLoanForm > div[style*="grid-template-columns"] {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  #investmentLoanForm .form-row {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  /* ローン結果カード内 4列グリッド→2列 */
  #view-loan [style*="grid-template-columns:repeat(4"] {
    grid-template-columns: repeat(2,1fr) !important;
  }
  #view-loan [style*="grid-template-columns: repeat(4"] {
    grid-template-columns: repeat(2,1fr) !important;
  }

  /* ローン結果テーブル横スクロール対応 */
  #view-loan table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    font-size: 12px;
  }

  /* 物件カードグリッド: 1カラム化 */
  #propertyGrid {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  /* 物件KPI: 5列→2列 */
  #propKPIs {
    grid-template-columns: repeat(2,1fr) !important;
    gap: 8px !important;
  }
}

@media(min-width:769px){
  body.loan-view-active #view-loan .step2-banks,
  body.loan-view-active #view-loan #step-content-3,
  body.loan-view-active #view-loan #step-content-4{
    padding-right:92px;
    padding-bottom:92px;
    box-sizing:border-box;
  }
}

/* agent-06: navigation improvement — tap target & sidebar-close */
#mobileHamburger {
  min-width: 44px;
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sidebar-close {
  min-width: 44px;
  min-height: 44px;
}

/* agent-07: CRM mobile UI */
@media(max-width:768px){
  /* --- CRM Table → Card conversion --- */
  #crmListView .table-wrap{overflow-x:visible!important}
  #crmListView table{min-width:0!important;width:100%!important}
  #crmListView table thead{display:none}
  #crmListView table tbody tr{
    display:block;
    margin-bottom:12px;
    border:1px solid var(--border,#e2e8f0);
    border-radius:8px;
    background:#fff;
    box-shadow:0 1px 3px rgba(0,0,0,0.06);
    border-left:none!important;
  }
  #crmListView table tbody td{
    display:block;
    text-align:left;
    border:none;
    white-space:normal!important;
  }
  #crmListView table tbody td::before{
    content:attr(data-label);
    font-weight:600;
    font-size:11px;
    color:var(--gray-500,#6b7280);
    display:block;
    margin-bottom:2px;
  }
  /* Hide checkbox column on mobile cards */
  #crmListView table tbody td[data-label=""]{display:none}
  /* --- CRM Filter toolbar: stack vertically on mobile --- */
  #view-crm>div>div[style*="display:flex"][style*="gap:8px"][style*="flex-wrap"]{
    flex-direction:column!important;
    gap:8px!important;
  }
  #view-crm>div>div[style*="display:flex"][style*="gap:8px"][style*="flex-wrap"] input[type="text"],
  #view-crm>div>div[style*="display:flex"][style*="gap:8px"][style*="flex-wrap"] select{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
  }
  #view-crm>div>div[style*="display:flex"][style*="gap:8px"][style*="flex-wrap"]>div[style*="margin-left:auto"]{
    margin-left:0!important;
    width:100%;
    flex-wrap:wrap;
  }
  /* --- Customer Detail Modal fullscreen on mobile --- */
  #customerDetailModal{
    max-width:100vw!important;
    width:100vw!important;
    height:100vh!important;
    max-height:100vh!important;
    margin:0!important;
    border-radius:0!important;
    top:0!important;
    left:0!important;
    position:fixed!important;
    overflow-y:auto!important;
  }
  /* --- Status tabs horizontal scroll on mobile --- */
  #crmStatusTabs{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    flex-wrap:nowrap!important;
    white-space:nowrap;
  }
}

/* agent-09: dashboard/closing mobile UI */
@media(max-width:768px){
  /* ダッシュボードKPIカード 2カラム維持 */
  #dashKpiGrid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
  }
  #dashKpiGrid .kpi-card .kpi-value {
    font-size: 20px !important;
  }
  #dashKpiGrid .kpi-card {
    padding: 14px 16px !important;
  }

  /* ダッシュボードのチャート・グラフエリア横スクロール */
  #dashPipeline,
  #dashMonthlyTrend {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* 成約支援 KPIグリッド 1カラム化 */
  #view-closing .card > div[style*="grid-template-columns:2fr 1fr 1fr 1fr 1fr"] {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 10px !important;
  }

  /* 成約支援 メインコンテンツ 1カラム化 */
  #closingMainContent {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  /* パイプラインテーブルの横スクロール */
  #pipelineTable {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  #pipelineTable table {
    min-width: 600px;
  }

  /* 成約支援タブの横スクロール対応 */
  #closingTabBuy, #closingTabSell {
    flex-shrink: 0;
    font-size: 12px !important;
    padding: 6px 14px !important;
  }

  /* スクリプトタブ横スクロール */
  #scriptTabPhone, #scriptTabLine, #scriptTabVisit {
    flex-shrink: 0;
    font-size: 11px !important;
    padding: 6px 12px !important;
  }

  /* ダッシュボード タスクリストのコンパクト表示 */
  #dashTodayTasks > div {
    padding: 8px 10px !important;
    font-size: 12px;
  }
  #dashPipelineSummary {
    font-size: 13px;
  }
}

@media(max-width:480px){
  /* 480px以下でもKPI 2カラム維持 */
  #dashKpiGrid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px !important;
  }
  #dashKpiGrid .kpi-card .kpi-value {
    font-size: 18px !important;
  }
  #dashKpiGrid .kpi-card {
    padding: 10px 12px !important;
  }

  /* 成約支援 KPI 2カラム化 */
  #view-closing .card > div[style*="grid-template-columns:2fr 1fr 1fr 1fr 1fr"] {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
  }

  /* 物件・賃貸管理カードグリッド: スマホ1カラム */
  #propertyGrid {
    grid-template-columns: minmax(0, 1fr) !important;
  }
}

/* ===== モバイル強化 (375px+) ===== */
@media(max-width:768px){
  /* 賃貸管理タブバーのスクロール改善 */
  #rmTabBar{
    display:flex !important;
    flex-wrap:nowrap !important;
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch;
    gap:0 !important;
    padding-bottom:2px;
  }
  #rmTabBar button{
    padding:10px 14px !important;
    font-size:12px !important;
    white-space:nowrap !important;
    flex-shrink:0;
  }

  /* ビューヘッダーのレスポンシブ化 */
  .view-header{
    flex-direction:column !important;
    align-items:flex-start !important;
    gap:10px !important;
    padding:16px !important;
  }
  .view-title{font-size:18px !important}
  .view-subtitle{font-size:11px !important}

  /* KPIグリッドの1-2列化 */
  [style*="grid-template-columns:repeat(4"]{
    grid-template-columns:repeat(2,1fr) !important;
  }
  [style*="grid-template-columns:repeat(5"]{
    grid-template-columns:repeat(2,1fr) !important;
  }
  [style*="grid-template-columns:repeat(8"]{
    grid-template-columns:repeat(2,1fr) !important;
  }

  /* テーブルの横スクロール保証 */
  table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
  thead,tbody,tr{display:table;width:100%;table-layout:auto}

  /* カードグリッドの1列化 */
  [style*="minmax(340px"]{
    grid-template-columns:1fr !important;
  }
  [style*="minmax(300px"]{
    grid-template-columns:1fr !important;
  }

  /* プラン選択カードの縦並び */
  [style*="grid-template-columns:repeat(4,1fr)"][style*="gap:16px"]{
    grid-template-columns:1fr !important;
  }

  /* モーダルのモバイル対応 */
  .modal{
    max-width:95vw !important;
    max-height:85vh !important;
    margin:8px !important;
  }
  .modal-body{
    padding:16px !important;
  }

  /* フォームのグリッド1列化 */
  [style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns:1fr !important;
  }

  /* ローンウィザード: ステップがモバイルで崩れない対応 */
  .wizard-progress{
    flex-wrap:nowrap !important;
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch;
  }
}

@media(max-width:480px){
  /* 超小型画面 */
  .view-header{padding:12px !important}
  .view-title{font-size:16px !important}

  /* KPIは1列 */
  [style*="grid-template-columns:repeat(2"]{
    grid-template-columns:1fr !important;
  }
  /* ただしダッシュボードKPIは2列維持 */
  #dashKpiGrid{
    grid-template-columns:repeat(2,1fr) !important;
  }
}

/* ===== Mobile app hardening: logged-in screens ===== */
@media(max-width:768px){
  html,
  body{
    overflow-x:hidden !important;
    max-width:100vw !important;
  }

  #appShell,
  .main-content,
  .view,
  .view.active{
    width:100% !important;
    max-width:100vw !important;
    min-width:0 !important;
    box-sizing:border-box !important;
  }

  #appShell{
    height:100vh !important;
    height:100dvh !important;
    min-height:100vh !important;
    min-height:100dvh !important;
    max-height:100vh !important;
    max-height:100dvh !important;
    overflow:hidden !important;
  }

  .main-content{
    padding-bottom:calc(var(--mobile-floating-stack) + 44px) !important;
    flex:1 1 auto !important;
    height:100vh !important;
    height:100dvh !important;
    min-height:0 !important;
    max-height:100vh !important;
    max-height:100dvh !important;
    overflow-y:auto !important;
    overflow-x:hidden !important;
    overscroll-behavior-y:contain;
    -webkit-overflow-scrolling:touch;
  }

  .view{
    min-height:100vh !important;
    min-height:100dvh !important;
  }

  /*
   * Logged-in mobile shell:
   * Some auth/test paths reveal #appShell with inline display:block.
   * In that state .main-content expands to its full content height and the
   * parent overflow:hidden clips the page, so the user cannot scroll down.
   * Keep hidden shells hidden, but normalize any visible shell to a fixed
   * viewport flex layout and make .main-content the actual scroll container.
   */
  #appShell[style*="display:flex"],
  #appShell[style*="display: flex"],
  #appShell[style*="display:block"],
  #appShell[style*="display: block"]{
    display:flex !important;
    height:100vh !important;
    height:100dvh !important;
    min-height:100vh !important;
    min-height:100dvh !important;
    max-height:100vh !important;
    max-height:100dvh !important;
    overflow:hidden !important;
  }

  #appShell[style*="display:flex"] .main-content,
  #appShell[style*="display: flex"] .main-content,
  #appShell[style*="display:block"] .main-content,
  #appShell[style*="display: block"] .main-content{
    flex:1 1 auto !important;
    height:100vh !important;
    height:100dvh !important;
    min-height:0 !important;
    max-height:100vh !important;
    max-height:100dvh !important;
    overflow-y:auto !important;
    overflow-x:hidden !important;
    overscroll-behavior-y:contain;
    -webkit-overflow-scrolling:touch;
  }

  #appShell[style*="display:flex"] .view,
  #appShell[style*="display: flex"] .view,
  #appShell[style*="display:block"] .view,
  #appShell[style*="display: block"] .view{
    min-height:100vh !important;
    min-height:100dvh !important;
  }

  .view.active > *,
  .view .card,
  .view section,
  .view article,
  .view [style*="display:grid"],
  .view [style*="display: grid"],
  .view [style*="display:flex"],
  .view [style*="display: flex"]{
    min-width:0 !important;
    max-width:100% !important;
    box-sizing:border-box !important;
  }

  .view [style*="grid-template-columns:repeat(auto-fit"],
  .view [style*="grid-template-columns: repeat(auto-fit"],
  .view [style*="grid-template-columns:repeat(auto-fill"],
  .view [style*="grid-template-columns: repeat(auto-fill"]{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }

  .view input,
  .view select,
  .view textarea,
  .view button{
    max-width:100% !important;
    box-sizing:border-box !important;
  }

  #supportChatBtn{
    right:12px !important;
    top:12px !important;
    bottom:auto !important;
    width:44px !important;
    height:44px !important;
    padding:0 !important;
    border-radius:999px !important;
    justify-content:center !important;
  }

  #supportChatBtn span{
    display:none !important;
  }

  #mobileFAB{
    top:12px !important;
    left:12px !important;
    right:auto !important;
    bottom:auto !important;
    z-index:1200 !important;
    align-items:flex-start !important;
    flex-direction:column-reverse !important;
  }

  #mobileFAB #fabMainBtn{
    width:44px !important;
    height:44px !important;
    font-size:19px !important;
  }

  #fabMenu{
    align-items:flex-start !important;
    margin:6px 0 0 !important;
    max-width:calc(100vw - 24px) !important;
    max-height:55vh !important;
    overflow-y:auto !important;
    -webkit-overflow-scrolling:touch;
  }

  #supportChatModal{
    left:12px !important;
    right:12px !important;
    top:64px !important;
    bottom:auto !important;
    width:auto !important;
    max-width:none !important;
    max-height:calc(100dvh - 82px) !important;
  }
}

@media(max-width:480px){
  .main-content{
    padding:52px 8px calc(var(--mobile-floating-stack) + 44px) !important;
  }
}

/* ===== SERVICE UPGRADE: Dashboard KPI Count-Up Animation ===== */
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.7; }
}
@keyframes kpiCountUp {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
.kpi-card {
  animation: kpiCountUp 0.5s ease both;
}
.kpi-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(0,0,0,0.08);
  transition: all 0.25s cubic-bezier(0.16,1,0.3,1);
}

/* ===== SERVICE UPGRADE: Dashboard Sparkline ===== */
.dash-sparkline { display: inline-block; vertical-align: middle; }

/* ===== agent-dashboard: Dashboard Fade-in from Skeleton ===== */
@keyframes dashFadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}
.dash-fade-in > * {
  animation: dashFadeIn 0.4s ease both;
}
.dash-fade-in > *:nth-child(1) { animation-delay: 0s; }
.dash-fade-in > *:nth-child(2) { animation-delay: 0.05s; }
.dash-fade-in > *:nth-child(3) { animation-delay: 0.1s; }
.dash-fade-in > *:nth-child(4) { animation-delay: 0.15s; }
.dash-fade-in > *:nth-child(5) { animation-delay: 0.2s; }
.dash-fade-in > *:nth-child(6) { animation-delay: 0.25s; }
.dash-fade-in > *:nth-child(n+7) { animation-delay: 0.3s; }

/* ===== agent-dashboard: Activity Timeline ===== */
.dash-timeline-item {
  display: flex; align-items: flex-start; gap: 12px; padding: 10px 0;
  border-bottom: 1px solid #f1f5f9; position: relative;
}
.dash-timeline-item:last-child { border-bottom: none; }
.dash-timeline-dot {
  width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; margin-top: 4px;
  box-shadow: 0 0 0 3px rgba(16,185,129,0.15);
}
.dash-timeline-line {
  position: absolute; left: 4px; top: 24px; bottom: -10px; width: 2px; background: #e2e8f0;
}
.dash-timeline-item:last-child .dash-timeline-line { display: none; }

/* ===== agent-dashboard: Weekly Goal Progress Bar ===== */
.dash-goal-bar-track {
  height: 8px; background: #e2e8f0; border-radius: 99px; overflow: hidden; flex: 1;
}
.dash-goal-bar-fill {
  height: 100%; border-radius: 99px; transition: width 0.8s cubic-bezier(0.16,1,0.3,1);
}

/* ===== SERVICE UPGRADE: Pipeline Bar Hover ===== */
.dash-pipe-bar:hover {
  filter: brightness(1.1);
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}

/* ===== SERVICE UPGRADE: CRM Quick-Action Toolbar ===== */
.crm-quick-actions {
  display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px;
}
.crm-quick-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 6px 14px; border-radius: 8px; border: 1.5px solid #e2e8f0;
  background: #fff; font-size: 11px; font-weight: 700; color: #374151;
  cursor: pointer; transition: all 0.15s;
}
.crm-quick-btn:hover {
  border-color: #10b981; color: #10b981; background: #eef2ff;
  transform: translateY(-1px);
}

/* ===== SERVICE UPGRADE: Property Gallery Lightbox ===== */
.prop-lightbox-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.85); z-index: 10000;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity 0.3s; pointer-events: none;
}
.prop-lightbox-overlay.active { opacity: 1; pointer-events: auto; }
.prop-lightbox-img {
  max-width: 90vw; max-height: 85vh; border-radius: 12px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
  transform: scale(0.9); transition: transform 0.3s cubic-bezier(0.16,1,0.3,1);
}
.prop-lightbox-overlay.active .prop-lightbox-img { transform: scale(1); }
.prop-lightbox-close {
  position: absolute; top: 20px; right: 24px; width: 44px; height: 44px;
  border-radius: 50%; background: rgba(255,255,255,0.15); border: none;
  color: #fff; font-size: 24px; cursor: pointer; display: flex;
  align-items: center; justify-content: center; transition: background 0.2s;
}
.prop-lightbox-close:hover { background: rgba(255,255,255,0.3); }
.prop-lightbox-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 48px; height: 48px; border-radius: 50%;
  background: rgba(255,255,255,0.15); border: none; color: #fff;
  font-size: 22px; cursor: pointer; display: flex; align-items: center;
  justify-content: center; transition: background 0.2s;
}
.prop-lightbox-nav:hover { background: rgba(255,255,255,0.3); }
.prop-lightbox-nav.prev { left: 20px; }
.prop-lightbox-nav.next { right: 20px; }

/* ===== SERVICE UPGRADE: Loan Comparison Sort Headers ===== */
.loan-sort-header {
  cursor: pointer; user-select: none; transition: color 0.15s;
}
.loan-sort-header:hover { color: #10b981; }
.loan-sort-header .sort-arrow { font-size: 10px; margin-left: 3px; }

/* ===== SERVICE UPGRADE: Document Template Preview ===== */
.doc-template-card {
  position: relative; overflow: hidden; border-radius: 12px;
  transition: all 0.2s;
}
.doc-template-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.08);
}
.doc-template-badge {
  position: absolute; top: 8px; right: 8px;
  padding: 2px 8px; border-radius: 20px;
  font-size: 9px; font-weight: 700;
}

/* ===== SERVICE UPGRADE: Closing Timeline Enhanced ===== */
.closing-timeline-node {
  position: relative; padding-left: 32px; margin-bottom: 16px;
}
.closing-timeline-node::before {
  content: ''; position: absolute; left: 11px; top: 24px;
  width: 2px; height: calc(100% - 4px); background: #e2e8f0;
}
.closing-timeline-node:last-child::before { display: none; }
.closing-timeline-dot {
  position: absolute; left: 4px; top: 4px;
  width: 18px; height: 18px; border-radius: 50%;
  border: 3px solid #e2e8f0; background: #fff;
  transition: all 0.2s;
}
.closing-timeline-node.active .closing-timeline-dot {
  border-color: #10b981; background: #10b981;
  box-shadow: 0 0 0 4px rgba(16,185,129,0.2);
}
.closing-timeline-node.completed .closing-timeline-dot {
  border-color: #22c55e; background: #22c55e;
}

/* ===== SERVICE UPGRADE: Rental Calendar View (premium) ===== */
.rental-calendar-grid {
  display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px;
}
.rental-cal-day {
  aspect-ratio: 1; padding: 4px; border-radius: 8px;
  font-size: 10px; text-align: center; cursor: pointer;
  transition: all 0.2s cubic-bezier(.4,0,.2,1);
  border: 1px solid transparent;
  font-weight: 500;
}
.rental-cal-day:hover { background: #eef2ff; transform: scale(1.05); box-shadow: 0 2px 8px rgba(16,185,129,0.12); }
.rental-cal-day.occupied { background: linear-gradient(135deg, #dcfce7, #bbf7d0); border-color: #86efac; }
.rental-cal-day.vacant { background: linear-gradient(135deg, #fef2f2, #fecaca); border-color: #fca5a5; }
.rental-cal-day.move-in { background: linear-gradient(135deg, #dbeafe, #bfdbfe); border: 1.5px solid #60a5fa; box-shadow: 0 1px 4px rgba(96,165,250,0.2); }
.rental-cal-day.move-out { background: linear-gradient(135deg, #fef3c7, #fde68a); border: 1.5px solid #fbbf24; box-shadow: 0 1px 4px rgba(251,191,36,0.2); }

/* ===== SERVICE UPGRADE: Auth Password Strength ===== */
.pwd-strength-bar {
  height: 4px; border-radius: 2px; background: #e2e8f0;
  margin-top: 6px; overflow: hidden; transition: all 0.3s;
}
.pwd-strength-fill {
  height: 100%; border-radius: 2px; transition: width 0.3s, background 0.3s;
}

/* ===== SERVICE UPGRADE: Smooth scroll-to-top for navigation ===== */
.view { scroll-behavior: smooth; }

/* ===== SERVICE UPGRADE: Enhanced card hover globally ===== */
.card { transition: box-shadow 0.2s, transform 0.2s; }
.card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.06); }
/* ===== Investment Loan Card Styles ===== */
.inv-card{background:#fff;border-radius:14px;padding:20px;margin-bottom:14px;transition:box-shadow .2s,transform .15s;position:relative;overflow:hidden}
.inv-card:hover{box-shadow:0 6px 24px rgba(0,0,0,.08);transform:translateY(-1px)}
.inv-card--high{background:linear-gradient(135deg,#f0fdf4 0%,#ecfdf5 100%);border:1.5px solid #86efac}
.inv-card--mid{background:linear-gradient(135deg,#fefce8 0%,#fef9c3 100%);border:1.5px solid #fde047}
.inv-card--low{background:#fff;border:1.5px solid #e2e8f0}
.inv-card--ng{background:#f9fafb;border:1.5px solid #e2e8f0;opacity:1}
.inv-card__rank{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:44px;height:44px;border-radius:10px;font-weight:900;font-size:18px;line-height:1}
.inv-card__rank--1{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;box-shadow:0 2px 8px rgba(245,158,11,.3)}
.inv-card__rank--2{background:linear-gradient(135deg,#d1d5db,#9ca3af);color:#fff;box-shadow:0 2px 8px rgba(156,163,175,.3)}
.inv-card__rank--3{background:linear-gradient(135deg,#d97706,#b45309);color:#fff;box-shadow:0 2px 8px rgba(180,83,9,.3)}
.inv-card__rank--other{background:#f1f5f9;color:#94a3b8;font-size:13px}
.inv-card__grade{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;border-radius:10px;font-weight:900;font-size:20px;color:#fff;letter-spacing:-0.5px}
.inv-card__grade--S{background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 2px 8px rgba(22,163,74,.25)}
.inv-card__grade--A{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 2px 8px rgba(37,99,235,.25)}
.inv-card__grade--B{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 2px 8px rgba(217,119,6,.25)}
.inv-card__grade--C{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 2px 8px rgba(220,38,38,.25)}
.inv-card__grade--D{background:linear-gradient(135deg,#6b7280,#4b5563);box-shadow:0 2px 8px rgba(107,114,128,.25)}
.inv-card__suit{font-size:12px;font-weight:800;padding:4px 12px;border-radius:99px;letter-spacing:0.3px}
.inv-card__suit--high{background:#dcfce7;color:#15803d;border:1.5px solid #86efac}
.inv-card__suit--mid{background:#fef9c3;color:#854d0e;border:1.5px solid #fde047}
.inv-card__suit--low{background:#f1f5f9;color:#64748b;border:1.5px solid #e2e8f0}
.inv-card__cat{font-size:10px;font-weight:700;padding:2px 8px;border-radius:99px;white-space:nowrap}
.inv-card__cat--mega{background:#eef2ff;color:#059669}
.inv-card__cat--regional{background:#f0fdf4;color:#16a34a}
.inv-card__cat--online{background:#faf5ff;color:#10b981}
.inv-card__cat--nonbank{background:#fff7ed;color:#c2410c}
.inv-card__cat--shinkin{background:#ecfeff;color:#0891b2}
.inv-card__cat--kumiai{background:#fdf4ff;color:#a21caf}
.inv-card__cat--policy{background:#f0f9ff;color:#0369a1}
.inv-card__tag{display:inline-block;font-size:10px;font-weight:600;padding:2px 7px;border-radius:99px;background:#f1f5f9;color:#475569;white-space:nowrap}
.inv-card__tag--area{background:#dbeafe;color:#1d4ed8}
.inv-card__tag--feat{background:#fce7f3;color:#be185d}
.inv-card__tag--warn{background:#fef2f2;color:#dc2626}
.inv-card__stat{background:#f8fafc;padding:8px 10px;border-radius:8px;text-align:center}
.inv-card__stat-label{font-size:9px;color:#94a3b8;font-weight:600;text-transform:uppercase;margin-bottom:2px}
.inv-card__stat-value{font-size:14px;font-weight:800;color:#0f172a}
.inv-card__stat-value--rate{color:#059669;font-size:16px}
.inv-card__stat-value--positive{color:#16a34a}
.inv-card__stat-value--negative{color:#dc2626}
.inv-card__ng{font-size:12px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:10px 12px;color:#dc2626;line-height:1.6}
.inv-card__ok{font-size:12px;color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;padding:10px 12px;line-height:1.6}
.inv-card__hp-link{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;color:#059669;text-decoration:none;padding:5px 12px;background:#eef2ff;border:1px solid #c7d2fe;border-radius:6px;transition:background .15s}
.inv-card__hp-link:hover{background:#e0e7ff}
.inv-card__actions{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.inv-highlight-strip{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.inv-highlight-chip{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:700;background:#fff;border:1.5px solid #e2e8f0}
.inv-highlight-chip--best-rate{border-color:#059669;color:#059669;background:#eef2ff}
.inv-highlight-chip--max-loan{border-color:#16a34a;color:#16a34a;background:#f0fdf4}
.inv-highlight-chip--recommend{border-color:#f59e0b;color:#b45309;background:#fffbeb}
.inv-grade-dots{display:flex;gap:2px}
.inv-grade-dot{width:8px;height:8px;border-radius:50%}
.inv-grade-dot--on-green{background:#16a34a}
.inv-grade-dot--on-amber{background:#f59e0b}
.inv-grade-dot--on-red{background:#dc2626}
.inv-grade-dot--off{background:#e2e8f0}
.inv-tooltip{position:relative;display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:#e2e8f0;color:#64748b;font-size:10px;font-weight:800;cursor:help;margin-left:4px;vertical-align:middle}
.inv-tooltip:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);padding:6px 10px;background:#0f172a;color:#fff;font-size:11px;font-weight:500;border-radius:6px;white-space:nowrap;z-index:100;pointer-events:none}
.inv-tooltip:hover::before{content:attr(x);position:absolute;bottom:calc(100% + 2px);left:50%;transform:translateX(-50%);border:4px solid transparent;border-top-color:#0f172a;z-index:100}
@media(max-width:640px){
  .inv-card .inv-card__stat-grid{grid-template-columns:repeat(2,1fr)!important}
  .inv-card{padding:14px}
  .inv-card__grade{min-width:34px;height:34px;font-size:17px}
  .inv-card__rank{min-width:38px;height:38px;font-size:16px}
  .inv-highlight-strip{flex-direction:column}
}
/* ===== /Investment Loan Card Styles ===== */

/* ===== PC TOP BAR LAYOUT (運営管理ダッシュボード style) ===== */
@media (min-width: 769px){
  #appShell{flex-direction:column !important}
  .sidebar{display:none !important}
  .app-topbar{display:flex !important}
  .app-tabs{display:flex !important}
  .main-content{flex:1 1 0% !important;overflow-y:auto !important;min-height:0 !important}
  .view{padding:28px 36px !important;min-height:auto !important}
  .view-header{padding:0 !important}
  /* FIX(2026-06-05): このレイアウトは上部バーが2段（.app-topbar 66px + .app-tabs 60px ≈126px）。
     モーダルの上余白 76px では2段目(.app-tabs)とヘッダーが衝突して顧客名等が隠れるため、
     2段分をクリアする 136px に拡張（ナビをモーダル上に残す R-NEW76 の挙動は維持）。 */
  #modalActiveHost{padding-top:136px}
}


.pp-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:24px 28px;margin-bottom:20px;box-shadow:0 1px 3px rgba(0,0,0,0.04)}

#appShell #appTabs,
body.uls-modal-open #appShell #appTabs{
  position:relative!important;
  z-index:100001!important;
}
.pp-card-h{font-size:15px;font-weight:900;color:#0f172a;display:flex;align-items:center;gap:10px;margin-bottom:14px;padding-bottom:12px;border-bottom:2px solid #f1f5f9}
.pp-card-h .pp-num{min-width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#10b981,#8b5cf6);color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pp-card p{font-size:13px;color:#475569;line-height:1.85;margin-bottom:9px}
.pp-card ol{margin:4px 0 12px 0;padding-left:22px}
.pp-card ol li{font-size:13px;color:#475569;line-height:1.85;margin-bottom:4px}
.pp-card .pp-info-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:16px 20px;font-size:13px;color:#374151;line-height:2}
.pp-card .pp-highlight{display:flex;gap:10px;background:#fffbeb;border:1.5px solid #fde68a;border-radius:9px;padding:12px 16px;margin-top:10px;margin-bottom:10px;font-size:12px;color:#92400e;line-height:1.8}

.tk-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden;margin-bottom:16px;box-shadow:0 1px 3px rgba(0,0,0,0.04)}
.tk-row{display:flex;border-bottom:1px solid #f1f5f9}
.tk-row:last-child{border-bottom:none}
.tk-label{width:180px;min-width:180px;padding:16px 20px;background:#f8fafc;font-size:13px;font-weight:700;color:#374151;display:flex;align-items:flex-start}
.tk-value{flex:1;padding:16px 20px;font-size:13px;color:#475569;line-height:1.85}

.mn-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:24px 28px;margin-bottom:20px;box-shadow:0 1px 3px rgba(0,0,0,0.04)}
.mn-h2{font-size:16px;font-weight:900;color:#0f172a;display:flex;align-items:center;gap:10px;margin-bottom:14px;padding-bottom:12px;border-bottom:2px solid #f1f5f9}
.mn-h3{font-size:13px;font-weight:700;color:#1e293b;margin:18px 0 7px;display:flex;align-items:center;gap:6px}
.mn-h4{font-size:12px;font-weight:700;color:#475569;margin:10px 0 5px}
.mn-p{font-size:13px;color:#475569;line-height:1.85;margin-bottom:9px}
.mn-ol{margin:4px 0 12px 0;padding-left:22px}
.mn-ol li{font-size:13px;color:#475569;line-height:1.85;margin-bottom:4px}
.mn-ul{margin:4px 0 12px 0;padding-left:22px;list-style:disc}
.mn-ul li{font-size:13px;color:#475569;line-height:1.85;margin-bottom:4px}
.mn-tip{display:flex;gap:10px;background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:9px;padding:12px 16px;margin-top:10px;margin-bottom:10px;font-size:12px;color:#166534;line-height:1.8}
.mn-warn{display:flex;gap:10px;background:#fffbeb;border:1.5px solid #fde68a;border-radius:9px;padding:12px 16px;margin-top:10px;margin-bottom:10px;font-size:12px;color:#92400e;line-height:1.8}
.mn-info{display:flex;gap:10px;background:#f0f9ff;border:1.5px solid #bae6fd;border-radius:9px;padding:12px 16px;margin-top:10px;margin-bottom:10px;font-size:12px;color:#0369a1;line-height:1.8}
.mn-step{display:flex;gap:10px;margin-bottom:8px;align-items:flex-start}
.mn-step-num{min-width:24px;height:24px;border-radius:50%;background:#10b981;color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.mn-badge{display:inline-block;padding:2px 9px;border-radius:6px;font-size:10px;font-weight:700}
.mn-kbd{display:inline-block;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:4px;padding:1px 6px;font-size:11px;font-weight:600;color:#374151;font-family:monospace}
.mn-tbl{width:100%;border-collapse:collapse;margin:8px 0 12px;font-size:12px}
.mn-tbl th{background:#f8fafc;padding:7px 12px;text-align:left;font-weight:700;color:#64748b;border-bottom:2px solid #e2e8f0}
.mn-tbl td{padding:8px 12px;border-bottom:1px solid #f1f5f9;color:#374151;vertical-align:top}
.mn-tbl tr:last-child td{border-bottom:none}
.mn-section-tag{display:inline-block;background:linear-gradient(135deg,#10b981,#8b5cf6);color:#fff;font-size:9px;font-weight:800;padding:2px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:0.06em;margin-left:8px;vertical-align:middle}

@media(max-width:640px){
  .tk-row{flex-direction:column}
  .tk-label{width:100%;min-width:100%;padding:12px 16px 4px;background:transparent;font-size:12px;color:#10b981}
  .tk-value{padding:4px 16px 12px}
}


    /* LP表示中はLP以外の全要素を確実に非表示
       FIX(2026-06-05): #lpContactOverlay を例外に追加。このルールが問い合わせオーバーレイ
       （lpScreenの後続兄弟）まで !important で隠し、LPの「お問い合わせ」が開けなくなっていた
       （inline display:block より優先されるため。旧構成の頃からの潜伏バグ）。 */
    #lpScreen:not([style*="display:none"]):not([style*="display: none"]) ~ *:not(script):not(style):not(link):not(#lpContactOverlay) {
      display:none !important;
    }
    @keyframes lpFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
    @keyframes lpPulse { 0%,100%{opacity:0.6} 50%{opacity:1} }
    @keyframes lpGlow { 0%{box-shadow:0 0 20px rgba(16,185,129,0.15)} 50%{box-shadow:0 0 40px rgba(16,185,129,0.3)} 100%{box-shadow:0 0 20px rgba(16,185,129,0.15)} }
    @keyframes lpGradient { 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }
    @keyframes lpSlideUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
    @keyframes lpSlideIn { from{opacity:0;transform:translateX(40px)} to{opacity:1;transform:translateX(0)} }
    @keyframes lpCount { from{opacity:0;transform:scale(0.8)} to{opacity:1;transform:scale(1)} }
    /* Button shine effect */
    @keyframes btnShine { 0%{left:-100%} 100%{left:200%} }
    #lpScreen .lp-btn-primary::after{content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);transform:skewX(-20deg);animation:btnShine 3s ease-in-out infinite}
    /* Particle float */
    @keyframes lpParticleFloat{0%{transform:translateY(0) translateX(0);opacity:0}10%{opacity:0.6}90%{opacity:0.6}100%{transform:translateY(-100vh) translateX(40px);opacity:0}}
    .lp-particle{position:absolute;border-radius:50%;pointer-events:none;animation:lpParticleFloat linear infinite}
    /* Hero background glow breathing */
    @keyframes lpHeroBreathe{0%,100%{opacity:0.15;transform:scale(1)}50%{opacity:0.3;transform:scale(1.1)}}
    .lp-hero-glow{animation:lpHeroBreathe 4s ease-in-out infinite}
    /* Enhanced card hover */
    #lpScreen .lp-bento-item:hover{transform:translateY(-6px);box-shadow:0 16px 50px rgba(16,185,129,0.2),0 12px 40px rgba(0,0,0,0.3)}
    /* Stats scale-in */
    @keyframes lpStatScaleIn{0%{opacity:0;transform:scale(0.5)}60%{transform:scale(1.08)}100%{opacity:1;transform:scale(1)}}
    .lp-stat-animate{animation:lpStatScaleIn 0.6s ease-out forwards}
    /* Browser frame mock */
    .lp-mock-browser{border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,0.1);box-shadow:0 20px 60px rgba(0,0,0,0.4)}
    .lp-mock-topbar{padding:8px 12px;background:rgba(0,0,0,0.4);display:flex;align-items:center;gap:6px;border-bottom:1px solid rgba(255,255,255,0.06)}
    .lp-mock-dots{display:flex;gap:5px}
    .lp-mock-dots span{width:8px;height:8px;border-radius:50%}
    .lp-mock-url{flex:1;margin:0 8px;padding:4px 10px;background:rgba(255,255,255,0.06);border-radius:6px;font-size:9px;color:#64748b}
    .lp-mock-body{display:flex;min-height:220px}
    .lp-mock-sidebar{width:48px;background:rgba(0,0,0,0.3);padding:8px 0;display:flex;flex-direction:column;align-items:center;gap:6px;border-right:1px solid rgba(255,255,255,0.04)}
    .lp-mock-sidebar i{width:24px;height:24px;border-radius:6px;display:block}
    .lp-mock-main{flex:1;padding:12px}
    #lpScreen *{box-sizing:border-box}
    #lpScreen .lp-glass{background:rgba(255,255,255,0.04);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,0.08);border-radius:20px}
    #lpScreen .lp-glass-light{background:rgba(255,255,255,0.06);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.1);border-radius:16px}
    #lpScreen .lp-gradient-text{background:linear-gradient(135deg,#a78bfa,#06b6d4,#34d399);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-size:200% 200%;animation:lpGradient 6s ease infinite}

    /* ===== COLORFUL LP OVERHAUL (kanri.html style) ===== */
    /* Multi-color glow orbs */
    @keyframes lpOrbDrift1{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(60px,-40px) scale(1.2)}66%{transform:translate(-30px,20px) scale(0.9)}}
    @keyframes lpOrbDrift2{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(-50px,30px) scale(1.15)}66%{transform:translate(40px,-50px) scale(0.85)}}
    @keyframes lpOrbDrift3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(20px,-60px) scale(1.1)}}
    .lp-orb-purple{position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(124,58,237,0.25) 0%,transparent 70%);filter:blur(80px);pointer-events:none;animation:lpOrbDrift1 12s ease-in-out infinite}
    .lp-orb-cyan{position:absolute;width:350px;height:350px;border-radius:50%;background:radial-gradient(circle,rgba(6,182,212,0.22) 0%,transparent 70%);filter:blur(70px);pointer-events:none;animation:lpOrbDrift2 10s ease-in-out infinite}
    .lp-orb-pink{position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(236,72,153,0.18) 0%,transparent 70%);filter:blur(65px);pointer-events:none;animation:lpOrbDrift3 14s ease-in-out infinite}
    .lp-orb-green{position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(16,185,129,0.2) 0%,transparent 70%);filter:blur(75px);pointer-events:none;animation:lpOrbDrift1 11s ease-in-out infinite reverse}

    /* Glassmorphism card */
    #lpScreen .lp-glass-card{background:rgba(255,255,255,0.04);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,0.08);border-radius:20px;transition:transform 0.5s cubic-bezier(.22,1,.36,1),box-shadow 0.5s cubic-bezier(.22,1,.36,1),border-color 0.4s ease}
    #lpScreen .lp-glass-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 24px 60px rgba(124,58,237,0.15),0 12px 30px rgba(6,182,212,0.1);border-color:rgba(124,58,237,0.25)}

    /* Section colored dividers */
    .lp-section-divider{height:2px;background:linear-gradient(90deg,transparent,#7c3aed,#06b6d4,#10b981,transparent);margin:0 auto;max-width:600px;opacity:0.5}

    /* Gradient badge pulse */
    @keyframes lpBadgePulse{0%,100%{box-shadow:0 0 0 0 rgba(124,58,237,0.4)}50%{box-shadow:0 0 0 12px rgba(124,58,237,0)}}
    .lp-badge-glow{animation:lpBadgePulse 2.5s ease-in-out infinite}

    /* Colorful stat number */
    .lp-stat-purple{background:linear-gradient(135deg,#a78bfa,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
    .lp-stat-cyan{background:linear-gradient(135deg,#67e8f9,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
    .lp-stat-pink{background:linear-gradient(135deg,#f9a8d4,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
    .lp-stat-green{background:linear-gradient(135deg,#6ee7b7,#10b981);-webkit-background-clip:text;-webkit-text-fill-color:transparent}

    /* Typing cursor multi-color */
    @keyframes lpCursorRainbow{0%{background:#a78bfa}25%{background:#06b6d4}50%{background:#10b981}75%{background:#ec4899}100%{background:#a78bfa}}
    .lp-cursor{animation:lpBlink 1s step-end infinite,lpCursorRainbow 4s linear infinite !important}

    /* Arrow bounce between steps */
    @keyframes lpArrowBounce{0%,100%{transform:translateX(0)}50%{transform:translateX(6px)}}
    .lp-arrow-bounce{animation:lpArrowBounce 1.5s ease-in-out infinite}

    /* CTA rainbow border */
    @keyframes lpRainbowBorder{0%{border-color:#7c3aed}25%{border-color:#06b6d4}50%{border-color:#10b981}75%{border-color:#ec4899}100%{border-color:#7c3aed}}

    /* Enhanced card icon hover glow */
    #lpScreen .lp-icon-box{transition:transform 0.4s ease,box-shadow 0.4s ease}
    #lpScreen .lp-glass-card:hover .lp-icon-box{transform:scale(1.2) rotate(8deg);box-shadow:0 0 24px rgba(124,58,237,0.3)}

    /* Floating label animation */
    @keyframes lpLabelFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
    .lp-float-label{animation:lpLabelFloat 3s ease-in-out infinite}

    /* Section heading gradient underline */
    #lpScreen .lp-heading-glow{position:relative;display:inline-block}
    #lpScreen .lp-heading-glow::after{content:'';position:absolute;bottom:-8px;left:10%;right:10%;height:3px;background:linear-gradient(90deg,#7c3aed,#06b6d4,#10b981);border-radius:2px;opacity:0.6}

    /* Neon text shadow on hover */
    #lpScreen h2:hover,#lpScreen h3:hover{text-shadow:0 0 30px rgba(124,58,237,0.25),0 0 60px rgba(6,182,212,0.15);transition:text-shadow 0.4s ease}

    /* Mesh gradient background for sections */
    .lp-mesh-bg{background:
      radial-gradient(ellipse at 20% 50%,rgba(124,58,237,0.08) 0%,transparent 50%),
      radial-gradient(ellipse at 80% 20%,rgba(6,182,212,0.06) 0%,transparent 50%),
      radial-gradient(ellipse at 50% 80%,rgba(16,185,129,0.06) 0%,transparent 50%)}

    /* Rainbow shimmer on CTA buttons */
    @keyframes lpRainbowShine{0%{background-position:200% 0}100%{background-position:-200% 0}}
    #lpScreen .lp-cta-rainbow{position:relative;overflow:hidden}
    #lpScreen .lp-cta-rainbow::after{content:'';position:absolute;top:0;left:-200%;width:200%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,0.15) 25%,rgba(167,139,250,0.15) 50%,rgba(6,182,212,0.15) 75%,transparent 100%);animation:lpRainbowShine 4s ease-in-out infinite}

    /* Pricing card popular glow */
    .lp-pricing-popular{position:relative}
    .lp-pricing-popular::before{content:'';position:absolute;inset:-2px;border-radius:18px;background:linear-gradient(135deg,#7c3aed,#06b6d4,#10b981);z-index:-1;opacity:0.6;filter:blur(1px)}
    .lp-pricing-popular::after{content:'';position:absolute;inset:0;border-radius:16px;background:#0f172a;z-index:-1}
    #lpScreen .lp-tag{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.05)}
    #lpScreen .lp-btn-primary{padding:14px 36px;background:linear-gradient(135deg,#10b981,#34d399);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;transition:all .3s;position:relative;overflow:hidden}
    #lpScreen .lp-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(16,185,129,0.4)}
    #lpScreen .lp-btn-secondary{padding:14px 36px;background:transparent;color:#e2e8f0;border:1.5px solid rgba(255,255,255,0.15);border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s}
    #lpScreen .lp-btn-secondary:hover{border-color:rgba(16,185,129,0.6);background:rgba(16,185,129,0.1)}
    #lpScreen .lp-section{padding:100px 48px;position:relative}
    #lpScreen .lp-section-inner{max-width:1100px;margin:0 auto}
    #lpScreen .lp-bento{display:grid;gap:16px}
    #lpScreen .lp-bento-item{padding:28px;border-radius:20px;position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s}
    #lpScreen .lp-pricing-grid .lp-bento-item,#lpScreen .lp-pricing-grid > div{overflow:visible !important}
    #lpScreen .lp-bento-item:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,0.3)}
    #lpScreen .lp-check{display:flex;align-items:center;gap:8px;font-size:13px;color:#94a3b8}
    #lpScreen .lp-check svg{flex-shrink:0}
    /* Scroll fade-in */
    .lp-animate{opacity:0;transform:translateY(30px);transition:opacity 0.6s ease,transform 0.6s ease}
    .lp-animate.lp-visible{opacity:1;transform:translateY(0)}
    /* Hero auto slideshow */
    @keyframes lpSlide1{0%,28%{opacity:1;z-index:3}33%,95%{opacity:0;z-index:1}100%{opacity:1;z-index:3}}
    @keyframes lpSlide2{0%,28%{opacity:0;z-index:1}33%,61%{opacity:1;z-index:3}66%,100%{opacity:0;z-index:1}}
    @keyframes lpSlide3{0%,61%{opacity:0;z-index:1}66%,95%{opacity:1;z-index:3}100%{opacity:0;z-index:1}}
    /* Tab animation */
    .lp-tab-content{display:none;animation:lpFadeIn 0.4s ease}
    .lp-tab-content.active{display:block}
    @keyframes lpFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
    /* Progress bar */
    @keyframes lpProgress{from{width:0}to{width:var(--w)}}
    /* Pop-in */
    @keyframes lpPopIn{0%{transform:scale(0.5);opacity:0}60%{transform:scale(1.1)}100%{transform:scale(1);opacity:1}}
    /* BA row slide */
    .lp-ba-row{opacity:0;transform:translateX(-30px);transition:opacity 0.5s ease,transform 0.5s ease}
    .lp-ba-row.lp-visible{opacity:1;transform:translateX(0)}
    /* Typewriter cursor */
    @keyframes lpBlink{0%,100%{opacity:1}50%{opacity:0}}
    .lp-cursor{display:inline-block;width:2px;height:1em;background:#a78bfa;margin-left:2px;animation:lpBlink 1s step-end infinite;vertical-align:text-bottom}
    /* Step line draw */
    @keyframes lpLineDraw{from{width:0}to{width:100%}}
    .lp-step-line{height:2px;background:linear-gradient(90deg,#10b981,#34d399);animation:lpLineDraw 1s ease-out forwards}
    /* Shimmer effect */
    @keyframes lpShimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
    .lp-shimmer{background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,0.05) 50%,transparent 100%);background-size:200% 100%;animation:lpShimmer 3s ease-in-out infinite}
    /* Stagger cards */
    .lp-stagger{opacity:0;transform:translateY(40px);transition:opacity 0.6s ease,transform 0.6s ease}
    .lp-stagger.lp-visible{opacity:1;transform:translateY(0)}
    /* Slide in left/right */
    .lp-slide-left{opacity:0;transform:translateX(-60px);transition:opacity 0.7s ease,transform 0.7s ease}
    .lp-slide-left.lp-visible{opacity:1;transform:translateX(0)}
    .lp-slide-right{opacity:0;transform:translateX(60px);transition:opacity 0.7s ease,transform 0.7s ease}
    .lp-slide-right.lp-visible{opacity:1;transform:translateX(0)}
    /* Rotate in */
    @keyframes lpRotateIn{from{transform:rotate(-8deg) scale(0.9);opacity:0}to{transform:rotate(0) scale(1);opacity:1}}
    /* Pulse ring */
    @keyframes lpPulseRing{0%{transform:scale(1);opacity:0.6}100%{transform:scale(2.5);opacity:0}}
    .lp-pulse-ring{position:absolute;border-radius:50%;border:2px solid;animation:lpPulseRing 2s ease-out infinite}
    /* Tour screenshot hover */
    .lp-tour-card{transition:transform 0.5s ease,box-shadow 0.5s ease}
    .lp-tour-card:hover{transform:scale(1.02);box-shadow:0 30px 80px rgba(16,185,129,0.25)}
    /* Typewriter cycle */
    @keyframes lpTypeIn{0%{width:0;opacity:1}5%{width:0;opacity:1}45%{width:100%;opacity:1}55%{width:100%;opacity:1}95%{width:0;opacity:1}100%{width:0;opacity:1}}
    .lp-type-cycle{display:inline-block;overflow:hidden;white-space:nowrap;border-right:3px solid #a78bfa;animation:lpBlink 1s step-end infinite}
    /* Gradient border animation */
    @keyframes lpBorderSpin{0%{--angle:0deg}100%{--angle:360deg}}
    .lp-glow-border{position:relative;overflow:hidden}
    .lp-glow-border::before{content:'';position:absolute;inset:-2px;background:conic-gradient(from var(--angle,0deg),#10b981,#34d399,#6ee7b7,#10b981);border-radius:inherit;z-index:-1;animation:lpBorderSpin 4s linear infinite}
    .lp-glow-border::after{content:'';position:absolute;inset:2px;background:#0f172a;border-radius:inherit;z-index:-1}
    /* Floating orb animation */
    @keyframes lpOrb{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(30px,-20px) scale(1.1)}50%{transform:translate(-10px,-40px) scale(0.9)}75%{transform:translate(-30px,-10px) scale(1.05)}}
    .lp-orb{position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none;animation:lpOrb 8s ease-in-out infinite}
    /* Number flip */
    @keyframes lpFlipIn{0%{transform:rotateX(-90deg);opacity:0}100%{transform:rotateX(0);opacity:1}}
    .lp-flip{animation:lpFlipIn 0.6s ease-out forwards;transform-style:preserve-3d}
    /* Scale bounce */
    @keyframes lpBounceIn{0%{transform:scale(0);opacity:0}60%{transform:scale(1.15)}100%{transform:scale(1);opacity:1}}
    .lp-bounce-in{opacity:0;animation:lpBounceIn 0.6s ease-out forwards}
    /* Scroll progress bar */
    #lpScrollProgress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,#10b981,#34d399,#6ee7b7);z-index:101;width:0;transition:width 0.1s linear;pointer-events:none}
    /* Glowing text on hover */
    .lp-hover-glow:hover{text-shadow:0 0 20px rgba(16,185,129,0.5),0 0 40px rgba(52,211,153,0.3)}
    /* Animated counter bar */
    @keyframes lpBarGrow{from{width:0}to{width:var(--bar-w,100%)}}
    .lp-bar-grow{animation:lpBarGrow 1.5s ease-out forwards}
    /* Wobble attention */
    @keyframes lpWobble{0%,100%{transform:rotate(0)}25%{transform:rotate(-3deg)}75%{transform:rotate(3deg)}}
    /* Tilt on hover */
    .lp-tilt{transition:transform 0.4s ease}
    .lp-tilt:hover{transform:perspective(1000px) rotateY(-5deg) rotateX(3deg) scale(1.02)}
    /* Live demo typing */
    @keyframes lpDemoType{0%{width:0}100%{width:100%}}
    @keyframes lpDemoFade{0%{opacity:0;transform:translateY(8px)}100%{opacity:1;transform:translateY(0)}}
    /* Marquee */
    @keyframes lpMarquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
    /* Testimonial card */
    .lp-testimonial{opacity:0;transform:scale(0.95);transition:opacity 0.5s ease,transform 0.5s ease}
    .lp-testimonial.lp-visible{opacity:1;transform:scale(1)}
    /* Tab buttons */
    .lp-tab-btn{padding:10px 20px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:10px;color:#94a3b8;font-size:13px;font-weight:700;cursor:pointer;transition:all .3s;white-space:nowrap}
    .lp-tab-btn.active{background:linear-gradient(135deg,rgba(16,185,129,0.2),rgba(52,211,153,0.15));border-color:rgba(16,185,129,0.4);color:#e2e8f0}
    .lp-tab-btn:hover{border-color:rgba(16,185,129,0.3);color:#e2e8f0}
    @media(max-width:768px){
      #lpScreen .lp-section{padding:60px 20px !important}
      #lpScreen #lpHeroSection{padding-top:120px !important;padding-bottom:40px !important}
      #lpScreen > header{padding:12px 16px !important}
      #lpScreen > header span[style*="font-size:18px"]{font-size:15px !important}
      #lpScreen > header .lp-btn-primary,#lpScreen > header button[style*="padding:9px 22px"]{padding:8px 16px !important;font-size:12px !important}
      #lpScreen > header a[style*="padding:9px 16px"]{padding:8px 10px !important;font-size:12px !important}
      #lpScreen .lp-hero-grid{grid-template-columns:1fr !important;gap:30px !important}
      #lpScreen .lp-hero-grid > div[style*="height:340px"]{height:240px !important}
      #lpScreen .lp-bento{grid-template-columns:1fr !important}
      #lpScreen .lp-feature-split{grid-template-columns:1fr !important}
      #lpScreen .lp-pricing-grid{grid-template-columns:1fr !important}
      #lpScreen .lp-pricing-grid > div{overflow:visible !important;margin-top:12px !important}
      #lpScreen .lp-stats-grid{grid-template-columns:1fr 1fr !important}
      #lpScreen table{font-size:11px !important}
      #lpScreen table th,#lpScreen table td{padding:8px 6px !important}
      #lpScreen .lp-bento-item[style*="grid-column:span 2"]{grid-column:span 1 !important}
      #lpScreen .lp-bento-item[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr !important}
      .lp-tab-wrap{flex-wrap:wrap}
      .lp-mock-body{flex-direction:column}
      .lp-mock-sidebar{width:100%;flex-direction:row;padding:4px 8px;border-right:none;border-bottom:1px solid rgba(255,255,255,0.04)}
      .lp-mock-sidebar i{width:18px;height:18px}
      .lp-mock-body{min-height:180px}
      #lpScreen .lp-tab-content .lp-glass{grid-template-columns:1fr !important}
      #lpScreen .lp-slide-left > div,#lpScreen .lp-slide-right > div{grid-template-columns:1fr !important}
      #lpScreen .lp-slide-left .lp-mock-browser,#lpScreen .lp-slide-right .lp-mock-browser{order:-1}
      #lpScreen [style*="grid-template-columns:1fr auto 1fr auto 1fr"]{grid-template-columns:1fr !important;gap:20px !important}
      #lpScreen [style*="grid-template-columns:1fr auto 1fr auto 1fr"] > div[style*="padding:0 8px"]{display:none}
      #lpScreen [style*="grid-template-columns:repeat(3,1fr)"][style*="max-width:900px"]{grid-template-columns:1fr !important}
      #lpScreen [style*="grid-template-columns:repeat(5,1fr)"]{grid-template-columns:repeat(2,1fr) !important}
      #lpScreen [style*="grid-template-columns:1.4fr 1fr"]{grid-template-columns:1fr !important}
      #lpScreen [style*="grid-template-columns:1fr 1.4fr"]{grid-template-columns:1fr !important}
    }
    @media(max-width:900px){.lp-pricing-grid{grid-template-columns:repeat(2,1fr)!important}}
    @media(max-width:540px){.lp-pricing-grid{grid-template-columns:1fr!important}}

    /* ===== M-02: prefers-reduced-motion 対応 ===== */
    @media (prefers-reduced-motion: reduce) {
      .lp-animate, .lp-stagger, .lp-slide-left, .lp-slide-right,
      .lp-ba-row, .lp-particle, .lp-orb, .lp-hero-glow,
      .lp-testimonial, .lp-bounce-in, .lp-stat-animate,
      .lp-orb-purple, .lp-orb-cyan, .lp-orb-pink, .lp-orb-green,
      .lp-badge-glow, .lp-cta-rainbow::after, .lp-pulse-ring,
      .lp-type-cycle, .lp-cursor, .lp-shimmer, .lp-float-label {
        animation: none !important;
        transition: none !important;
        opacity: 1 !important;
        transform: none !important;
      }
      #lpScrollProgress { display: none !important; }
      #lpParticles { display: none !important; }
      #lpScreen .lp-btn-primary::after { animation: none !important; }
      #lpScreen .lp-gradient-text,
      #lpScreen .lp-stat-purple, #lpScreen .lp-stat-cyan,
      #lpScreen .lp-stat-pink, #lpScreen .lp-stat-green {
        animation: none !important;
      }
    }

    /* ===== M-03: グラデーションテキスト 標準プロパティ追加 ===== */
    #lpScreen .lp-gradient-text{background-clip:text;color:transparent}
    .lp-stat-purple,.lp-stat-cyan,.lp-stat-pink,.lp-stat-green{background-clip:text;color:transparent}

    /* ===== H-02: キーボードアクセシビリティ — focus-visible スタイル ===== */
    #lpScreen a:focus-visible,
    #lpScreen button:focus-visible,
    #lpScreen .lp-tab-btn:focus-visible,
    #lpScreen input:focus-visible,
    #lpScreen select:focus-visible,
    #lpScreen textarea:focus-visible,
    #lpScreen details summary:focus-visible {
      outline: 2px solid #10b981;
      outline-offset: 2px;
      box-shadow: 0 0 0 4px rgba(16,185,129,0.25);
    }
    /* スキップリンク（JS で挿入） */
    #lpSkipNav{position:absolute;top:-100px;left:16px;padding:8px 16px;background:#10b981;color:#fff;border-radius:8px;font-size:13px;font-weight:700;z-index:110;transition:top 0.2s ease}
    #lpSkipNav:focus{top:8px}

    /* ===== M-01: コントラスト改善 ===== */
    #lpScreen .lp-header-nav a[style*="color:var(--gray-400)"],
    #lpScreen .lp-header-nav a[id="lpHeaderLoginBtn"] {
      color: #cbd5e1 !important;
    }

/* ===== 物件マッチング (PM) ===== */
.pm-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:14px 16px;margin-bottom:12px}
.pm-section-title{font-size:13px;font-weight:800;color:var(--gray-800);margin-bottom:10px}
.pm-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;border:none;cursor:pointer;transition:opacity .15s}
.pm-btn:hover{opacity:.85}
.pm-btn-primary{background:#10b981;color:#fff}
.pm-btn-ghost{background:#f1f5f9;color:var(--gray-700)}
.pm-tag{display:inline-block;padding:2px 8px;border-radius:6px;font-size:10px;font-weight:600;line-height:1.6}
.pm-tag-hit{background:#dcfce7;color:#16a34a}
.pm-tag-miss{background:#fef3c7;color:#d97706}
.pm-card{display:flex;gap:12px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:12px;margin-bottom:8px;transition:box-shadow .15s}
.pm-card:hover{box-shadow:0 2px 8px rgba(0,0,0,.06)}
.pm-card-img{width:90px;height:70px;border-radius:8px;object-fit:cover;flex-shrink:0;background:#10b981}
.pm-card-body{flex:1;min-width:0}
.pm-form-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.pm-form-row .pm-label{width:90px;flex-shrink:0;font-size:12px;font-weight:600;color:var(--gray-600)}
.pm-form-row .pm-input{flex:1}
.pm-input{border:1px solid #cbd5e1;border-radius:8px;padding:6px 10px;font-size:12px;outline:none;width:100%;box-sizing:border-box}
.pm-input:focus{border-color:#10b981;box-shadow:0 0 0 2px rgba(16,185,129,.15)}
.pm-actions{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px}
.pm-meta{font-size:10px;color:var(--gray-400);margin-top:4px}
@media(max-width:600px){
  .pm-card{flex-direction:column}
  .pm-card-img{width:100%;height:120px}
  .pm-form-row{flex-direction:column;align-items:stretch}
  .pm-form-row .pm-label{width:auto;margin-bottom:2px}
}

/* ===== Support Chat / FAB overlap fix (mobile) ===== */
@media(max-width:768px){
  #supportChatBtn{top:12px!important;right:12px!important;bottom:auto!important;width:44px!important;height:44px!important}
  #mobileFAB,
  #fabMenu{
    display:none!important;
    opacity:0!important;
    pointer-events:none!important;
  }
  #docAiPanel{bottom:64px!important;right:12px!important;max-width:calc(100vw - 24px)!important}
  #supportChatModal{top:64px!important;bottom:auto!important;right:12px!important;max-width:calc(100vw - 24px)!important;max-height:calc(100dvh - 82px)!important}
}

/* ===== Modal mobile fix ===== */
@media(max-width:768px){
  .modal{
    max-height:90vh !important;
    overflow-y:auto !important;
    max-width:calc(100vw - 24px) !important;
    border-radius:12px !important;
  }
  .modal-body{
    max-height:calc(90vh - 80px) !important;
    overflow-y:auto !important;
  }
  .modal-header{
    padding:16px !important;
  }
  .modal-lg{
    max-width:calc(100vw - 24px) !important;
  }
}

@media(max-width:480px){
  .modal{
    max-height:95vh !important;
    max-width:calc(100vw - 16px) !important;
  }
  .modal-body{
    max-height:calc(95vh - 100px) !important;
  }
  .modal-header{
    padding:14px 12px !important;
  }
}

/* ===== 共通ユーティリティ（インラインスタイル置換用） ===== */
.u-label-sm{font-size:11px;font-weight:700;color:var(--gray-700);display:block;margin-bottom:4px}
.u-label-xs{font-size:10px;font-weight:600;color:var(--gray-500);display:block;margin-bottom:2px}
.u-text-right{text-align:right}
.u-text-center{text-align:center}
.u-divider{border-bottom:1px solid #f1f5f9}
.u-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.u-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.u-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.u-flex-between{display:flex;justify-content:space-between;align-items:center}
.u-flex-gap{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.u-btn-bar{display:flex;gap:8px;margin-top:12px}
.u-meta{font-size:10px;color:var(--gray-400)}
.u-section-title{font-size:13px;font-weight:800;color:var(--gray-800);margin-bottom:10px}
.u-status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.u-status-dot--green{background:#22c55e}
.u-status-dot--yellow{background:#f59e0b}
.u-status-dot--red{background:#ef4444}
.u-status-dot--gray{background:#94a3b8}
.u-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.u-fs-12{font-size:12px}
.u-fs-11{font-size:11px}
.u-fs-10{font-size:10px}
.u-text-muted{color:var(--gray-500)}
.u-text-subtle{font-size:10px;color:var(--gray-400)}
.u-text-sub{font-size:10px;color:var(--gray-500)}
.u-text-danger{color:var(--red-500)}
.u-text-success{color:var(--green-600,#16a34a)}
.u-nowrap{white-space:nowrap}
.u-nowrap-sm{white-space:nowrap;font-size:12px}
.u-flex-center{display:flex;align-items:center;gap:8px}
.u-flex-wrap{display:flex;flex-wrap:wrap;gap:6px}
.u-input-base{width:100%;padding:11px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:14px;font-family:inherit}
.u-stat-card{background:var(--gray-50);border-radius:10px;padding:10px 8px;text-align:center;border:1px solid #e2e8f0}
.u-num-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#059669;color:#fff;font-size:10px;font-weight:800;margin-right:2px}
.u-section-label{font-size:9px;font-weight:700;color:var(--gray-400);letter-spacing:0.08em;margin-bottom:3px}
.u-label-muted{font-size:12px;color:var(--gray-500);display:block;margin-bottom:4px}
.u-text-muted-sm{font-size:11px;color:var(--gray-500)}
.u-text-muted-mb{font-size:11px;color:var(--gray-500);margin-bottom:4px}
.u-text-muted-bold{color:var(--gray-500);font-weight:600}
.u-text-muted-label{font-size:11px;color:var(--gray-500);display:block;margin-bottom:2px}
.u-text-muted-label-3{font-size:11px;color:var(--gray-500);display:block;margin-bottom:3px}
.u-text-muted-sm-bold{font-size:11px;color:var(--gray-500);margin-bottom:4px;font-weight:600}
.u-text-subtle-mb{font-size:10px;color:var(--gray-400);margin-bottom:2px}
.u-text-subtle-lg{font-size:11px;color:var(--gray-400)}
.u-text-muted-12{font-size:12px;color:var(--gray-500)}
.u-text-gray-400{color:var(--gray-400)}
.u-fw-600{font-weight:600}
.u-mb-16{margin-bottom:16px}
.u-d-none{display:none}
.u-bg-gray-50{background:var(--gray-50)}
.u-table-base{width:100%;border-collapse:collapse}
.u-mb-8{margin-bottom:8px}
.u-mb-12{margin-bottom:12px}
.u-mb-20{margin-bottom:20px}
.u-mt-8{margin-top:8px}
.u-mt-12{margin-top:12px}
.u-flex-gap-8{display:flex;gap:8px}

/* ===== TABLE CELL UTILITIES ===== */
.u-td{padding:8px 12px}
.u-td-right{padding:8px 12px;text-align:right}
.u-td-center{padding:8px 12px;text-align:center}
.u-td-sm{padding:8px}
.u-td-sm-right{padding:8px;text-align:right}
.u-td-sm-center{padding:8px;text-align:center}
.u-th{padding:8px 12px;font-size:11px;font-weight:700;color:var(--gray-500);text-align:left;border-bottom:2px solid #e2e8f0}
.u-th-center{padding:10px 14px;font-size:11px;font-weight:700;color:var(--gray-500);text-align:center;border-bottom:2px solid #e2e8f0}
.u-td-row{padding:10px 12px;text-align:left;font-weight:600;color:var(--gray-700)}
.u-td-row-center{padding:10px 12px;text-align:center;font-weight:600;color:var(--gray-700)}
.u-td-right-bold{padding:10px 16px;text-align:right;font-weight:600}
.u-td-pad{padding:10px 16px}
.u-td-pad-right{padding:10px 8px;text-align:right}
.u-td-pad-right-bold{padding:10px 8px;text-align:right;font-weight:600}
.u-td-pad-center{padding:10px 14px;text-align:center}
.u-td-12-right{padding:12px;text-align:center}
.u-td-sm-11-right{padding:8px;font-size:11px;text-align:right}
.u-td-sm-12-right{padding:8px;font-size:12px;text-align:right}
.u-td-right-muted{padding:8px 12px;text-align:right;font-weight:600;color:var(--gray-500)}
.u-td-sm-12{padding:8px 12px;font-size:12px}
.u-td-kpi{padding:16px;text-align:center;border-right:1px solid #e2e8f0}
.u-td-detail{padding:8px 10px;font-size:9px;color:var(--gray-700);line-height:1.8}
.u-td-detail-center{padding:8px 10px;text-align:center}

/* ===== SECTION TITLE UTILITIES ===== */
.u-heading-800{font-size:13px;font-weight:700;color:var(--gray-800)}
.u-heading-900{font-size:13px;font-weight:700;color:var(--gray-900)}
.u-heading-brand{font-size:13px;font-weight:700;color:#1F3864;border-bottom:2px solid #1F3864;padding-bottom:6px;margin:0 0 12px}
.u-heading-700{font-size:13px;font-weight:700;color:var(--gray-700)}
.u-heading-700-mb{font-size:13px;font-weight:700;color:var(--gray-700);margin-bottom:8px}
.u-heading-600{font-size:13px;font-weight:600;color:#334155;margin-bottom:8px}
.u-heading-600-mb10{font-size:13px;font-weight:600;color:#334155;margin-bottom:10px}
.u-heading-600-700{font-size:13px;font-weight:600;color:var(--gray-700);margin-bottom:12px}
.u-heading-800-border{font-size:13px;font-weight:700;color:var(--gray-800);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid #e2e8f0}
.u-heading-800-mb4{font-size:13px;font-weight:700;color:var(--gray-800);margin-bottom:4px}
.u-heading-800-mb10{font-size:13px;font-weight:700;color:var(--gray-800);margin-bottom:10px}

/* ===== GRID UTILITIES (extended) ===== */
.u-grid-2-10{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.u-grid-2-16{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.u-grid-3-10{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
@media(max-width:768px){
  .u-grid-2,.u-grid-3,.u-grid-4{grid-template-columns:1fr}
}

/* ===================================================================
 * [R-NEW28] スマホ表示崩壊の包括的修正
 * ユーザー報告: メイン画面をスマホで開くと「メチャクチャ」に崩れている。
 * playwright + iPhone 14 Pro emulation (390x844) で確認した overflow:
 *   - 29 要素が viewport (390px) を超えて 416-460px で描画
 *   - #dashZeroState (ダッシュボード空状態 2列カード) が最大 460px overflow
 *   - inline style grid-template-columns:1fr 1fr などが mobile 1 列化されていない
 *   - 一部の card / .view 子要素が min-width: auto で grid blowout
 * ----------------------------------------------------------------- */
@media (max-width: 768px) {
  /* 1) 大原則: body / html は横スクロール禁止 (line 8 で既設) を維持し、
     さらに全 view も同様にして「画面外に巨大要素が突き出す」事故を防ぐ */
  #appShell, .main-content, .view {
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }

  /* 2) grid / flex 子要素のうち、デフォルトで min-width: auto を残すと
     コンテンツ最小幅 (テキストの非改行/SVG 等) で grid blowout する。
     ダッシュボードと主要 view 内の子要素に min-width: 0 を強制。 */
  #view-dashboard, #view-rentalManagement, #view-crm, #view-inbound,
  #view-properties, #view-applications, #view-tenants, #view-payments,
  #view-repairs, #view-arrear, #view-contracts, #view-ownerReport,
  #view-ownerMgmt, #view-docs, #view-esign, #view-rentAppraisal,
  #view-bbAgents, #view-settings, #view-billing, #view-team,
  #view-loan, #view-analytics, #view-aroundService {
    min-width: 0 !important;
  }
  #view-dashboard *, #view-rentalManagement *, #view-crm *,
  #view-inbound *, #view-properties *, #view-applications *,
  #view-tenants *, #view-payments *, #view-repairs *,
  #view-arrear *, #view-contracts *, #view-ownerReport *,
  #view-ownerMgmt *, #view-docs *, #view-esign *,
  #view-rentAppraisal *, #view-bbAgents *, #view-settings *,
  #view-billing *, #view-team *, #view-loan *,
  #view-analytics *, #view-aroundService * {
    min-width: 0;
  }

  /* 3) ダッシュボード空状態カード: inline style で grid-template-columns:1fr 1fr
     が指定されているため !important で 1 列に上書き */
  #dashZeroState > div[style*="grid-template-columns:1fr 1fr"],
  #dashZeroState > div[style*="grid-template-columns: 1fr 1fr"] {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 12px !important;
  }

  /* 4) インラインで grid-template-columns に複数列を指定している
     ダッシュボード系セクションを共通で 1 列化 (主要セレクタを列挙) */
  #view-dashboard [style*="grid-template-columns:1fr 1fr"],
  #view-dashboard [style*="grid-template-columns: 1fr 1fr"],
  #view-dashboard [style*="grid-template-columns:repeat(2,"],
  #view-dashboard [style*="grid-template-columns:repeat(3,"],
  #view-dashboard [style*="grid-template-columns:repeat(4,"] {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  #view-rentalManagement [style*="grid-template-columns:1fr 1fr"],
  #view-rentalManagement [style*="grid-template-columns: 1fr 1fr"],
  #view-rentalManagement [style*="grid-template-columns:repeat(2,"],
  #view-rentalManagement [style*="grid-template-columns:repeat(3,"],
  #view-rentalManagement [style*="grid-template-columns:repeat(4,"] {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  #view-rentalManagement [style*="grid-template-columns:repeat(4,"],
  #view-rentalManagement [style*="grid-template-columns: repeat(4,"] {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  /* 5) テーブル overflow 対策 — 親に table-wrap がない素のテーブルも
     横スクロール可能にして、突き出さないようにする */
  .view table:not(.no-scroll) {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100% !important;
  }

  /* 6) モーダル: 横幅 viewport 内に収める */
  .modal-content, .uls-modal-content, .modal-body,
  .modal, [class*="modal-dialog"] {
    max-width: calc(100vw - 16px) !important;
    width: calc(100vw - 16px) !important;
  }

  /* 7) フォーム: 入力欄が parent を超えないように */
  .form-control, input[type="text"], input[type="email"],
  input[type="password"], input[type="number"], input[type="tel"],
  input[type="search"], input[type="date"], select, textarea {
    max-width: 100% !important;
    box-sizing: border-box;
  }

  /* 8) img / svg がコンテナ幅を超えないように */
  .view img, .view svg.responsive {
    max-width: 100% !important;
    height: auto;
  }
}

/* 9) 320-380px の極狭スマホ向け: グリッドはすべて 1 列にまで縮退 */
@media (max-width: 380px) {
  #view-rentalManagement [style*="grid-template-columns:1fr 1fr"],
  #view-rentalManagement [style*="grid-template-columns: 1fr 1fr"],
  #view-rentalManagement [style*="grid-template-columns:repeat(2,"],
  #view-rentalManagement [style*="grid-template-columns:repeat(3,"],
  #view-rentalManagement [style*="grid-template-columns:repeat(4,"] {
    grid-template-columns: minmax(0, 1fr) !important;
  }
}
/* ===================================================================
 * [R-NEW28] end
 * ----------------------------------------------------------------- */

/* [R-NEW28 retry] grid items も intrinsic min-content で expand しないように
 * minmax(0, 1fr) で囲んだ上で、子要素にも明示 min-width:0 */
@media (max-width: 768px) {
  #dashZeroState, #dashZeroState > div, #dashZeroState > div > div {
    min-width: 0 !important;
    max-width: 100% !important;
  }
  /* インラインで grid-template-columns に複数列が書かれた全要素を強制 1 列+shrinkable */
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns:repeat(2,"],
  [style*="grid-template-columns: repeat(2,"],
  [style*="grid-template-columns:repeat(3,"],
  [style*="grid-template-columns: repeat(3,"],
  [style*="grid-template-columns:repeat(4,"],
  [style*="grid-template-columns: repeat(4,"] {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  /* それらの直接の子も shrinkable に */
  [style*="grid-template-columns:1fr 1fr"] > *,
  [style*="grid-template-columns: 1fr 1fr"] > *,
  [style*="grid-template-columns:repeat(2,"] > *,
  [style*="grid-template-columns: repeat(2,"] > *,
  [style*="grid-template-columns:repeat(3,"] > *,
  [style*="grid-template-columns: repeat(3,"] > *,
  [style*="grid-template-columns:repeat(4,"] > *,
  [style*="grid-template-columns: repeat(4,"] > * {
    min-width: 0 !important;
    max-width: 100% !important;
  }
}

/* [R-NEW28 step 3] 残り overflow パターン:
 *  - インライン min-width:120px の button → 上書き
 *  - 横並びの 2-col .card レイアウト → wrap 強制
 *  - .card / .view 全要素に max-width: 100%
 *  - position:absolute で viewport 外に出る要素 → right/transform reset */
@media (max-width: 768px) {
  /* インライン min-width を持つ button / div を強制 shrinkable */
  button[style*="min-width:"], div[style*="min-width:"] {
    min-width: 0 !important;
  }
  /* flex 横並びを wrap させて、子要素が突き出さないように */
  [style*="display:flex"]:not(.no-wrap),
  [style*="display: flex"]:not(.no-wrap) {
    flex-wrap: wrap !important;
  }
  /* 全 .card と view 直下の div は viewport 内に収める */
  .view .card, .view > div, .view section,
  .view article {
    max-width: 100% !important;
    box-sizing: border-box;
  }
  /* インライン margin に依存しない margin-bottom:20px ラッパー類 */
  .view [style*="margin-bottom:20px"],
  .view [style*="margin-bottom: 20px"] {
    max-width: 100% !important;
    box-sizing: border-box;
  }
  /* タイムライン等の長いコンテンツは横スクロール許可 */
  #dashActivityTimeline, #dashOpsCommandCenter {
    max-width: 100% !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
  }
  /* position:absolute で viewport 外に出る要素を viewport 内に閉じ込める */
  .view [style*="position:absolute"],
  .view [style*="position: absolute"] {
    max-width: 100vw !important;
  }
}

/* Sales analytics: simplified decision-first layout */
#view-analytics .an-slim-shell {
  display: grid;
  gap: 16px;
}

#view-analytics .an-focus-panel {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  padding: 18px;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
}

#view-analytics .an-eyebrow {
  margin-bottom: 6px;
  color: #0f766e;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0;
}

#view-analytics .an-focus-title {
  color: #0f172a;
  font-size: 20px;
  font-weight: 900;
  line-height: 1.35;
  letter-spacing: 0;
}

#view-analytics .an-focus-copy {
  max-width: 620px;
  margin-top: 5px;
  color: #64748b;
  font-size: 12px;
  line-height: 1.7;
}

#view-analytics .an-focus-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

#view-analytics .an-primary-btn,
#view-analytics .an-ghost-btn {
  min-height: 34px;
  padding: 8px 13px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
  transition: background .15s ease, border-color .15s ease, color .15s ease, transform .15s ease;
}

#view-analytics .an-primary-btn {
  border: 1px solid #0f766e;
  background: #0f766e;
  color: #fff;
}

#view-analytics .an-ghost-btn {
  border: 1px solid #cbd5e1;
  background: #fff;
  color: #334155;
}

#view-analytics .an-primary-btn:hover,
#view-analytics .an-ghost-btn:hover {
  transform: translateY(-1px);
}

#view-analytics .an-main-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, .85fr);
  gap: 16px;
  align-items: start;
}

#view-analytics .an-main-grid > *,
#view-analytics .an-fold-body > * {
  min-width: 0;
}

#view-analytics .an-section-title {
  margin: 2px 0 -6px;
  color: #334155;
  font-size: 12px;
  font-weight: 900;
}

#view-analytics .an-fold {
  overflow: hidden;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  background: #fff;
}

#view-analytics .an-fold summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  cursor: pointer;
  list-style: none;
}

#view-analytics .an-fold summary::-webkit-details-marker {
  display: none;
}

#view-analytics .an-fold summary span {
  color: #0f172a;
  font-size: 13px;
  font-weight: 900;
}

#view-analytics .an-fold summary small {
  color: #64748b;
  font-size: 11px;
  font-weight: 700;
  line-height: 1.5;
}

#view-analytics .an-fold[open] summary {
  border-bottom: 1px solid #edf2f7;
}

#view-analytics .an-fold-body {
  display: grid;
  gap: 14px;
  padding: 14px 16px 16px;
}

#view-analytics .an-deep-report {
  gap: 18px;
}

@media (max-width: 900px) {
  #view-analytics .an-focus-panel,
  #view-analytics .an-fold summary {
    flex-direction: column;
    align-items: stretch;
  }

  #view-analytics .an-focus-actions {
    justify-content: stretch;
  }

  #view-analytics .an-focus-actions button {
    flex: 1 1 140px;
  }

  #view-analytics .an-main-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

/* Mobile scroll final guard:
   the page should have exactly one vertical app scroller: .main-content.
   If .view also becomes a scroll container, wheel/touch events can get trapped
   on forms or empty view areas and the user feels like the screen is frozen. */
@media (max-width: 768px) {
  .main-content {
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
  }

  .view,
  .view.active {
    overflow-x: visible !important;
    overflow-y: visible !important;
  }
}

/* CRM command center */
.crm-command-center{
  margin:0 0 16px;
}
.crm-command-grid{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(280px,.9fr);
  gap:14px;
  align-items:stretch;
}
.crm-command-card{
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:10px;
  padding:16px;
  box-shadow:0 10px 28px rgba(15,23,42,.04);
  min-width:0;
}
.crm-command-primary{
  grid-row:span 2;
}
.crm-command-wide{
  grid-column:2;
}
.crm-command-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.crm-command-eyebrow{
  color:#64748b;
  font-size:10px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.crm-command-head h3{
  margin:2px 0 0;
  color:#0f172a;
  font-size:17px;
  font-weight:900;
  letter-spacing:0;
}
.crm-command-link{
  border:1px solid #dbeafe;
  border-radius:8px;
  background:#eff6ff;
  color:#2563eb;
  cursor:pointer;
  font-size:11px;
  font-weight:900;
  padding:7px 10px;
  white-space:nowrap;
}
.crm-command-stats{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
  margin-bottom:12px;
}
.crm-command-stat{
  border:1px solid #e2e8f0;
  border-radius:8px;
  background:#f8fafc;
  padding:10px;
  min-width:0;
}
.crm-command-stat-danger{background:#fef2f2;border-color:#fecaca}
.crm-command-stat-warn{background:#fffbeb;border-color:#fde68a}
.crm-command-stat-good{background:#f0fdf4;border-color:#bbf7d0}
.crm-command-stat-label{
  color:#64748b;
  font-size:10px;
  font-weight:900;
}
.crm-command-stat-value{
  margin-top:3px;
  color:#0f172a;
  font-size:24px;
  font-weight:950;
  line-height:1;
}
.crm-command-stat-sub{
  margin-top:4px;
  color:#64748b;
  font-size:10px;
  font-weight:700;
  line-height:1.35;
}
.crm-work-list{
  display:grid;
  gap:8px;
}
.crm-work-item{
  display:grid;
  grid-template-columns:30px minmax(0,1fr) auto auto;
  align-items:center;
  gap:10px;
  width:100%;
  border:1px solid #e2e8f0;
  border-radius:9px;
  background:#fff;
  cursor:pointer;
  padding:10px;
  text-align:left;
  transition:background .12s ease,border-color .12s ease,transform .12s ease;
}
.crm-work-item:hover{
  background:#f8fafc;
  border-color:#bfdbfe;
  transform:translateY(-1px);
}
.crm-work-rank{
  display:flex;
  align-items:center;
  justify-content:center;
  width:26px;
  height:26px;
  border-radius:999px;
  background:#0f172a;
  color:#fff;
  font-size:11px;
  font-weight:900;
}
.crm-work-main{
  min-width:0;
}
.crm-work-main strong{
  display:block;
  color:#0f172a;
  font-size:13px;
  font-weight:900;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.crm-work-main small{
  display:block;
  margin-top:2px;
  color:#64748b;
  font-size:10px;
  font-weight:700;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.crm-work-badge{
  border-radius:999px;
  font-size:10px;
  font-weight:900;
  padding:4px 8px;
  white-space:nowrap;
}
.crm-work-badge-danger{background:#fee2e2;color:#b91c1c}
.crm-work-badge-warn{background:#fef3c7;color:#b45309}
.crm-work-badge-good{background:#dcfce7;color:#15803d}
.crm-work-badge-neutral{background:#f1f5f9;color:#475569}
.crm-work-action{
  color:#0f172a;
  font-size:11px;
  font-weight:900;
  white-space:nowrap;
}
.crm-kpi-progress{
  display:grid;
  gap:12px;
}
.crm-progress-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px 12px;
  align-items:center;
}
.crm-progress-row strong{
  display:block;
  color:#0f172a;
  font-size:12px;
  font-weight:900;
}
.crm-progress-row small{
  display:block;
  margin-top:2px;
  color:#64748b;
  font-size:10px;
  font-weight:700;
}
.crm-progress-row span{
  color:#0f172a;
  font-size:12px;
  font-weight:900;
}
.crm-progress-row i{
  grid-column:1 / -1;
  display:block;
  height:8px;
  overflow:hidden;
  border-radius:999px;
  background:#e2e8f0;
}
.crm-progress-row i b{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,#10b981,#22c55e);
}
.crm-progress-row i.is-risk b{
  background:linear-gradient(90deg,#f59e0b,#ef4444);
}
.crm-owner-list{
  display:grid;
  gap:8px;
}
.crm-owner-row{
  display:grid;
  grid-template-columns:minmax(118px,1fr) repeat(4,72px) 92px;
  gap:8px;
  align-items:center;
  width:100%;
  border:1px solid #e2e8f0;
  border-radius:9px;
  background:#fff;
  cursor:pointer;
  padding:9px 10px;
  text-align:left;
}
.crm-owner-row:hover,
.crm-owner-row.is-active{
  border-color:#93c5fd;
  background:#eff6ff;
}
.crm-owner-name{
  min-width:0;
  color:#0f172a;
  font-size:12px;
  font-weight:900;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.crm-owner-metric{
  text-align:right;
}
.crm-owner-metric strong{
  display:block;
  color:#0f172a;
  font-size:13px;
  font-weight:950;
}
.crm-owner-metric small{
  display:block;
  color:#64748b;
  font-size:9px;
  font-weight:800;
}
.crm-owner-warn strong{
  color:#dc2626;
}
.crm-owner-health{
  position:relative;
  display:block;
  height:18px;
  border-radius:999px;
  overflow:hidden;
  background:#e2e8f0;
}
.crm-owner-health i{
  display:block;
  height:100%;
  border-radius:999px;
}
.crm-owner-health-good i{background:#22c55e}
.crm-owner-health-warn i{background:#f59e0b}
.crm-owner-health-danger i{background:#ef4444}
.crm-owner-health em{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#0f172a;
  font-size:10px;
  font-style:normal;
  font-weight:950;
}
.crm-empty-command{
  display:flex;
  flex-direction:column;
  gap:4px;
  border:1px dashed #cbd5e1;
  border-radius:9px;
  background:#f8fafc;
  color:#475569;
  padding:16px;
}
.crm-empty-command strong{
  color:#0f172a;
  font-size:13px;
}
.crm-empty-command span{
  font-size:11px;
  font-weight:700;
}

@media(max-width:1100px){
  .crm-command-grid{
    grid-template-columns:1fr;
  }
  .crm-command-primary,
  .crm-command-wide{
    grid-column:auto;
    grid-row:auto;
  }
}

@media(max-width:640px){
  .crm-command-card{
    padding:12px;
    border-radius:9px;
  }
  .crm-command-head{
    flex-direction:column;
    align-items:stretch;
  }
  .crm-command-stats{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .crm-work-item{
    grid-template-columns:26px minmax(0,1fr);
    gap:8px;
  }
  .crm-work-badge,
  .crm-work-action{
    grid-column:2;
    justify-self:start;
  }
  .crm-owner-row{
    grid-template-columns:minmax(0,1fr) repeat(2,58px);
  }
  .crm-owner-row .crm-owner-metric:nth-of-type(n+4),
  .crm-owner-health{
    display:none;
  }
}

/* CRM / Analytics cockpit simplification */
.crm-simple-shell,
.an-simple-shell{
  display:grid;
  gap:14px;
  margin-bottom:16px;
}
.crm-simple-hero,
.an-simple-hero{
  display:flex;
  justify-content:space-between;
  align-items:stretch;
  gap:16px;
  border:1px solid #e2e8f0;
  border-radius:14px;
  background:#fff;
  padding:18px 20px;
  box-shadow:0 2px 10px rgba(15,23,42,.04);
}
.crm-simple-hero p,
.an-simple-hero p,
.crm-simple-card-head p,
.an-simple-card-head p{
  margin:0 0 4px;
  color:#64748b;
  font-size:10px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.crm-simple-hero h2,
.an-simple-hero h2{
  margin:0;
  color:#0f172a;
  font-size:20px;
  font-weight:950;
  letter-spacing:0;
}
.crm-simple-hero span,
.an-simple-hero span{
  display:block;
  margin-top:6px;
  color:#475569;
  font-size:12px;
  font-weight:700;
  line-height:1.6;
}
.crm-simple-hero-metric,
.an-simple-hero-metric{
  min-width:150px;
  border-radius:12px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
  padding:12px 14px;
  text-align:right;
}
.crm-simple-hero-metric strong,
.an-simple-hero-metric strong{
  display:block;
  color:#0f172a;
  font-size:32px;
  font-weight:950;
  line-height:1;
}
.crm-simple-hero-metric span,
.an-simple-hero-metric span{
  margin-top:4px;
  color:#475569;
  font-size:11px;
  font-weight:900;
}
.crm-simple-hero-metric small,
.an-simple-hero-metric small{
  display:block;
  margin-top:3px;
  color:#64748b;
  font-size:10px;
  font-weight:800;
}
.crm-simple-stats,
.an-simple-stats{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
}
.crm-simple-stat,
.an-simple-stat{
  display:block;
  width:100%;
  border:1px solid #e2e8f0;
  border-radius:12px;
  background:#fff;
  padding:12px 14px;
  text-align:left;
  cursor:pointer;
}
.crm-simple-stat:hover,
.an-simple-stat:hover{
  border-color:#93c5fd;
  background:#f8fafc;
}
.crm-simple-stat span,
.an-simple-stat span{
  display:block;
  color:#64748b;
  font-size:10px;
  font-weight:900;
}
.crm-simple-stat strong,
.an-simple-stat strong{
  display:block;
  margin-top:5px;
  color:#0f172a;
  font-size:24px;
  font-weight:950;
  line-height:1;
}
.crm-simple-stat small,
.an-simple-stat small{
  display:block;
  margin-top:5px;
  color:#94a3b8;
  font-size:10px;
  font-weight:800;
}
.crm-simple-stat-danger strong,
.an-simple-stat-danger strong{color:#dc2626}
.crm-simple-stat-warn strong,
.an-simple-stat-warn strong{color:#d97706}
.crm-simple-stat-good strong,
.an-simple-stat-good strong{color:#16a34a}
.crm-simple-stat-blue strong,
.an-simple-stat-blue strong{color:#2563eb}
.crm-inbox-shell{
  gap:12px;
}
#view-crm #crmKpiStrip{
  display:none !important;
}
.crm-inbox-hero{
  border-color:#dbeafe;
  background:linear-gradient(180deg,#fff,#f8fbff);
}
.crm-inbox-source-panel{
  border:1px solid #e2e8f0;
  border-radius:14px;
  background:#fff;
  padding:14px;
  box-shadow:0 2px 10px rgba(15,23,42,.035);
}
.crm-inbox-source-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.crm-inbox-source-head p{
  margin:0 0 4px;
  color:#64748b;
  font-size:10px;
  font-weight:950;
  letter-spacing:.08em;
}
.crm-inbox-source-head h3{
  margin:0;
  color:#0f172a;
  font-size:15px;
  font-weight:950;
}
.crm-inbox-source-head > div:last-child{
  display:flex;
  gap:7px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.crm-inbox-source-head button{
  border:1px solid #dbeafe;
  border-radius:9px;
  background:#eff6ff;
  color:#1d4ed8;
  cursor:pointer;
  font-size:11px;
  font-weight:950;
  padding:7px 10px;
  white-space:nowrap;
}
.crm-inbox-source-note{
  align-self:center;
  border:1px solid #dcfce7;
  border-radius:999px;
  background:#f0fdf4;
  color:#15803d;
  font-size:11px;
  font-weight:950;
  padding:6px 10px;
  white-space:nowrap;
}
.crm-inbox-source-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:9px;
}
.crm-inbox-source{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:2px 10px;
  width:100%;
  border:1px solid #e2e8f0;
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  padding:12px;
  text-align:left;
}
.crm-inbox-source:hover{
  border-color:#bfdbfe;
  background:#f8fafc;
}
.crm-inbox-source span{
  color:#64748b;
  font-size:10px;
  font-weight:950;
}
.crm-inbox-source strong{
  grid-row:1 / 3;
  grid-column:2;
  color:#0f172a;
  font-size:25px;
  font-weight:950;
  line-height:1;
}
.crm-inbox-source small{
  color:#475569;
  font-size:11px;
  font-weight:850;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.crm-inbox-source em{
  grid-column:1 / -1;
  justify-self:start;
  margin-top:7px;
  border-radius:999px;
  background:#f1f5f9;
  color:#475569;
  font-size:10px;
  font-style:normal;
  font-weight:950;
  padding:5px 8px;
}
.crm-inbox-source-warn strong{color:#d97706}
.crm-inbox-source-blue strong{color:#2563eb}
.crm-inbox-source-good strong{color:#16a34a}
.crm-inbox-action-copy{
  margin-top:12px;
  border:1px solid #e2e8f0;
  border-radius:10px;
  background:#f8fafc;
  color:#334155;
  font-size:12px;
  font-weight:850;
  line-height:1.6;
  padding:10px 11px;
}
.crm-pipeline-board{
  border:1px solid #e2e8f0;
  border-radius:14px;
  background:#fff;
  padding:14px;
  box-shadow:0 2px 10px rgba(15,23,42,.035);
}
.crm-pipeline-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.crm-pipeline-head p{
  margin:0 0 4px;
  color:#64748b;
  font-size:10px;
  font-weight:950;
  letter-spacing:.08em;
}
.crm-pipeline-head h3{
  margin:0;
  color:#0f172a;
  font-size:15px;
  font-weight:950;
}
.crm-pipeline-head button{
  border:1px solid #dbeafe;
  border-radius:9px;
  background:#eff6ff;
  color:#1d4ed8;
  cursor:pointer;
  font-size:11px;
  font-weight:900;
  padding:7px 10px;
  white-space:nowrap;
}
.crm-pipeline-steps{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:8px;
}
.crm-pipeline-step{
  position:relative;
  min-width:0;
  border:1px solid #e2e8f0;
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  padding:11px 10px 11px 14px;
  text-align:left;
}
.crm-pipeline-step::before{
  content:'';
  position:absolute;
  left:0;
  top:10px;
  bottom:10px;
  width:4px;
  border-radius:999px;
  background:#cbd5e1;
}
.crm-pipeline-step:hover,
.crm-pipeline-step.is-active{
  border-color:#93c5fd;
  background:#f8fafc;
}
.crm-pipeline-step span,
.crm-pipeline-step strong,
.crm-pipeline-step small{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.crm-pipeline-step span{
  color:#475569;
  font-size:10px;
  font-weight:950;
}
.crm-pipeline-step strong{
  margin-top:4px;
  color:#0f172a;
  font-size:22px;
  font-weight:950;
  line-height:1;
}
.crm-pipeline-step small{
  margin-top:5px;
  color:#64748b;
  font-size:10px;
  font-weight:850;
}
.crm-pipeline-step-warn::before{background:#d97706}
.crm-pipeline-step-blue::before{background:#2563eb}
.crm-pipeline-step-good::before{background:#16a34a}
.crm-pipeline-step-muted::before{background:#64748b}
.crm-pipeline-step-empty strong{color:#94a3b8}
.crm-inbox-manager-card{
  border-style:dashed;
  background:#f8fafc;
}
.crm-manager-next-list{
  display:grid;
  gap:8px;
  margin-top:12px;
}
.crm-manager-next-empty{
  border:1px dashed #cbd5e1;
  border-radius:10px;
  background:#fff;
  color:#64748b;
  font-size:11px;
  font-weight:850;
  padding:10px;
  text-align:center;
}
.crm-inbox-manager-copy{
  margin:11px 0 0;
  color:#64748b;
  font-size:11px;
  font-weight:800;
  line-height:1.6;
}
.cd-secondary-actions,
.cd-metrics-details{
  border-bottom:1px solid #e2e8f0;
  background:#fff;
}
.cd-secondary-actions summary,
.cd-metrics-details summary{
  cursor:pointer;
  list-style:none;
  padding:9px 24px;
  color:#64748b;
  font-size:11px;
  font-weight:950;
  letter-spacing:0;
}
.cd-secondary-actions summary::-webkit-details-marker,
.cd-metrics-details summary::-webkit-details-marker{
  display:none;
}
.cd-secondary-actions summary::after,
.cd-metrics-details summary::after{
  content:'開く';
  float:right;
  color:#94a3b8;
  font-size:10px;
  font-weight:900;
}
.cd-secondary-actions[open] summary::after,
.cd-metrics-details[open] summary::after{
  content:'閉じる';
}
.cd-secondary-action-list{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  padding:0 24px 12px;
}
.cd-secondary-action-list button{
  min-height:32px;
  border:1px dashed #c7d2fe;
  border-radius:8px;
  background:#fff;
  color:#4f46e5;
  cursor:pointer;
  font-size:11px;
  font-weight:900;
  padding:6px 12px;
}
.cd-secondary-action-list .cd-secondary-action-danger{
  border-style:solid;
  border-color:#fecaca;
  color:#dc2626;
}
.cd-metrics-details{
  background:#f8fafc;
}
.cd-metrics-details[open] summary{
  border-bottom:1px solid #e2e8f0;
}
.cd-command-panel{
  position:sticky;
  top:0;
  z-index:5;
  padding:14px 18px;
  background:linear-gradient(180deg,#fff,#f8fafc);
  border-bottom:1px solid #e2e8f0;
  min-width:0;
  max-width:100%;
  box-sizing:border-box;
}
.cd-command-grid{
  display:grid;
  grid-template-columns:minmax(180px,1.2fr) repeat(5,minmax(90px,1fr));
  gap:12px;
  align-items:center;
  min-width:0;
  max-width:100%;
}
.cd-command-signal,
.cd-command-signal-row{
  min-width:0;
}
.cd-command-signal-row{
  display:flex;
  align-items:center;
  gap:8px;
  margin-top:10px;
}
.cd-command-signal-row span:last-child{
  color:#475569;
  font-size:12px;
  font-weight:800;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.cd-lost-note{
  margin-top:10px;
  border:1px solid #fed7aa;
  border-radius:8px;
  background:#fff7ed;
  color:#9a3412;
  font-size:12px;
  font-weight:800;
  padding:9px 11px;
}
.cd-lost-note span{
  font-weight:600;
}
.cd-next-best{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
  align-items:center;
  border:1px solid #dbeafe;
  border-left:4px solid #2563eb;
  border-radius:12px;
  background:#fff;
  padding:11px 12px;
  min-width:0;
  max-width:100%;
  box-sizing:border-box;
}
.cd-next-best > div{
  min-width:0;
}
.cd-next-best-warn{border-left-color:#d97706;background:#fffaf0}
.cd-next-best-danger{border-left-color:#dc2626;background:#fff7f7}
.cd-next-best-blue{border-left-color:#2563eb;background:#f8fbff}
.cd-next-best-good{border-left-color:#16a34a;background:#f8fffb}
.cd-next-best span,
.cd-next-best strong,
.cd-next-best small{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.cd-next-best span{
  color:#64748b;
  font-size:10px;
  font-weight:950;
  letter-spacing:.08em;
}
.cd-next-best strong{
  margin-top:2px;
  color:#0f172a;
  font-size:14px;
  font-weight:950;
}
.cd-next-best small{
  margin-top:3px;
  color:#475569;
  font-size:11px;
  font-weight:850;
  white-space:normal;
}
.cd-next-best button{
  height:34px;
  border:1px solid #bfdbfe;
  border-radius:10px;
  background:#eff6ff;
  color:#1d4ed8;
  cursor:pointer;
  font-size:11px;
  font-weight:950;
  padding:0 12px;
  white-space:nowrap;
  max-width:100%;
  box-sizing:border-box;
}
.crm-today-kpi{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
  margin-top:12px;
}
.crm-today-kpi span{
  border:1px solid #e2e8f0;
  border-radius:11px;
  background:#fff;
  padding:10px;
}
.crm-today-kpi b,
.crm-today-kpi small{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.crm-today-kpi b{
  color:#0f172a;
  font-size:22px;
  font-weight:950;
  line-height:1;
}
.crm-today-kpi small{
  margin-top:5px;
  color:#64748b;
  font-size:10px;
  font-weight:900;
}
.cd-primary-actions{
  display:grid;
  grid-template-columns:repeat(7,minmax(0,1fr));
  gap:8px;
  margin-top:12px;
}
.cd-primary-action{
  border:1px solid #dbeafe;
  border-radius:12px;
  background:#fff;
  color:#1e3a8a;
  cursor:pointer;
  padding:11px 12px;
  text-align:left;
  transition:background .14s ease,border-color .14s ease,transform .14s ease;
}
.cd-primary-action:hover{
  border-color:#93c5fd;
  background:#eff6ff;
  transform:translateY(-1px);
}
.cd-primary-action:disabled{
  cursor:not-allowed;
  opacity:.46;
  transform:none;
}
.cd-primary-action-main{
  border-color:#bfdbfe;
  background:#eff6ff;
}
.cd-primary-action-done{
  border-color:#86efac;
  background:#f0fdf4;
  color:#166534;
}
.cd-primary-action-done strong{
  color:#166534;
}
.cd-primary-action-advance{
  border-color:#bbf7d0;
  background:#f0fdf4;
  color:#166534;
}
.cd-mobile-action-bar{
  display:none;
}
.crm-inbox-action-button{
  width:100%;
  text-align:left;
  border:1px solid #dbeafe;
  border-radius:10px;
  background:#eff6ff;
  color:#1d4ed8;
  cursor:pointer;
  font:inherit;
}
.crm-inbox-action-button:hover{
  border-color:#93c5fd;
  background:#dbeafe;
}
.cd-primary-action strong,
.cd-primary-action span{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.cd-primary-action strong{
  color:#0f172a;
  font-size:13px;
  font-weight:950;
}
.cd-primary-action span{
  margin-top:4px;
  color:#64748b;
  font-size:10px;
  font-weight:850;
}
.crm-simple-grid,
.an-simple-grid{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);
  gap:14px;
}
.dash-role-home{
  margin-bottom:20px;
  border:1px solid #dbeafe;
  border-radius:18px;
  background:linear-gradient(135deg,#f8fbff,#ffffff 58%,#f0fdf4);
  box-shadow:0 16px 42px rgba(15,23,42,.07);
  padding:18px;
}
.dash-role-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:14px;
}
.dash-role-head p,
.dash-role-card-title{
  margin:0 0 5px;
  color:#2563eb;
  font-size:11px;
  font-weight:950;
  letter-spacing:.08em;
}
.dash-role-head h2{
  margin:0;
  color:#0f172a;
  font-size:20px;
  font-weight:950;
  letter-spacing:0;
}
.dash-role-head span{
  display:block;
  margin-top:5px;
  color:#64748b;
  font-size:12px;
  font-weight:800;
  line-height:1.55;
}
.dash-role-head button{
  flex-shrink:0;
  border:0;
  border-radius:12px;
  background:#0f172a;
  color:#fff;
  cursor:pointer;
  font-size:12px;
  font-weight:950;
  padding:10px 14px;
  box-shadow:0 10px 22px rgba(15,23,42,.16);
}
.dash-role-grid{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr);
  gap:12px;
}
.dash-role-grid-single{
  grid-template-columns:1fr;
}
.dash-role-card{
  min-width:0;
  border:1px solid #e2e8f0;
  border-radius:14px;
  background:rgba(255,255,255,.88);
  padding:13px;
}
.dash-role-stats{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
  margin-bottom:12px;
}
.dash-role-stats span{
  border:1px solid #e2e8f0;
  border-radius:12px;
  background:#fff;
  padding:10px;
}
.dash-role-stats b,
.dash-role-stats small{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.dash-role-stats b{
  color:#0f172a;
  font-size:24px;
  font-weight:950;
  line-height:1;
}
.dash-role-stats small{
  margin-top:5px;
  color:#64748b;
  font-size:10px;
  font-weight:900;
}
.dash-role-task-list,
.dash-role-owner-list{
  display:grid;
  gap:8px;
}
.dash-role-task{
  display:grid;
  grid-template-columns:32px minmax(0,1fr) auto;
  align-items:center;
  gap:10px;
  width:100%;
  border:1px solid #e2e8f0;
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  padding:10px;
  text-align:left;
}
.dash-role-rank{
  width:32px;
  height:32px;
  border-radius:10px;
  background:#eff6ff;
  color:#1d4ed8;
  display:grid;
  place-items:center;
  font-size:12px;
  font-weight:950;
}
.dash-role-main{
  min-width:0;
}
.dash-role-main strong,
.dash-role-main small{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.dash-role-main strong{
  color:#0f172a;
  font-size:13px;
  font-weight:950;
}
.dash-role-main small{
  margin-top:2px;
  color:#64748b;
  font-size:11px;
  font-weight:800;
}
.dash-role-cta{
  color:#1d4ed8;
  font-size:11px;
  font-weight:950;
}
.dash-role-owner{
  display:grid;
  grid-template-columns:minmax(0,1fr) 58px 58px minmax(86px,.7fr);
  align-items:center;
  gap:8px;
  width:100%;
  border:1px solid #e2e8f0;
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  padding:10px;
  text-align:left;
}
.dash-role-owner strong,
.dash-role-owner em{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.dash-role-owner strong{
  color:#0f172a;
  font-size:12px;
  font-weight:950;
}
.dash-role-owner span b,
.dash-role-owner span small{
  display:block;
  text-align:center;
}
.dash-role-owner span b{
  color:#0f172a;
  font-size:16px;
  font-weight:950;
}
.dash-role-owner span small{
  color:#64748b;
  font-size:9px;
  font-weight:900;
}
.dash-role-owner em{
  color:#2563eb;
  font-size:11px;
  font-style:normal;
  font-weight:950;
}
.dash-role-empty{
  padding:18px;
  border:1px dashed #cbd5e1;
  border-radius:12px;
  color:#64748b;
  font-size:12px;
  font-weight:800;
  text-align:center;
}
.crm-simple-card,
.an-simple-card{
  min-width:0;
  border:1px solid #e2e8f0;
  border-radius:14px;
  background:#fff;
  padding:16px;
  box-shadow:0 2px 10px rgba(15,23,42,.04);
}
.crm-simple-card-wide,
.an-simple-card-wide{
  grid-column:1 / -1;
}
.crm-simple-card-head,
.an-simple-card-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.crm-simple-card-head h3,
.an-simple-card-head h3{
  margin:0;
  color:#0f172a;
  font-size:15px;
  font-weight:950;
  letter-spacing:0;
}
.crm-simple-card-head button,
.an-simple-card-head button{
  border:1px solid #dbeafe;
  border-radius:9px;
  background:#eff6ff;
  color:#1d4ed8;
  cursor:pointer;
  font-size:11px;
  font-weight:900;
  padding:7px 10px;
  white-space:nowrap;
}
.crm-simple-task-list{
  display:grid;
  gap:8px;
}
.crm-simple-task{
  display:grid;
  grid-template-columns:10px minmax(0,1fr) auto;
  align-items:center;
  gap:10px;
  width:100%;
  border:1px solid #e2e8f0;
  border-radius:10px;
  background:#fff;
  cursor:pointer;
  padding:11px 12px;
  text-align:left;
}
.crm-simple-task:hover{
  border-color:#93c5fd;
  background:#f8fafc;
}
.crm-simple-task-dot{
  width:8px;
  height:8px;
  border-radius:999px;
  background:#94a3b8;
}
.crm-simple-task-danger .crm-simple-task-dot{background:#dc2626}
.crm-simple-task-warn .crm-simple-task-dot{background:#d97706}
.crm-simple-task-good .crm-simple-task-dot{background:#16a34a}
.crm-simple-task-main{
  min-width:0;
}
.crm-simple-task-main strong{
  display:block;
  color:#0f172a;
  font-size:13px;
  font-weight:950;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.crm-simple-task-main small{
  display:block;
  margin-top:2px;
  color:#64748b;
  font-size:10px;
  font-weight:800;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.crm-simple-task-cta{
  color:#1d4ed8;
  font-size:11px;
  font-weight:950;
}
.crm-simple-empty{
  border:1px dashed #cbd5e1;
  border-radius:10px;
  background:#f8fafc;
  padding:18px;
  text-align:center;
}
.crm-simple-empty strong{
  display:block;
  color:#0f172a;
  font-size:13px;
  font-weight:950;
}
.crm-simple-empty span{
  display:block;
  margin-top:4px;
  color:#64748b;
  font-size:11px;
  font-weight:700;
}
.crm-simple-progress-row,
.an-simple-progress-row{
  display:flex;
  justify-content:space-between;
  gap:10px;
  margin-top:12px;
  color:#0f172a;
  font-size:12px;
  font-weight:900;
}
.crm-simple-progress,
.an-simple-progress{
  height:8px;
  margin-top:7px;
  border-radius:999px;
  overflow:hidden;
  background:#e2e8f0;
}
.crm-simple-progress i,
.an-simple-progress i{
  display:block;
  height:100%;
  max-width:100%;
  border-radius:999px;
  background:#16a34a;
}
.crm-simple-progress-blue i,
.an-simple-progress-blue i{background:#2563eb}
.crm-simple-mini,
.an-simple-mini{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:14px;
}
.crm-simple-mini span,
.an-simple-mini span{
  border-radius:999px;
  background:#f1f5f9;
  color:#475569;
  font-size:10px;
  font-weight:900;
  padding:6px 9px;
}
.crm-simple-owner-head,
.crm-simple-owner-row{
  display:grid;
  grid-template-columns:minmax(130px,1.5fr) repeat(4,72px) 86px minmax(100px,1fr);
  gap:8px;
  align-items:center;
}
.crm-simple-owner-head{
  border-radius:9px;
  background:#f8fafc;
  color:#64748b;
  font-size:10px;
  font-weight:950;
  padding:8px 10px;
}
.crm-simple-owner-head span:not(:first-child){
  text-align:right;
}
.crm-simple-owner-row{
  width:100%;
  border:0;
  border-bottom:1px solid #f1f5f9;
  background:#fff;
  cursor:pointer;
  padding:10px;
  text-align:left;
}
.crm-simple-owner-row:hover{
  background:#f8fafc;
}
.crm-simple-owner-name{
  color:#0f172a;
  font-size:12px;
  font-weight:950;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.crm-simple-owner-row span:not(.crm-simple-owner-name):not(.crm-simple-health):not(.crm-simple-owner-advice){
  text-align:right;
}
.crm-simple-owner-row b{
  display:block;
  color:#0f172a;
  font-size:13px;
  font-weight:950;
}
.crm-simple-owner-row small{
  display:block;
  color:#94a3b8;
  font-size:9px;
  font-weight:800;
}
.crm-simple-owner-row .is-danger b{
  color:#dc2626;
}
.crm-simple-health{
  position:relative;
  display:block;
  height:18px;
  border-radius:999px;
  overflow:hidden;
  background:#e2e8f0;
}
.crm-simple-health i{
  display:block;
  height:100%;
  border-radius:999px;
}
.crm-simple-health-good i{background:#16a34a}
.crm-simple-health-warn i{background:#d97706}
.crm-simple-health-danger i{background:#dc2626}
.crm-simple-health em{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#0f172a;
  font-size:10px;
  font-style:normal;
  font-weight:950;
}
.crm-simple-owner-advice{
  color:#475569;
  font-size:11px;
  font-weight:900;
  text-align:right;
}
.an-simple-owner-table{
  display:grid;
  gap:7px;
}
.an-simple-owner-row{
  display:grid;
  grid-template-columns:minmax(120px,1.4fr) repeat(4,70px) minmax(120px,1fr);
  gap:8px;
  align-items:center;
  border:1px solid #e2e8f0;
  border-radius:10px;
  background:#fff;
  padding:9px 10px;
  color:#0f172a;
  font-size:12px;
  font-weight:900;
}
.an-simple-owner-row span:not(:first-child){
  text-align:right;
}
.an-simple-owner-row small{
  display:block;
  color:#94a3b8;
  font-size:9px;
  font-weight:800;
}
.an-simple-owner-row .is-danger{
  color:#dc2626;
}
.crm-essential-filters,
#crmEssentialFilters{
  margin:0 0 12px;
}
.crm-essential-row{
  display:grid;
  grid-template-columns:minmax(180px,1.2fr) minmax(130px,.7fr) minmax(130px,.7fr) minmax(260px,1.2fr) auto;
  gap:8px;
  align-items:center;
  border:1px solid #e2e8f0;
  border-radius:14px;
  background:#fff;
  padding:10px;
  box-shadow:0 2px 10px rgba(15,23,42,.035);
}
.crm-essential-search,
.crm-essential-select{
  width:100%;
  min-width:0;
  height:38px;
  border:1px solid #dbe3ee;
  border-radius:10px;
  background:#f8fafc;
  color:#0f172a;
  font-size:12px;
  font-weight:800;
  padding:0 11px;
}
.crm-essential-chips{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  min-width:0;
}
.crm-essential-chip,
.crm-essential-clear{
  height:34px;
  border-radius:999px;
  cursor:pointer;
  font-size:11px;
  font-weight:900;
  white-space:nowrap;
}
.crm-essential-chip{
  border:1px solid #dbe3ee;
  background:#fff;
  color:#475569;
  padding:0 10px;
}
.crm-essential-chip.is-active{
  border-color:#0f172a;
  background:#0f172a;
  color:#fff;
}
.crm-essential-clear{
  border:1px solid #e2e8f0;
  background:#f8fafc;
  color:#64748b;
  padding:0 12px;
}
.crm-essential-note{
  margin-top:6px;
  color:#94a3b8;
  font-size:10px;
  font-weight:800;
}
.crm-sales-board{
  margin:0 0 14px;
  border:1px solid #e2e8f0;
  border-radius:16px;
  background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);
  box-shadow:0 10px 28px rgba(15,23,42,.05);
  padding:14px;
}
.crm-sales-board-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.crm-sales-board-head p{
  margin:0 0 3px;
  color:#2563eb;
  font-size:10px;
  font-weight:950;
  letter-spacing:.08em;
}
.crm-sales-board-head h3{
  margin:0;
  color:#0f172a;
  font-size:16px;
  font-weight:950;
  letter-spacing:0;
}
.crm-sales-board-head > span,
.crm-sales-head-actions > span{
  color:#64748b;
  font-size:11px;
  font-weight:900;
  white-space:nowrap;
}
.crm-sales-head-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}
.crm-sales-head-actions button{
  border:1px solid #dbeafe;
  border-radius:999px;
  background:#f8fbff;
  color:#1d4ed8;
  font-size:11px;
  font-weight:950;
  padding:7px 10px;
  cursor:pointer;
  transition:background .16s ease,border-color .16s ease,transform .16s ease;
}
.crm-sales-head-actions button:hover{
  background:#eff6ff;
  border-color:#bfdbfe;
  transform:translateY(-1px);
}
.crm-legacy-table-card{
  display:none;
}
.crm-legacy-table-card.is-open{
  display:block;
}
.crm-sales-card-list{
  display:grid;
  gap:9px;
}
.crm-sales-card{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px 12px;
  align-items:center;
  border:1px solid #e2e8f0;
  border-left-width:4px;
  border-radius:14px;
  background:#fff;
  padding:12px;
  color:#0f172a;
  box-shadow:0 2px 10px rgba(15,23,42,.035);
}
.crm-sales-card-danger{border-left-color:#dc2626}
.crm-sales-card-warn{border-left-color:#d97706}
.crm-sales-card-blue{border-left-color:#2563eb}
.crm-sales-card-good{border-left-color:#16a34a}
.crm-sales-main{
  display:grid;
  grid-template-columns:14px minmax(160px,1.25fr) minmax(130px,.8fr) minmax(180px,1fr) minmax(190px,1fr);
  gap:10px;
  align-items:center;
  min-width:0;
  cursor:pointer;
}
.crm-sales-dot{
  width:9px;
  height:9px;
  border-radius:999px;
  background:#16a34a;
  box-shadow:0 0 0 4px #dcfce7;
}
.crm-sales-card-danger .crm-sales-dot{background:#dc2626;box-shadow:0 0 0 4px #fee2e2}
.crm-sales-card-warn .crm-sales-dot{background:#d97706;box-shadow:0 0 0 4px #ffedd5}
.crm-sales-card-blue .crm-sales-dot{background:#2563eb;box-shadow:0 0 0 4px #dbeafe}
.crm-sales-name,
.crm-sales-signal,
.crm-sales-next,
.crm-sales-meta{
  min-width:0;
}
.crm-sales-name strong,
.crm-sales-signal span,
.crm-sales-next span{
  display:block;
  overflow:hidden;
  color:#0f172a;
  font-size:13px;
  font-weight:950;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.crm-sales-name small,
.crm-sales-signal small,
.crm-sales-next small{
  display:block;
  overflow:hidden;
  margin-top:3px;
  color:#64748b;
  font-size:10px;
  font-weight:850;
  line-height:1.3;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.crm-sales-next-danger span{color:#dc2626}
.crm-sales-next-warn span{color:#d97706}
.crm-sales-next-good span{color:#16a34a}
.crm-sales-meta{
  display:flex;
  justify-content:flex-end;
  gap:6px;
  flex-wrap:wrap;
}
.crm-sales-meta span{
  display:inline-flex;
  align-items:center;
  height:24px;
  border-radius:999px;
  background:#f8fafc;
  color:#475569;
  font-size:10px;
  font-weight:900;
  padding:0 8px;
  white-space:nowrap;
}
.crm-sales-actions{
  display:flex;
  gap:7px;
  justify-content:flex-end;
}
.crm-sales-actions button{
  height:34px;
  border-radius:10px;
  border:1px solid #dbeafe;
  background:#eff6ff;
  color:#1d4ed8;
  cursor:pointer;
  font-size:11px;
  font-weight:950;
  padding:0 11px;
  white-space:nowrap;
}
.crm-sales-actions button:first-child{
  border-color:#0f172a;
  background:#0f172a;
  color:#fff;
}
.crm-sales-actions .crm-sales-done-btn{
  border-color:#86efac;
  background:#f0fdf4;
  color:#166534;
}
.crm-sales-actions button:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 18px rgba(37,99,235,.12);
}
.crm-sales-reco{
  grid-column:1 / -1;
  margin:0;
  border-top:1px solid #f1f5f9;
  padding-top:8px;
  color:#334155;
  font-size:11px;
  font-weight:850;
  line-height:1.45;
}
.crm-intervention-grid,
.an-intervention-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
  margin-bottom:12px;
}
.crm-intervention-card,
.an-intervention-card{
  display:block;
  min-width:0;
  border:1px solid #fed7aa;
  border-radius:12px;
  background:#fff7ed;
  color:#7c2d12;
  padding:11px 12px;
  text-align:left;
}
.crm-intervention-card{
  cursor:pointer;
}
.crm-intervention-card:hover{
  border-color:#fb923c;
  background:#ffedd5;
}
.crm-intervention-card strong,
.an-intervention-card strong{
  display:block;
  color:#0f172a;
  font-size:13px;
  font-weight:950;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.an-intervention-card span{
  display:inline-flex;
  margin-bottom:5px;
  border-radius:999px;
  background:#fff;
  color:#c2410c;
  font-size:9px;
  font-weight:950;
  padding:3px 7px;
}
.crm-intervention-card span,
.an-intervention-card p{
  display:block;
  margin:4px 0 0;
  color:#9a3412;
  font-size:10px;
  font-weight:900;
  line-height:1.5;
}
.crm-intervention-card em,
.an-intervention-card em{
  display:block;
  margin-top:5px;
  color:#475569;
  font-size:10px;
  font-style:normal;
  font-weight:900;
}
#view-analytics #anKpiHero,
#view-analytics #anManagerHero{
  display:none !important;
}

.an-manager-shell{
  gap:14px;
}
.an-manager-hero-simple{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  border:1px solid #dbe3ee;
  border-radius:14px;
  background:#fff;
  padding:18px 20px;
  box-shadow:0 2px 10px rgba(15,23,42,.035);
}
.an-manager-hero-simple p,
.an-manager-kpi span,
.an-manager-bottleneck span{
  margin:0 0 6px;
  color:#64748b;
  font-size:10px;
  font-weight:950;
  letter-spacing:.08em;
}
.an-manager-hero-simple h2{
  margin:0;
  color:#0f172a;
  font-size:20px;
  font-weight:950;
  letter-spacing:0;
}
.an-manager-hero-simple span{
  display:block;
  margin-top:6px;
  color:#64748b;
  font-size:12px;
  font-weight:800;
  line-height:1.65;
}
.an-manager-hero-score{
  min-width:118px;
  border:1px solid #dbeafe;
  border-radius:14px;
  background:#eff6ff;
  padding:13px 16px;
  text-align:center;
}
.an-manager-hero-score strong{
  display:block;
  color:#0f172a;
  font-size:30px;
  font-weight:950;
  line-height:1;
}
.an-manager-hero-score span,
.an-manager-hero-score small{
  display:block;
  margin-top:5px;
  color:#475569;
  font-size:10px;
  font-weight:950;
}
.an-manager-kpi-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.an-manager-kpi{
  border:1px solid #e2e8f0;
  border-radius:13px;
  background:#fff;
  padding:13px 14px;
  box-shadow:0 2px 10px rgba(15,23,42,.03);
}
.an-manager-kpi strong{
  display:block;
  color:#0f172a;
  font-size:25px;
  font-weight:950;
  line-height:1.1;
}
.an-manager-kpi small{
  display:block;
  margin-top:5px;
  color:#64748b;
  font-size:11px;
  font-weight:850;
}
.an-manager-kpi-danger strong{color:#dc2626}
.an-manager-kpi-warn strong{color:#d97706}
.an-manager-kpi-good strong{color:#16a34a}
.an-manager-kpi-blue strong{color:#2563eb}
.an-manager-layout{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(320px,.85fr);
  gap:14px;
}
.an-manager-supporting{
  border:1px solid #e2e8f0;
  border-radius:14px;
  background:#fff;
  padding:12px;
  box-shadow:0 2px 10px rgba(15,23,42,.03);
}
.an-manager-supporting summary{
  cursor:pointer;
  list-style:none;
  color:#475569;
  font-size:12px;
  font-weight:950;
  padding:2px 2px 12px;
}
.an-manager-supporting summary::-webkit-details-marker{
  display:none;
}
.an-manager-supporting summary::after{
  content:'閉じる';
  float:right;
  color:#94a3b8;
  font-size:10px;
  font-weight:900;
}
.an-manager-supporting:not([open]) summary{
  padding-bottom:2px;
}
.an-manager-supporting:not([open]) summary::after{
  content:'開く';
}
.an-manager-supporting .an-manager-kpi-grid{
  margin-bottom:12px;
}
.an-manager-supporting .an-simple-card{
  border-color:#edf2f7;
  box-shadow:none;
}
.an-manager-action-list{
  display:grid;
  gap:9px;
}

.pm-usage-card{
  margin-bottom:16px;
  border:1px solid #dbeafe;
  border-radius:14px;
  background:linear-gradient(135deg,#f8fbff,#eef8ff);
  padding:14px;
}
.pm-usage-intro{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.pm-usage-eyebrow{
  font-size:11px;
  font-weight:950;
  color:#2563eb;
  letter-spacing:.06em;
}
.pm-usage-title{
  margin-top:2px;
  font-size:15px;
  font-weight:950;
  color:#0f172a;
}
.pm-usage-hint{
  margin-top:4px;
  font-size:11px;
  line-height:1.7;
  color:#475569;
}
.pm-usage-select-fallback{
  width:210px;
  min-width:190px;
  font-weight:800;
}
.pm-usage-choice-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
  margin-top:12px;
}
.pm-usage-choice{
  min-height:74px;
  border:1px solid #dbeafe;
  border-radius:12px;
  background:#fff;
  color:#334155;
  padding:10px;
  text-align:left;
  cursor:pointer;
  transition:background .16s ease,border-color .16s ease,box-shadow .16s ease,transform .16s ease;
}
.pm-usage-choice:hover{
  transform:translateY(-1px);
  border-color:#bfdbfe;
  box-shadow:0 8px 18px rgba(37,99,235,.08);
}
.pm-usage-choice strong,
.pm-usage-choice span{
  display:block;
}
.pm-usage-choice strong{
  color:#0f172a;
  font-size:13px;
  font-weight:950;
}
.pm-usage-choice span{
  margin-top:5px;
  color:#64748b;
  font-size:10.5px;
  font-weight:800;
  line-height:1.5;
}
.pm-usage-choice.is-active{
  border-color:#2563eb;
  background:#eff6ff;
  box-shadow:0 0 0 3px rgba(37,99,235,.1);
}
.pm-usage-choice.is-active strong{
  color:#1d4ed8;
}
.an-manager-action{
  display:grid;
  grid-template-columns:100px minmax(0,1fr);
  gap:4px 12px;
  align-items:center;
  width:100%;
  border:1px solid #e2e8f0;
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  padding:12px 13px;
  text-align:left;
}
.an-manager-action:hover,
.an-manager-health-row:hover,
.an-manager-bottleneck:hover{
  border-color:#bfdbfe;
  background:#f8fafc;
}
.an-manager-action > span{
  grid-row:1 / 4;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  border-radius:999px;
  background:#f1f5f9;
  color:#475569;
  font-size:10px;
  font-weight:950;
  white-space:nowrap;
}
.an-manager-action strong{
  color:#0f172a;
  font-size:14px;
  font-weight:950;
}
.an-manager-action p,
.an-manager-action small{
  margin:0;
  color:#475569;
  font-size:11px;
  font-weight:850;
  line-height:1.45;
}
.an-manager-action small{
  color:#64748b;
  font-size:10px;
}
.an-manager-action-danger > span{background:#fef2f2;color:#dc2626}
.an-manager-action-warn > span{background:#fff7ed;color:#d97706}
.an-manager-action-blue > span{background:#eff6ff;color:#2563eb}
.an-manager-action-good > span{background:#f0fdf4;color:#16a34a}
.an-manager-directive-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:2px;
  color:#64748b;
  font-size:10px;
  font-weight:900;
}
.an-manager-directive-head span{
  color:#0f172a;
  font-size:11px;
  font-weight:950;
}
.an-manager-directive-head small{
  color:#94a3b8;
  font-size:10px;
  font-weight:850;
}
.an-manager-saved-list{
  display:grid;
  gap:7px;
  margin:0 0 3px;
}
.an-manager-saved-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  align-items:center;
  border:1px solid #dbeafe;
  border-radius:12px;
  background:#eff6ff;
  padding:9px 10px;
}
.an-manager-saved-row strong,
.an-manager-saved-row small{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.an-manager-saved-row strong{
  color:#1e3a8a;
  font-size:12px;
  font-weight:950;
}
.an-manager-saved-row small{
  margin-top:2px;
  color:#1d4ed8;
  font-size:10px;
  font-weight:800;
}
.an-manager-saved-row button{
  height:30px;
  border:1px solid #bfdbfe;
  border-radius:9px;
  background:#fff;
  color:#1d4ed8;
  cursor:pointer;
  font-size:10px;
  font-weight:950;
  padding:0 10px;
}
.an-manager-directive{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  align-items:center;
  border:1px solid #e2e8f0;
  border-left:4px solid #2563eb;
  border-radius:13px;
  background:#fff;
  padding:10px;
}
.an-manager-directive-danger{border-left-color:#dc2626}
.an-manager-directive-warn,
.an-manager-directive-warning{border-left-color:#d97706}
.an-manager-directive-blue{border-left-color:#2563eb}
.an-manager-directive-good,
.an-manager-directive-success{border-left-color:#16a34a}
.an-manager-directive-main{
  display:grid;
  grid-template-columns:72px minmax(0,1fr);
  gap:4px 10px;
  align-items:start;
  min-width:0;
  border:0;
  background:transparent;
  cursor:pointer;
  padding:0;
  text-align:left;
}
.an-manager-directive-main span{
  grid-row:1 / 5;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:28px;
  border-radius:999px;
  background:#f1f5f9;
  color:#475569;
  font-size:9px;
  font-weight:950;
  white-space:nowrap;
}
.an-manager-directive-danger .an-manager-directive-main span{background:#fef2f2;color:#dc2626}
.an-manager-directive-warn .an-manager-directive-main span,
.an-manager-directive-warning .an-manager-directive-main span{background:#fff7ed;color:#d97706}
.an-manager-directive-blue .an-manager-directive-main span{background:#eff6ff;color:#2563eb}
.an-manager-directive-good .an-manager-directive-main span,
.an-manager-directive-success .an-manager-directive-main span{background:#f0fdf4;color:#16a34a}
.an-manager-directive-main strong,
.an-manager-directive-main p,
.an-manager-directive-main small{
  grid-column:2;
  margin:0;
  min-width:0;
}
.an-manager-directive-main strong{
  color:#0f172a;
  font-size:13px;
  font-weight:950;
}
.an-manager-directive-main p{
  color:#334155;
  font-size:11px;
  font-weight:850;
  line-height:1.45;
}
.an-manager-directive-main small{
  color:#64748b;
  font-size:10px;
  font-weight:800;
}
.an-manager-directive-reason{
  color:#0f172a !important;
  font-weight:900 !important;
}
.an-manager-oneonone{
  color:#475569 !important;
  font-weight:850 !important;
}
.an-manager-directive-save{
  height:34px;
  border:1px solid #dbeafe;
  border-radius:10px;
  background:#eff6ff;
  color:#1d4ed8;
  cursor:pointer;
  font-size:11px;
  font-weight:950;
  padding:0 11px;
  white-space:nowrap;
}
.an-manager-directive-save:hover,
.an-manager-saved-row button:hover{
  border-color:#93c5fd;
  background:#dbeafe;
}
.an-manager-bottleneck-grid{
  display:grid;
  gap:9px;
}
.an-manager-bottleneck{
  display:block;
  width:100%;
  border:1px solid #e2e8f0;
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  padding:12px 13px;
  text-align:left;
}
.an-manager-bottleneck strong{
  display:block;
  color:#0f172a;
  font-size:23px;
  font-weight:950;
  line-height:1.1;
}
.an-manager-bottleneck small{
  display:block;
  margin-top:5px;
  color:#64748b;
  font-size:10px;
  font-weight:850;
  line-height:1.45;
}
.an-manager-bottleneck-danger strong{color:#dc2626}
.an-manager-bottleneck-warn strong{color:#d97706}
.an-manager-bottleneck-blue strong{color:#2563eb}
.an-manager-bottleneck-good strong{color:#16a34a}
.an-manager-health-table{
  display:grid;
  gap:7px;
}
.an-manager-health-row{
  display:grid;
  grid-template-columns:minmax(170px,1.3fr) 112px repeat(4,72px);
  gap:8px;
  align-items:center;
  width:100%;
  border:1px solid #e2e8f0;
  border-radius:11px;
  background:#fff;
  cursor:pointer;
  padding:10px 11px;
  text-align:left;
}
.an-manager-health-name{
  color:#0f172a;
  font-size:13px;
  font-weight:950;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.an-manager-health-row small{
  display:block;
  margin-top:2px;
  color:#94a3b8;
  font-size:9px;
  font-weight:850;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.an-manager-health-row span:not(.an-manager-health-name):not(.an-manager-health-status){
  text-align:right;
}
.an-manager-health-row b{
  display:block;
  color:#0f172a;
  font-size:13px;
  font-weight:950;
}
.an-manager-health-row .is-danger b{
  color:#dc2626;
}
.an-manager-health-status{
  justify-self:start;
  border-radius:999px;
  padding:5px 9px;
  background:#f1f5f9;
  color:#475569;
  font-size:10px;
  font-weight:950;
  white-space:nowrap;
}
.an-manager-health-danger{background:#fef2f2;color:#dc2626}
.an-manager-health-warn{background:#fff7ed;color:#d97706}
.an-manager-health-blue{background:#eff6ff;color:#2563eb}
.an-manager-health-good{background:#f0fdf4;color:#16a34a}
.an-manager-health-watch{background:#f8fafc;color:#475569}

.kpi-command-hero{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:14px;
  border:1px solid #dbe3ee;
  border-radius:14px;
  background:#fff;
  padding:18px 20px;
  box-shadow:0 2px 10px rgba(15,23,42,.035);
}
.kpi-command-hero span,
.kpi-plan-card span,
.kpi-input-card span,
.kpi-advanced-input span{
  display:block;
  color:#64748b;
  font-size:10px;
  font-weight:950;
  letter-spacing:.08em;
}
.kpi-command-hero h2{
  margin:5px 0 0;
  color:#0f172a;
  font-size:20px;
  font-weight:950;
  line-height:1.35;
  letter-spacing:0;
}
.kpi-command-hero p,
.kpi-command-card-head p,
.kpi-plan-card p{
  margin:6px 0 0;
  color:#64748b;
  font-size:12px;
  font-weight:800;
  line-height:1.6;
}
.kpi-scope-switch{
  display:inline-flex;
  gap:3px;
  flex-shrink:0;
  border:1px solid #e2e8f0;
  border-radius:10px;
  background:#f8fafc;
  padding:3px;
}
.kpi-scope-switch button{
  border:0;
  border-radius:8px;
  background:transparent;
  color:#64748b;
  cursor:pointer;
  font-size:11px;
  font-weight:950;
  padding:7px 14px;
}
.kpi-command-card{
  min-width:0;
  margin-bottom:14px;
  border:1px solid #e2e8f0;
  border-radius:14px;
  background:#fff;
  padding:16px;
  box-shadow:0 2px 10px rgba(15,23,42,.03);
}
.kpi-command-card-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:13px;
}
.kpi-command-card-head #kpiScopeLabel{
  color:#64748b;
  font-size:11px;
  font-weight:850;
}
.kpi-command-card-head button{
  border:0;
  border-radius:9px;
  background:#0f172a;
  color:#fff;
  cursor:pointer;
  flex-shrink:0;
  font-size:12px;
  font-weight:950;
  padding:9px 14px;
}
.kpi-primary-form{
  display:block;
}
.kpi-revenue-builder{
  display:grid;
  grid-template-columns:minmax(170px,.9fr) minmax(170px,.9fr) minmax(260px,1.3fr);
  gap:10px;
  align-items:stretch;
}
.kpi-input-card{
  display:block;
  min-width:0;
  border:1px solid #e2e8f0;
  border-radius:12px;
  background:#f8fafc;
  padding:12px;
}
.kpi-input-card-main{
  background:#fff;
  border-color:#dbeafe;
}
.kpi-input-card > div{
  display:flex;
  align-items:flex-end;
  gap:8px;
  margin-top:7px;
}
.kpi-input-card input{
  width:100%;
  min-width:0;
  border:0;
  border-bottom:2px solid #cbd5e1;
  background:transparent;
  color:#0f172a;
  font-size:25px;
  font-weight:950;
  line-height:1.1;
  outline:none;
  padding:0 0 3px;
}
.kpi-input-card input:focus{
  border-bottom-color:#2563eb;
}
.kpi-input-card em,
.kpi-advanced-input em{
  color:#475569;
  flex-shrink:0;
  font-size:11px;
  font-style:normal;
  font-weight:950;
  padding-bottom:6px;
}
.kpi-input-card small{
  display:block;
  margin-top:7px;
  color:#64748b;
  font-size:10px;
  font-weight:850;
  line-height:1.45;
}
.kpi-reverse-preview{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  min-width:0;
  border:1px solid #0f172a;
  border-radius:12px;
  background:#0f172a;
  color:#fff;
  padding:13px 14px;
  box-shadow:0 10px 26px rgba(15,23,42,.16);
}
.kpi-reverse-title{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:8px;
  margin-bottom:10px;
}
.kpi-reverse-title span{
  color:#93c5fd;
  font-size:10px;
  font-weight:950;
  letter-spacing:.08em;
}
.kpi-reverse-title strong{
  color:#fff;
  font-size:12px;
  font-weight:950;
  text-align:right;
}
.kpi-reverse-metrics{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:6px;
}
.kpi-reverse-metrics div{
  min-width:0;
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  background:rgba(255,255,255,.07);
  padding:8px 6px;
  text-align:center;
}
.kpi-reverse-metrics strong{
  display:block;
  color:#fff;
  font-size:21px;
  font-weight:950;
  line-height:1;
}
.kpi-reverse-metrics span{
  display:block;
  margin-top:5px;
  color:#cbd5e1;
  font-size:9px;
  font-weight:900;
  letter-spacing:0;
}
.kpi-reverse-preview p{
  margin:10px 0 0;
  color:#cbd5e1;
  font-size:10px;
  font-weight:800;
  line-height:1.5;
}
.kpi-advanced-fold{
  margin-top:10px;
  border-top:1px solid #edf2f7;
  padding-top:10px;
}
.kpi-advanced-fold summary{
  color:#475569;
  cursor:pointer;
  font-size:11px;
  font-weight:950;
}
.kpi-advanced-form{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
  margin-top:10px;
}
.kpi-advanced-input{
  display:grid;
  grid-template-columns:minmax(0,1fr) 84px auto;
  gap:7px;
  align-items:center;
  border:1px solid #e2e8f0;
  border-radius:10px;
  padding:9px 10px;
}
.kpi-advanced-input input{
  width:100%;
  min-width:0;
  border:1px solid #dbe3ee;
  border-radius:8px;
  color:#0f172a;
  font-size:13px;
  font-weight:900;
  padding:6px 8px;
}
.kpi-auto-plan{
  display:grid;
  grid-template-columns:1.25fr repeat(3,minmax(0,1fr));
  gap:10px;
  margin-bottom:14px;
}
.kpi-plan-card{
  min-width:0;
  border:1px solid #e2e8f0;
  border-radius:14px;
  background:#fff;
  padding:14px;
  box-shadow:0 2px 10px rgba(15,23,42,.03);
}
.kpi-plan-main{
  background:#0f172a;
  border-color:#0f172a;
}
.kpi-plan-main span{
  color:#93c5fd;
}
.kpi-plan-card strong{
  display:block;
  margin-top:5px;
  color:#0f172a;
  font-size:23px;
  font-weight:950;
  line-height:1.15;
}
.kpi-plan-main strong,
.kpi-plan-main p{
  color:#fff;
}
.kpi-command-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:14px;
  margin-bottom:14px;
}
.kpi-progress-card{
  display:grid;
  gap:8px;
  margin-bottom:10px;
  border:1px solid #e2e8f0;
  border-radius:12px;
  padding:12px;
}
.kpi-progress-card span{
  color:#64748b;
  font-size:10px;
  font-weight:950;
}
.kpi-progress-card strong{
  display:block;
  margin-top:3px;
  color:#0f172a;
  font-size:21px;
  font-weight:950;
  line-height:1.1;
}
.kpi-progress-card strong small{
  color:#94a3b8;
  font-size:11px;
  font-weight:850;
}
.kpi-progress-card p{
  margin:5px 0 0;
  color:#64748b;
  font-size:11px;
  font-weight:850;
}
.kpi-progress-card em{
  display:block;
  height:7px;
  border-radius:999px;
  background:#e2e8f0;
  overflow:hidden;
}
.kpi-progress-card i{
  display:block;
  height:100%;
  border-radius:999px;
  background:#2563eb;
}
.kpi-progress-good i{background:#16a34a}
.kpi-progress-warn i{background:#d97706}
.kpi-next-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:9px;
  border:1px solid #e2e8f0;
  border-radius:12px;
  background:#fff;
  padding:11px 12px;
}
.kpi-next-row span{
  color:#0f172a;
  font-size:12px;
  font-weight:950;
}
.kpi-next-row small{
  display:block;
  margin-top:3px;
  color:#64748b;
  font-size:10px;
  font-weight:850;
  line-height:1.45;
}
.kpi-next-row strong{
  color:#0f172a;
  flex-shrink:0;
  font-size:19px;
  font-weight:950;
}
.kpi-next-danger{border-color:#fecaca;background:#fef2f2}
.kpi-next-warn{border-color:#fed7aa;background:#fff7ed}
.kpi-next-blue{border-color:#bfdbfe;background:#eff6ff}
.kpi-next-good{border-color:#bbf7d0;background:#f0fdf4}
.kpi-member-row{
  display:grid;
  grid-template-columns:minmax(180px,1.2fr) 88px repeat(4,70px);
  gap:8px;
  align-items:center;
  width:100%;
  margin-bottom:8px;
  border:1px solid #e2e8f0;
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  padding:11px 12px;
  text-align:left;
}
.kpi-member-row:hover{
  border-color:#bfdbfe;
  background:#f8fafc;
}
.kpi-member-row span{
  min-width:0;
}
.kpi-member-row span strong{
  display:block;
  color:#0f172a;
  font-size:13px;
  font-weight:950;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.kpi-member-row span small{
  display:block;
  margin-top:3px;
  color:#64748b;
  font-size:10px;
  font-weight:850;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.kpi-member-row em{
  justify-self:start;
  border-radius:999px;
  background:#f1f5f9;
  color:#475569;
  font-size:10px;
  font-style:normal;
  font-weight:950;
  padding:5px 9px;
}
.kpi-member-row b{
  color:#0f172a;
  font-size:13px;
  font-weight:950;
  text-align:right;
}
.kpi-member-row b small{
  display:block;
  margin-top:2px;
  color:#94a3b8;
  font-size:9px;
  font-weight:850;
}
.kpi-member-row .is-danger{color:#dc2626}
.kpi-member-danger em{background:#fef2f2;color:#dc2626}
.kpi-member-warn em{background:#fff7ed;color:#d97706}
.kpi-member-blue em{background:#eff6ff;color:#2563eb}
.kpi-member-good em{background:#f0fdf4;color:#16a34a}

@media(max-width:980px){
  .crm-simple-stats,
  .an-simple-stats{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .kpi-primary-form,
  .kpi-revenue-builder,
  .kpi-auto-plan,
  .kpi-command-grid{
    grid-template-columns:1fr;
  }
  .kpi-advanced-form{
    grid-template-columns:1fr;
  }
  .kpi-member-row{
    grid-template-columns:minmax(0,1fr) 92px repeat(2,58px);
  }
  .kpi-member-row b:nth-of-type(n+3){
    display:none;
  }
  .crm-inbox-source-grid{
    grid-template-columns:1fr;
  }
  .crm-pipeline-steps{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .cd-command-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .cd-primary-actions{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .cd-command-signal{
    grid-column:1 / -1;
  }
  .an-manager-kpi-grid,
  .an-manager-layout{
    grid-template-columns:1fr;
  }
  .crm-simple-grid,
  .an-simple-grid{
    grid-template-columns:1fr;
  }
  .dash-role-grid{
    grid-template-columns:1fr;
  }
  .dash-role-head{
    flex-direction:column;
  }
  .dash-role-head button{
    width:100%;
  }
  .crm-essential-row{
    grid-template-columns:1fr 1fr;
  }
  .crm-essential-chips{
    grid-column:1 / -1;
  }
  .crm-sales-card{
    grid-template-columns:1fr;
  }
  .crm-sales-main{
    grid-template-columns:14px minmax(160px,1.1fr) minmax(140px,.9fr);
  }
  .crm-sales-next,
  .crm-sales-meta{
    grid-column:2 / -1;
  }
  .crm-sales-meta{
    justify-content:flex-start;
  }
  .crm-sales-actions{
    justify-content:flex-start;
  }
  .crm-intervention-grid,
  .an-intervention-grid{
    grid-template-columns:1fr;
  }
}

@media(max-width:640px){
  .kpi-command-hero,
  .crm-simple-hero,
  .an-simple-hero{
    flex-direction:column;
    padding:14px;
  }
  .kpi-command-hero h2,
  .crm-simple-hero h2,
  .an-simple-hero h2{
    font-size:17px;
  }
  .kpi-scope-switch,
  .kpi-command-card-head{
    width:100%;
  }
  .kpi-command-card-head{
    flex-direction:column;
  }
  .kpi-command-card-head button{
    width:100%;
  }
  .kpi-scope-switch button{
    flex:1;
  }
  .kpi-input-card input{
    font-size:22px;
  }
  .kpi-reverse-metrics{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .kpi-advanced-input{
    grid-template-columns:minmax(0,1fr) 74px auto;
  }
  .kpi-member-row{
    grid-template-columns:minmax(0,1fr) 80px 54px;
  }
  .kpi-member-row b:nth-of-type(n+2){
    display:none;
  }
  .crm-simple-hero-metric,
  .an-simple-hero-metric{
    min-width:0;
    text-align:left;
  }
  .dash-role-home{
    border-radius:16px;
    padding:14px;
  }
  .dash-role-head h2{
    font-size:17px;
  }
  .dash-role-stats{
    grid-template-columns:1fr;
  }
  .dash-role-task{
    grid-template-columns:28px minmax(0,1fr);
  }
  .dash-role-cta{
    grid-column:2;
    justify-self:start;
  }
  .dash-role-owner{
    grid-template-columns:minmax(0,1fr) 54px 54px;
  }
  .dash-role-owner em{
    grid-column:1 / -1;
  }
  .crm-simple-stats,
  .an-simple-stats{
    grid-template-columns:1fr;
  }
  .crm-simple-card,
  .an-simple-card{
    padding:13px;
  }
  .crm-inbox-source-head{
    flex-direction:column;
  }
  .crm-pipeline-head{
    flex-direction:column;
  }
  .crm-pipeline-head button{
    width:100%;
  }
  .crm-pipeline-steps,
  .crm-today-kpi,
  .cd-primary-actions{
    grid-template-columns:1fr;
  }
  .cd-secondary-actions summary,
  .cd-metrics-details summary{
    padding-left:16px;
    padding-right:16px;
  }
  .cd-secondary-action-list{
    padding-left:16px;
    padding-right:16px;
  }
  .cd-secondary-action-list button{
    flex:1 1 100%;
  }
  .cd-command-panel{
    overflow-x:hidden;
    padding:12px 16px 70px;
  }
  .cd-mobile-action-bar{
    position:fixed;
    left:12px;
    right:12px;
    bottom:12px;
    z-index:40;
    display:grid;
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:7px;
    padding:8px;
    border:1px solid rgba(148,163,184,.28);
    border-radius:16px;
    background:rgba(255,255,255,.96);
    box-shadow:0 18px 42px rgba(15,23,42,.22);
    backdrop-filter:blur(14px);
  }
  .cd-mobile-action-bar button{
    min-height:42px;
    border:0;
    border-radius:11px;
    background:#0f172a;
    color:#fff;
    font-size:12px;
    font-weight:950;
    cursor:pointer;
  }
  .cd-mobile-action-bar button:disabled{
    background:#e2e8f0;
    color:#94a3b8;
    cursor:not-allowed;
  }
  .cd-mobile-action-bar .cd-mobile-done{
    background:#16a34a;
  }
  #customerDetailModal #cdMetricsRow{
    grid-template-columns:1fr!important;
  }
  .cd-next-best{
    grid-template-columns:1fr;
    overflow:hidden;
  }
  .cd-next-best button{
    width:100%;
  }
  .cd-command-grid{
    grid-template-columns:1fr;
  }
  .crm-inbox-source-note,
  .crm-inbox-source-head > div:last-child,
  .crm-inbox-source-head button{
    width:100%;
  }
  .crm-inbox-source-head button{
    justify-content:center;
  }
  .an-manager-hero-simple{
    flex-direction:column;
    align-items:stretch;
    padding:14px;
  }
  .an-manager-hero-simple h2{
    font-size:17px;
  }
  .an-manager-kpi-grid{
    grid-template-columns:1fr;
  }
  .an-manager-action{
    grid-template-columns:1fr;
  }
  .an-manager-action > span{
    grid-row:auto;
    justify-self:start;
    min-height:0;
    padding:5px 9px;
  }
  .an-manager-directive,
  .an-manager-saved-row{
    grid-template-columns:1fr;
  }
  .an-manager-directive-main{
    grid-template-columns:1fr;
  }
  .an-manager-directive-main span{
    grid-row:auto;
    justify-self:start;
    min-height:0;
    padding:5px 9px;
  }
  .an-manager-directive-save,
  .an-manager-saved-row button{
    width:100%;
  }
  .an-manager-health-row{
    grid-template-columns:minmax(0,1fr) 92px repeat(2,54px);
  }
  .an-manager-health-row span:nth-child(n+5){
    display:none;
  }
  .crm-essential-row{
    grid-template-columns:1fr;
    padding:9px;
  }
  .crm-essential-chips{
    grid-column:auto;
  }
  .crm-essential-chip,
  .crm-essential-clear{
    flex:1 1 calc(50% - 4px);
  }
  .crm-sales-board{
    padding:11px;
    border-radius:14px;
  }
  .crm-sales-board-head{
    align-items:flex-start;
    flex-direction:column;
    gap:4px;
  }
  .crm-sales-head-actions{
    width:100%;
    justify-content:space-between;
  }
  .crm-sales-card{
    padding:11px;
  }
  .crm-sales-main{
    grid-template-columns:12px minmax(0,1fr);
  }
  .crm-sales-signal,
  .crm-sales-next,
  .crm-sales-meta{
    grid-column:2;
  }
  .crm-sales-actions{
    display:grid;
    grid-template-columns:1fr 1fr 1fr;
  }
  .crm-sales-actions button{
    width:100%;
  }
  .pm-usage-intro{
    display:block;
  }
  .pm-usage-select-fallback{
    width:100%;
    min-width:0;
    margin-top:10px;
  }
  .pm-usage-choice-grid{
    grid-template-columns:1fr;
  }
  .crm-simple-task{
    grid-template-columns:10px minmax(0,1fr);
  }
  .crm-simple-task-cta{
    grid-column:2;
    justify-self:start;
  }
  .crm-simple-owner-head{
    display:none;
  }
  .crm-simple-owner-row,
  .an-simple-owner-row{
    grid-template-columns:minmax(0,1fr) repeat(2,58px);
  }
  .crm-simple-owner-row span:nth-child(n+4),
  .an-simple-owner-row span:nth-child(n+4){
    display:none;
  }
}

/* R-NEW67: CRM / 営業分析の表示崩れ対策
   index.html の旧インライン緊急CSSより強い指定で、現行のシンプルUIを優先する。 */
html body #appShell .view:not(.active){
  display:none !important;
  pointer-events:none !important;
}
html body #appShell .view.active{
  pointer-events:auto !important;
}

html body #view-analytics #anKpiHero,
html body #view-analytics #anManagerHero{
  display:none !important;
  visibility:hidden !important;
  height:0 !important;
  min-height:0 !important;
  max-height:0 !important;
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
  overflow:hidden !important;
  pointer-events:none !important;
}

html body #view-analytics #anModeTabContainer{
  display:inline-flex;
  align-items:center;
  gap:4px;
  border-radius:12px;
  background:#f1f5f9;
  padding:4px;
  position:relative;
  z-index:3;
}
html body #view-analytics #anModeTabContainer #anMode-personal,
html body #view-analytics #anModeTabContainer #anMode-manager{
  background:transparent !important;
  color:#64748b !important;
  border:0 !important;
  box-shadow:none !important;
}
html body #view-analytics #anModeTabContainer #anMode-personal.is-active,
html body #view-analytics #anModeTabContainer #anMode-manager.is-active{
  background:#0f172a !important;
  color:#fff !important;
  box-shadow:0 1px 3px rgba(15,23,42,.16) !important;
}

html body #view-crm #crmCommandCenter .crm-simple-task,
html body #view-analytics .crm-simple-task{
  background:#fff !important;
  color:#0f172a !important;
  border:1px solid #e2e8f0 !important;
  box-shadow:none !important;
}
html body #view-crm #crmCommandCenter .crm-simple-task:hover,
html body #view-analytics .crm-simple-task:hover{
  background:#f8fafc !important;
  border-color:#bfdbfe !important;
}
html body #view-crm #crmCommandCenter .crm-simple-task-main strong,
html body #view-analytics .crm-simple-task-main strong{
  color:#0f172a !important;
  opacity:1 !important;
}
html body #view-crm #crmCommandCenter .crm-simple-task-main small,
html body #view-analytics .crm-simple-task-main small{
  color:#475569 !important;
  opacity:1 !important;
}
html body #view-crm #crmCommandCenter .crm-simple-task-cta,
html body #view-analytics .crm-simple-task-cta{
  color:#1d4ed8 !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
}
html body #view-crm #crmCommandCenter .crm-simple-task-danger .crm-simple-task-dot,
html body #view-analytics .crm-simple-task-danger .crm-simple-task-dot{
  background:#dc2626 !important;
}
html body #view-crm #crmCommandCenter .crm-simple-task-warn .crm-simple-task-dot,
html body #view-analytics .crm-simple-task-warn .crm-simple-task-dot{
  background:#d97706 !important;
}
html body #view-crm #crmCommandCenter .crm-simple-task-good .crm-simple-task-dot,
html body #view-analytics .crm-simple-task-good .crm-simple-task-dot{
  background:#16a34a !important;
}

html body #view-crm #crmCommandCenter .crm-simple-card-head button{
  background:#eff6ff !important;
  color:#1d4ed8 !important;
  border:1px solid #dbeafe !important;
  box-shadow:none !important;
}

@media(max-width:640px){
  html body #view-crm #crmCommandCenter .crm-simple-task,
  html body #view-analytics .crm-simple-task{
    grid-template-columns:10px minmax(0,1fr);
  }
  html body #view-crm #crmCommandCenter .crm-simple-task-cta,
  html body #view-analytics .crm-simple-task-cta{
    grid-column:2;
    justify-self:start;
  }
}

/* ===== 周辺サービス: simple command UI ===== */
#view-services .svc-command{
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding:18px;
  box-shadow:0 12px 30px rgba(15,23,42,.05);
}
#view-services .svc-command-top{
  display:grid;
  grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr);
  gap:16px;
  align-items:stretch;
}
#view-services .svc-command-copy{
  background:linear-gradient(135deg,#0f172a,#1e293b);
  color:#fff;
  border-radius:12px;
  padding:18px;
  min-height:180px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
#view-services .svc-section-kicker{
  font-size:10px;
  font-weight:900;
  color:#10b981;
  letter-spacing:.16em;
}
#view-services .svc-command-copy h3{
  margin:8px 0 8px;
  font-size:24px;
  line-height:1.35;
  letter-spacing:0;
}
#view-services .svc-command-copy p{
  margin:0;
  color:#cbd5e1;
  font-size:13px;
  line-height:1.8;
}
#view-services .svc-command-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:16px;
}
#view-services .svc-command-actions button,
#view-services .svc-command-actions a{
  border:0;
  border-radius:9px;
  padding:9px 13px;
  font-size:12px;
  font-weight:850;
  cursor:pointer;
  text-decoration:none;
  white-space:nowrap;
}
#view-services .svc-primary-action{background:#10b981;color:#fff}
#view-services .svc-secondary-action{background:rgba(255,255,255,.1);color:#e2e8f0;border:1px solid rgba(255,255,255,.14)!important}
#view-services .svc-command-metrics{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
#view-services .svc-command-metric{
  border:1px solid #e5e7eb;
  border-radius:12px;
  padding:14px;
  background:linear-gradient(180deg,#fff,#f8fafc);
}
#view-services .svc-command-metric small{
  display:block;
  color:#64748b;
  font-size:10px;
  font-weight:900;
  margin-bottom:6px;
}
#view-services .svc-command-metric strong{
  display:block;
  color:#0f172a;
  font-size:25px;
  line-height:1;
  letter-spacing:0;
}
#view-services .svc-command-metric span{
  display:block;
  color:#94a3b8;
  font-size:10px;
  margin-top:6px;
}
#view-services .svc-next-card{
  margin-top:12px;
  border:1px solid #e5e7eb;
  border-radius:12px;
  background:#f8fafc;
  padding:14px;
}
#view-services .svc-next-card-title{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:center;
  margin-bottom:8px;
}
#view-services .svc-next-card-title strong{
  color:#0f172a;
  font-size:13px;
}
#view-services .svc-next-card-title span{
  color:#64748b;
  font-size:10px;
  font-weight:800;
}
#view-services .svc-next-card p{
  margin:0;
  color:#475569;
  font-size:12px;
  line-height:1.7;
}
#view-services .svc-next-card .svc-secondary-action{
  background:#fff;
  color:#334155;
  border:1px solid #cbd5e1!important;
}
#view-services .svc-rec-card{
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding:16px;
  box-shadow:0 8px 22px rgba(15,23,42,.04);
}
#view-services .svc-rec-head,
#view-services .svc-tools-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  margin-bottom:12px;
}
#view-services .svc-section-title{
  color:#0f172a;
  font-size:16px;
  font-weight:900;
  margin-top:3px;
}
#view-services .svc-rec-head span,
#view-services .svc-tools-head span{
  color:#64748b;
  font-size:11px;
  font-weight:800;
  white-space:nowrap;
}
#view-services .svc-rec-list{
  display:flex;
  flex-direction:column;
  gap:8px;
}
#view-services .svc-rec-row{
  display:grid;
  grid-template-columns:10px minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
  border:1px solid #e5e7eb;
  border-radius:12px;
  padding:11px 12px;
  background:#fff;
}
#view-services .svc-rec-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:#10b981;
}
#view-services .svc-rec-main strong{
  display:block;
  color:#0f172a;
  font-size:13px;
}
#view-services .svc-rec-badge{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:2px 7px;
  margin-left:6px;
  font-size:10px;
  font-weight:900;
  vertical-align:middle;
}
#view-services .svc-rec-reason{
  display:block;
  color:#64748b;
  font-size:11px;
  margin-top:3px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
#view-services .svc-rec-actions{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
#view-services .svc-rec-actions button{
  border:1px solid #e5e7eb;
  background:#fff;
  color:#334155;
  border-radius:8px;
  padding:6px 9px;
  font-size:11px;
  font-weight:850;
  cursor:pointer;
}
#view-services .svc-rec-actions .svc-rec-primary{
  background:#0f172a;
  color:#fff;
  border-color:#0f172a;
}
#view-services .svc-tools-shell{
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding:14px 16px 16px;
}
#view-services .svc-tool-tabs{
  display:flex;
  gap:6px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  padding-bottom:2px;
}
#view-services .svc-tool-tab{
  border:1px solid #e5e7eb!important;
  background:#fff!important;
  color:#475569!important;
  border-radius:10px!important;
  padding:9px 13px!important;
  font-size:12px!important;
  font-weight:850!important;
  cursor:pointer!important;
  white-space:nowrap!important;
  flex-shrink:0!important;
  box-shadow:none!important;
}
#view-services .svc-tool-tab.is-active{
  background:#0f172a!important;
  color:#fff!important;
  border-color:#0f172a!important;
}
#view-services .svc-settings summary{
  list-style:none;
  cursor:pointer;
}
#view-services .svc-settings summary::-webkit-details-marker{display:none}
#view-services .svc-settings-shell{
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding:14px 16px;
}
#view-services .svc-settings-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:10px;
  margin-top:12px;
}
.mobile-bottom-nav{display:none}
@media(max-width:760px){
  #view-services .svc-command{padding:14px}
  #view-services .svc-command-top{grid-template-columns:1fr}
  #view-services .svc-command-copy{padding:16px;min-height:0}
  #view-services .svc-command-copy h3{font-size:20px}
  #view-services .svc-command-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}
  #view-services .svc-command-metric{padding:12px}
  #view-services .svc-command-metric strong{font-size:22px}
  #view-services .svc-rec-row{grid-template-columns:10px minmax(0,1fr)}
  #view-services .svc-rec-actions{grid-column:2;justify-content:flex-start}
  #view-services .svc-rec-head,
  #view-services .svc-tools-head{display:block}
  #view-services .svc-rec-head span,
  #view-services .svc-tools-head span{display:block;margin-top:6px}
}

/* ===== Mobile UX polish: 操作できるスマホ画面へ ===== */
@media(max-width:768px){
  .main-content{
    padding-top:62px!important;
    padding-bottom:calc(env(safe-area-inset-bottom) + 96px)!important;
  }

  .mobile-bottom-nav{
    position:fixed;
    left:10px;
    right:10px;
    bottom:calc(env(safe-area-inset-bottom) + 8px);
    height:62px;
    display:grid!important;
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:4px;
    z-index:7900;
    padding:6px;
    border:1px solid rgba(148,163,184,.32);
    border-radius:20px;
    background:rgba(255,255,255,.94);
    box-shadow:0 18px 46px rgba(15,23,42,.18);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
  }
  .mobile-bottom-nav button{
    appearance:none;
    border:0;
    background:transparent;
    color:#64748b;
    border-radius:14px;
    min-width:0;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:3px;
    font-size:10px;
    font-weight:900;
    letter-spacing:0;
    cursor:pointer;
    transition:background .15s ease,color .15s ease,transform .15s ease;
  }
  .mobile-bottom-nav button svg{
    width:19px;
    height:19px;
    flex:0 0 auto;
  }
  .mobile-bottom-nav button span{
    display:block;
    max-width:100%;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .mobile-bottom-nav button.active{
    background:#0f172a;
    color:#fff;
    box-shadow:0 8px 18px rgba(15,23,42,.18);
  }
  .mobile-bottom-nav button:active{
    transform:scale(.97);
  }

  #mobileHamburger{
    width:40px!important;
    height:40px!important;
    top:12px!important;
    left:12px!important;
    border-radius:12px!important;
    background:rgba(255,255,255,.95)!important;
    color:#0f172a!important;
    border:1px solid #dbe3ef!important;
    box-shadow:0 10px 24px rgba(15,23,42,.14)!important;
    font-size:20px!important;
    line-height:1!important;
    backdrop-filter:blur(10px)!important;
  }

  #supportChatBtn{
    top:auto!important;
    right:14px!important;
    bottom:calc(env(safe-area-inset-bottom) + 82px)!important;
    width:42px!important;
    height:42px!important;
    min-width:42px!important;
    min-height:42px!important;
    padding:0!important;
    border-radius:999px!important;
    background:#0f172a!important;
    color:#fff!important;
    box-shadow:0 12px 30px rgba(15,23,42,.24)!important;
    border:1px solid rgba(255,255,255,.18)!important;
  }
  #supportChatBtn span{display:none!important}
  #supportChatModal{
    top:auto!important;
    left:12px!important;
    right:12px!important;
    bottom:calc(env(safe-area-inset-bottom) + 132px)!important;
    width:auto!important;
    max-width:none!important;
    max-height:calc(100dvh - 104px)!important;
  }
  #dashHeroBar > div[style*="radial-gradient"]{
    display:none!important;
  }
  #dashAiBriefing div[style*="border-radius:50%"][style*="pointer-events:none"]{
    display:none!important;
  }

  #view-crm .view-header > div:nth-child(2){
    display:grid!important;
    grid-template-columns:minmax(0,1fr) 44px!important;
    gap:8px!important;
    width:100%!important;
    justify-content:stretch!important;
    align-items:stretch!important;
  }
  #view-crm .view-header > div:nth-child(2) > button.btn-primary{
    grid-column:1 / -1!important;
    order:1!important;
    width:100%!important;
    min-height:46px!important;
    justify-content:center!important;
  }
  #view-crm .view-header > div:nth-child(2) > button[onclick*="openFormIssueModal"]:not(#crmHeaderKebabMenu *){
    order:2!important;
    width:100%!important;
    min-height:42px!important;
    justify-content:center!important;
    margin:0!important;
  }
  #view-crm .view-header > div:nth-child(2) > div[style*="position:relative"]{
    order:3!important;
    width:44px!important;
  }
  #crmHeaderKebab{
    width:44px!important;
    height:42px!important;
    border-radius:12px!important;
    margin:0!important;
  }
  #crmHeaderKebabMenu{
    right:0!important;
    min-width:min(270px, calc(100vw - 32px))!important;
    z-index:1200!important;
  }

  #view-loan .loan-step-actions{
    position:static!important;
    bottom:auto!important;
    z-index:auto!important;
    background:transparent!important;
    padding:12px 0 0!important;
    text-align:initial!important;
  }
  #view-loan .loan-step-actions .btn{
    width:100%!important;
    min-height:48px!important;
    justify-content:center!important;
  }
  #view-loan #buildingAgeRow,
  #view-loan .loan-mobile-optional-row{
    background:#f8fafc!important;
    border:1px solid #e2e8f0!important;
    border-radius:14px!important;
    padding:10px!important;
    gap:10px!important;
  }
  #view-loan #buildingAgeRow .form-group,
  #view-loan .loan-mobile-optional-row .form-group{
    margin-bottom:0!important;
  }
  #view-loan .loan-mobile-optional-row .form-label,
  #view-loan #buildingAgeRow .form-label{
    font-size:11px!important;
  }
  #view-loan #completionAgeBar{
    margin:-2px 0 10px!important;
    padding:9px 10px!important;
    border-radius:12px!important;
  }
  #view-loan #completionAgeBar > div:first-child{
    gap:6px!important;
  }
  #view-loan #completionAgeVal{
    font-size:17px!important;
  }

  #view-documents .doc-mobile-step-guide{
    display:grid!important;
    grid-template-columns:minmax(0,1fr)!important;
    gap:10px!important;
    padding:14px!important;
  }
  #view-documents .doc-mobile-step-guide > div{
    min-width:0!important;
  }
  #view-documents .doc-mobile-step-guide > div[style*="width:32px"]{
    display:none!important;
  }
  #view-documents .doc-mobile-step-guide > div[style*="flex:1"]{
    width:100%!important;
    padding:10px 12px!important;
    border:1px solid #e2e8f0!important;
    border-radius:12px!important;
    background:#fff!important;
  }
  #view-documents .doc-mobile-step-guide > div[style*="margin-left"]{
    margin-left:0!important;
    width:100%!important;
  }
  #view-documents .doc-mobile-step-guide label{
    width:100%!important;
    justify-content:center!important;
    min-height:42px!important;
    box-sizing:border-box!important;
  }

  #view-property .prop-url-import-row{
    display:grid!important;
    grid-template-columns:minmax(0,1fr)!important;
    gap:8px!important;
    align-items:stretch!important;
  }
  #view-property #propKPIs{
    grid-template-columns:repeat(4,minmax(0,1fr))!important;
    gap:8px!important;
    margin-bottom:12px!important;
  }
  #view-property #propKPIs .prop-kpi-card{
    padding:10px 5px!important;
    border-radius:12px!important;
    min-height:74px!important;
  }
  #view-property #propKPIs .prop-kpi-card svg{
    width:14px!important;
    height:14px!important;
  }
  #view-property #propKPIs .prop-kpi-label{
    font-size:9px!important;
    line-height:1.25!important;
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
  }
  #view-property #propKPIs .prop-kpi-value{
    font-size:16px!important;
    line-height:1.15!important;
  }
  #view-property #propKPIs .prop-kpi-sub,
  #view-property #propKPIs .prop-kpi-secondary{
    display:none!important;
  }
  #view-property .prop-import-card{
    padding:14px!important;
    margin-bottom:14px!important;
  }
  #view-property .prop-import-warning{
    font-size:10px!important;
    line-height:1.45!important;
  }
  .uls-subtab-bar{
    overflow-x:auto!important;
    flex-wrap:nowrap!important;
    justify-content:flex-start!important;
    gap:6px!important;
    padding:4px!important;
    -webkit-overflow-scrolling:touch!important;
    scroll-snap-type:x proximity!important;
    mask-image:linear-gradient(90deg,#000 calc(100% - 28px),transparent)!important;
    -webkit-mask-image:linear-gradient(90deg,#000 calc(100% - 28px),transparent)!important;
  }
  .uls-subtab{
    flex:0 0 auto!important;
    min-width:max-content!important;
    white-space:nowrap!important;
    word-break:keep-all!important;
    overflow-wrap:normal!important;
    line-height:1.15!important;
    font-size:12px!important;
    padding:9px 14px!important;
    scroll-snap-align:start!important;
  }
  #view-property .prop-url-import-row #propUrlInput,
  #view-property .prop-url-import-row #propUrlOpenBtn,
  #view-property .prop-url-import-row button{
    width:100%!important;
    box-sizing:border-box!important;
    justify-content:center!important;
    text-align:center!important;
  }

  #view-esign .esign-mobile-kpis,
  #rmTabPanel-esign .esign-mobile-kpis{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:10px!important;
    margin-bottom:14px!important;
  }
  #view-esign .esign-mobile-kpis > div,
  #rmTabPanel-esign .esign-mobile-kpis > div{
    padding:12px 10px!important;
  }
  #view-esign .esign-mobile-kpis [style*="font-size:28px"],
  #rmTabPanel-esign .esign-mobile-kpis [style*="font-size:28px"]{
    font-size:22px!important;
  }
  #view-esign .esign-mobile-alerts,
  #rmTabPanel-esign .esign-mobile-alerts{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:8px!important;
  }
  #view-esign .esign-mobile-actions,
  #rmTabPanel-esign .esign-mobile-actions,
  #view-esign .esign-mobile-usage,
  #rmTabPanel-esign .esign-mobile-usage{
    display:grid!important;
    grid-template-columns:minmax(0,1fr)!important;
    align-items:stretch!important;
    gap:8px!important;
  }
  #view-esign .esign-mobile-actions .btn,
  #rmTabPanel-esign .esign-mobile-actions .btn,
  #view-esign .esign-mobile-actions button,
  #rmTabPanel-esign .esign-mobile-actions button{
    width:100%!important;
    min-height:42px!important;
    justify-content:center!important;
  }
  #view-esign .esign-mobile-actions > div,
  #rmTabPanel-esign .esign-mobile-actions > div{
    width:100%!important;
    justify-content:center!important;
    flex-wrap:wrap!important;
  }
  #view-esign .esign-mobile-filters,
  #rmTabPanel-esign .esign-mobile-filters,
  #view-services .svc-tool-tabs,
  #rmTabBar,
  .admin-tabs{
    overflow-x:auto!important;
    flex-wrap:nowrap!important;
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x proximity;
    padding-right:24px!important;
    mask-image:linear-gradient(90deg,#000 calc(100% - 28px),transparent);
    -webkit-mask-image:linear-gradient(90deg,#000 calc(100% - 28px),transparent);
  }
  #view-esign .esign-mobile-filters button,
  #rmTabPanel-esign .esign-mobile-filters button,
  #view-services .svc-tool-tab,
  #rmTabBar button,
  .admin-tab{
    flex:0 0 auto!important;
    scroll-snap-align:start;
  }
  #view-services .svc-tool-tab{
    min-width:max-content!important;
    white-space:nowrap!important;
    word-break:keep-all!important;
    overflow-wrap:normal!important;
    line-height:1.15!important;
    padding:8px 11px!important;
    font-size:11px!important;
    letter-spacing:0!important;
  }

  #view-esign .esign-mobile-filters,
  #rmTabPanel-esign .esign-mobile-filters{
    flex-wrap:wrap!important;
    overflow-x:visible!important;
    padding-right:0!important;
    mask-image:none!important;
    -webkit-mask-image:none!important;
  }
  #view-esign .esign-mobile-filters button,
  #rmTabPanel-esign .esign-mobile-filters button{
    flex:1 1 calc(50% - 4px)!important;
    text-align:center!important;
  }

  #view-esign #esignViewContent table,
  #rmTabPanel-esign table{
    display:block!important;
    min-width:0!important;
    width:100%!important;
    overflow:visible!important;
  }
  #view-esign #esignViewContent table thead,
  #rmTabPanel-esign table thead{
    display:none!important;
  }
  #view-esign #esignViewContent table tbody,
  #view-esign #esignViewContent table tr,
  #view-esign #esignViewContent table td,
  #rmTabPanel-esign table tbody,
  #rmTabPanel-esign table tr,
  #rmTabPanel-esign table td{
    display:block!important;
    width:100%!important;
    box-sizing:border-box!important;
  }
  #view-esign #esignViewContent table tr,
  #rmTabPanel-esign table tr{
    border:1px solid #e2e8f0!important;
    border-radius:14px!important;
    padding:12px!important;
    margin-bottom:10px!important;
    background:#fff!important;
  }
  #view-esign #esignViewContent table td,
  #rmTabPanel-esign table td{
    padding:7px 0!important;
    text-align:left!important;
    border:none!important;
  }
  #view-esign #esignViewContent table td:first-child,
  #rmTabPanel-esign table td:first-child{
    display:none!important;
  }
  #view-esign #esignViewContent table td:nth-child(n+3)::before,
  #rmTabPanel-esign table td:nth-child(n+3)::before{
    display:block;
    margin-bottom:4px;
    color:#94a3b8;
    font-size:10px;
    font-weight:900;
    letter-spacing:.06em;
  }
  #view-esign #esignViewContent table td:nth-child(3)::before,
  #rmTabPanel-esign table td:nth-child(3)::before{content:"種別"}
  #view-esign #esignViewContent table td:nth-child(4)::before,
  #rmTabPanel-esign table td:nth-child(4)::before{content:"署名者"}
  #view-esign #esignViewContent table td:nth-child(5)::before,
  #rmTabPanel-esign table td:nth-child(5)::before{content:"進捗"}
  #view-esign #esignViewContent table td:nth-child(6)::before,
  #rmTabPanel-esign table td:nth-child(6)::before{content:"ステータス"}
  #view-esign #esignViewContent table td:nth-child(7)::before,
  #rmTabPanel-esign table td:nth-child(7)::before{content:"期限"}
  #view-esign #esignViewContent table td:nth-child(8)::before,
  #rmTabPanel-esign table td:nth-child(8)::before{content:"操作"}
  #view-esign #esignViewContent table td:nth-child(8) > div,
  #rmTabPanel-esign table td:nth-child(8) > div{
    justify-content:flex-start!important;
    flex-wrap:wrap!important;
  }

  #billingViewContent table[style*="min-width:620px"]{
    min-width:0!important;
    width:100%!important;
    table-layout:fixed!important;
  }
  #billingViewContent table[style*="min-width:620px"] th,
  #billingViewContent table[style*="min-width:620px"] td{
    white-space:normal!important;
    word-break:break-word!important;
    padding:9px 10px!important;
  }
}

@media(max-width:480px){
  .main-content{
    padding-top:58px!important;
    padding-bottom:calc(env(safe-area-inset-bottom) + 96px)!important;
  }
  #view-esign .esign-mobile-kpis,
  #rmTabPanel-esign .esign-mobile-kpis{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  #view-esign .esign-mobile-alerts,
  #rmTabPanel-esign .esign-mobile-alerts{
    grid-template-columns:minmax(0,1fr)!important;
  }
  .mobile-bottom-nav{
    left:8px;
    right:8px;
    height:60px;
    border-radius:18px;
  }
  .mobile-bottom-nav button{
    font-size:9px;
  }
  .mobile-bottom-nav button svg{
    width:18px;
    height:18px;
  }
}

/* PC UI review 2026-05-26: keep core work surfaces readable without changing navigation. */
@media(min-width:769px){
  #view-crm #crmListView .table-wrap{
    overflow-x:auto!important;
  }
  #view-crm #crmListView table{
    min-width:1120px!important;
    width:100%!important;
    table-layout:fixed!important;
  }
  #view-crm #crmListView table th:last-child,
  #view-crm #crmListView table td:last-child{
    position:sticky;
    right:0;
    z-index:4;
    background:#fff;
    box-shadow:-10px 0 18px -18px rgba(15,23,42,.55);
  }
  #view-crm #crmListView table thead th:last-child{
    z-index:8;
  }
  #view-crm #crmListView table th,
  #view-crm #crmListView table td{
    overflow:hidden;
    text-overflow:ellipsis;
  }
  #view-property #propKPIs{
    grid-template-columns:repeat(6,minmax(0,1fr))!important;
  }
  #view-property #propKPIs .prop-kpi-card{
    min-height:96px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
  }
  #view-analytics .an-utility-panel{
    align-items:center;
    padding:13px 16px!important;
    border-radius:12px;
    background:#fff;
  }
  #view-analytics .an-utility-panel .an-focus-title{
    font-size:14px!important;
  }
  #view-analytics .an-utility-panel .an-focus-copy{
    margin-top:2px;
    font-size:11px!important;
    line-height:1.55;
  }
}

@media(min-width:769px) and (max-width:1180px){
  #view-property #propKPIs{
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
  }
}
