<!-- ===== /ULSAPO 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{
  /* LP / ITANDI-BB 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}

/* ===== 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(160deg,var(--ink) 0%,#0f172a 55%,#0a0e27 100%);
  display:flex;align-items:center;justify-content:center;
  padding:64px 52px;position:relative;overflow:hidden;flex-shrink:0;
}

/* 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:radial-gradient(circle,rgba(255,255,255,0.04) 1px,transparent 1px);
  background-size:26px 26px;pointer-events:none;
}
.auth-brand::after{
  content:'';position:absolute;bottom:-140px;left:-100px;
  width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(16,185,129,0.18) 0%,transparent 70%);
  pointer-events:none;
}
.auth-brand-inner{position:relative;z-index:1;width:100%;max-width:360px}
.auth-brand-inner::before{
  content:'';position:absolute;top:-140px;right:-140px;
  width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,rgba(234,179,8,0.14) 0%,transparent 70%);
  pointer-events:none;z-index:-1;
}
.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);
}
/* 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 */
/* NOTE (2026-04-20): コンテンツが viewport より高い時の上下クリップ対策。
 * `safe center` によりコンテンツがはみ出す場合は自動的に上寄せになり、
 * 親 .auth-bg の overflow-y:auto でスクロールできる。 */
.auth-form-panel{
  flex:1;display:flex;align-items:safe center;justify-content:safe center;
  padding:40px 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 (ITANDI-BB / 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}
#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 (ITANDI-BB / 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:#fff;border:1px solid #d1d5db;border-radius:4px;box-shadow:0 4px 24px rgba(0,0,0,0.08),0 0 0 1px rgba(0,0,0,0.03);padding:40px 36px;min-height:560px;font-family:'Hiragino Kaku Gothic ProN','Noto Sans JP',sans-serif;position:relative;max-width:794px;margin:0 auto}
.doc-a4-frame::before{content:'A4';position:absolute;top:6px;right:10px;font-size:9px;color:#cbd5e1;font-weight:700;letter-spacing:0.05em}
/* ===== 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}
.doc-hist-row .hist-badge{font-size:9px;font-weight:700;padding:2px 8px;border-radius:10px;white-space:nowrap}
/* ===== 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);
  z-index:100000;display:none;align-items:center;justify-content:center;padding:20px;
  will-change:opacity,transform;transform:translateZ(0);transition:opacity 0.2s ease;
}
#modalOverlay.show{display:flex}
#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:absolute;
  inset:0;
  width:100%;
  max-width:100%;
  max-height:100%;
  display:grid;
  place-items:center;
  pointer-events:none;
}
#modalActiveHost > .modal{
  pointer-events:auto;
  margin:0;
}
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{
  overflow:hidden;
}
#ulsModalOverlay .uls-modal-body{
  width:100%;
}
#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;
}
#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:120500;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:100000;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:100000;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 24px !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-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: 1fr !important;
    gap: 10px !important;
  }

  /* === グリッド系の強制1カラム化 === */
  .form-row, .form-row-3 {
    grid-template-columns: 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: 1fr !important; }
  .bank-grid { grid-template-columns: 1fr !important; }
  .analysis-grid { grid-template-columns: 1fr !important; }
  .bank-stats { grid-template-columns: 1fr !important; }
  .step2-layout { flex-direction: column !important; }
  .bank-filter-sidebar { width: 100% !important; position: static !important; }
  .cs-row { grid-template-columns: 1fr !important; }
  [style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
  [style*="grid-template-columns: 1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
  [style*="grid-template-columns:repeat(4"] {
    grid-template-columns: repeat(2,1fr) !important;
  }
  [style*="grid-template-columns:repeat(3"] {
    grid-template-columns: 1fr !important;
  }
  [style*="grid-template-columns:repeat(2"] {
    grid-template-columns: 1fr !important;
  }

  /* === カード === */
  .card { padding: 12px !important; }
  .card-header { padding: 14px 14px 0 !important; }
  .card-body { padding: 0 14px 14px !important; }

  /* === ウィザードプログレス === */
  .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: 1fr !important;
  }
  /* ダッシュボード KPIグリッド 3列→2列 */
  #dashKpiGrid {
    grid-template-columns: repeat(2,1fr) !important;
    gap: 10px !important;
  }

  /* === 収益用不動産ローン 2カラム→1カラム === */
  #investmentLoanForm > div {
    grid-template-columns: 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: 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: 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: 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: 1fr !important;
  }
}

/* ⑪ ローン検索結果テーブル — モバイル横スクロール */
@media (max-width: 768px) {
  .analysis-grid { grid-template-columns: 1fr !important; }
  #analysisGrid { grid-template-columns: 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: 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: 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: 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: 1fr !important;
  }
  #investmentLoanForm .form-row {
    grid-template-columns: 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: 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: 1fr !important;
    gap: 10px !important;
  }

  /* 成約支援 メインコンテンツ 1カラム化 */
  #closingMainContent {
    grid-template-columns: 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: 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;
  }
}

/* ===== 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}
}


.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)}
.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以外の全要素を確実に非表示 */
    #lpScreen:not([style*="display:none"]):not([style*="display: none"]) ~ *:not(script):not(style):not(link) {
      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{right:12px!important;bottom:12px!important;width:44px!important;height:44px!important}
  #mobileFAB{bottom:12px!important;right:64px!important}
  #docAiPanel{bottom:64px!important;right:12px!important;max-width:calc(100vw - 24px)!important}
  #supportChatModal{bottom:64px!important;right:12px!important;max-width:calc(100vw - 24px)!important;max-height:60vh!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}
}

/* ============================================================
   DOCS_DEEP_AUDIT 2026-04-21 Finding D: 書類管理画面のレスポンシブ化
   ============================================================ */
.docs-main-grid{
  display:grid;
  grid-template-columns:minmax(200px,260px) minmax(0,1fr);
  gap:16px;
  align-items:flex-start;
}
@media(max-width:768px){
  .docs-main-grid{
    grid-template-columns:1fr !important;
  }
  .docs-main-grid > div:first-child{
    position:static !important;
    order:1;
  }
}
@media(max-width:480px){
  .docs-main-grid{gap:12px}
}

/* モーダル z-index 整合: 書類生成モーダル = 1000, 特約モーダル = 1100 */
#specialClauseModal, .doc-special-clause-modal{ z-index:1100 !important; }

/* A4 印刷 CSS 標準化 */
@media print{
  body{padding:0 !important;margin:0 !important}
  .no-print, header, footer, nav, .sidebar, .docs-main-grid > div:first-child{
    display:none !important;
  }
  .docs-main-grid{grid-template-columns:1fr !important;gap:0 !important}
  @page{size:A4;margin:15mm 12mm 15mm 15mm}
  .doc-preview, .doc-content, [data-print-area]{
    box-shadow:none !important;
    border:none !important;
    padding:0 !important;
    margin:0 !important;
  }
  .page-break-before{page-break-before:always}
  .page-break-avoid{page-break-inside:avoid}
}
