:root{
  color-scheme:dark;
  --bg:#070a12;
  --bg2:#0d1324;
  --panel:rgba(255,255,255,.072);
  --panel2:rgba(255,255,255,.105);
  --line:rgba(255,255,255,.15);
  --line2:rgba(159,190,255,.25);
  --text:#f7faff;
  --muted:rgba(225,235,248,.76);
  --soft:rgba(225,235,248,.56);
  --accent:#9fc2ff;
  --accent2:#dbc7ff;
  --gold:#f1d391;
  --shadow:0 28px 100px rgba(0,0,0,.44);
  --radius:20px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-height:100vh;
  font-family:"Noto Sans JP", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 18% 4%, rgba(95,140,255,.24), transparent 28%),
    radial-gradient(circle at 84% 10%, rgba(196,142,255,.2), transparent 30%),
    radial-gradient(circle at 52% 90%, rgba(75,119,255,.12), transparent 34%),
    linear-gradient(145deg, #05070d 0%, var(--bg) 42%, #10172a 100%);
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.22;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:linear-gradient(to bottom, black, transparent 72%);
}
a{color:inherit;text-decoration:none}
.public-header{
  position:sticky;
  top:0;
  z-index:30;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  padding:18px clamp(18px, 4vw, 56px);
  border-bottom:1px solid rgba(255,255,255,.09);
  background:rgba(5,7,13,.72);
  backdrop-filter:blur(22px);
}
.public-brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}
.public-brand-mark{
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  border:1px solid var(--line2);
  border-radius:13px;
  background:
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.38), transparent 26%),
    linear-gradient(145deg, rgba(159,194,255,.28), rgba(219,199,255,.11));
  font-family:"Outfit", sans-serif;
  font-weight:800;
  color:#eaf2ff;
  box-shadow:0 16px 42px rgba(82,126,230,.22);
}
.public-brand strong{
  display:block;
  font-family:"Outfit", sans-serif;
  letter-spacing:.055em;
  font-size:16px;
}
.public-brand small{
  display:block;
  margin-top:2px;
  color:var(--soft);
  font-family:"Outfit", sans-serif;
  font-size:11px;
  letter-spacing:.11em;
}
.public-nav{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:7px;
  flex-wrap:wrap;
  color:var(--muted);
  font-size:13px;
}
.public-nav a{
  padding:9px 12px;
  border-radius:999px;
  transition:background .18s ease, color .18s ease, border-color .18s ease, transform .18s ease;
}
.public-nav a:hover{
  background:rgba(255,255,255,.08);
  color:var(--text);
  transform:translateY(-1px);
}
.public-login-link{
  border:1px solid rgba(159,194,255,.54);
  color:#eef5ff !important;
  background:linear-gradient(135deg, rgba(159,194,255,.22), rgba(219,199,255,.11));
  box-shadow:0 10px 30px rgba(95,140,255,.16);
}
.hero-shell{
  position:relative;
  display:grid;
  grid-template-columns:minmax(600px, 1.12fr) minmax(320px, .88fr);
  align-items:center;
  gap:44px;
  width:min(1180px, calc(100% - 36px));
  min-height:calc(100vh - 86px);
  margin:0 auto;
  padding:74px 0 66px;
}
.hero-glow{
  position:absolute;
  pointer-events:none;
  filter:blur(8px);
  border-radius:999px;
}
.hero-glow-a{
  width:300px;
  height:300px;
  left:-120px;
  top:70px;
  background:rgba(109,153,255,.18);
}
.hero-glow-b{
  width:240px;
  height:240px;
  right:8%;
  bottom:18%;
  background:rgba(219,199,255,.15);
}
.hero-copy,
.product-frame-wrap{
  position:relative;
}
.product-frame{
  position:relative;
  z-index:1;
}
.hero-kicker,
.section-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin:0 0 16px;
  color:var(--accent);
  font-family:"Outfit", sans-serif;
  font-size:12px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.kicker-dot{
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--gold);
  box-shadow:0 0 24px rgba(241,211,145,.8);
}
h1{
  margin:0;
  max-width:760px;
  font-size:clamp(42px, 5vw, 66px);
  line-height:1.12;
  letter-spacing:-.045em;
}
.hero-title-line{
  display:block;
  white-space:nowrap;
}
.hero-title-accent{
  color:transparent;
  background:linear-gradient(90deg, #ffffff, #aecaFF 48%, #e1ccff 100%);
  -webkit-background-clip:text;
  background-clip:text;
}
.hero-lead{
  margin:24px 0 0;
  max-width:670px;
  color:var(--muted);
  font-size:clamp(15px, 1.8vw, 18px);
  line-height:2;
}
.hero-actions{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:32px;
}
.btn-primary,
.btn-ghost{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:0 20px;
  border-radius:999px;
  font-weight:800;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.btn-primary{
  color:#06111f;
  background:linear-gradient(135deg, #f8fbff, #9fc2ff 58%, #d9c7ff);
  box-shadow:0 20px 48px rgba(93,144,255,.28);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 26px 62px rgba(93,144,255,.36);
}
.btn-ghost{
  border:1px solid var(--line);
  color:var(--text);
  background:rgba(255,255,255,.065);
}
.btn-ghost:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,.1);
}
.hero-proof{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:28px;
}
.hero-proof span{
  padding:7px 10px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  color:var(--soft);
  background:rgba(255,255,255,.045);
  font-family:"Outfit", sans-serif;
  font-size:12px;
}
.product-frame{
  border:1px solid rgba(255,255,255,.18);
  border-radius:22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.13), rgba(255,255,255,.055)),
    rgba(12,18,32,.88);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.product-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
  border-bottom:1px solid rgba(255,255,255,.11);
  background:rgba(255,255,255,.055);
}
.window-dots{
  display:flex;
  gap:6px;
}
.window-dots span{
  width:10px;
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.28);
}
.product-title{
  color:var(--muted);
  font-family:"Outfit", sans-serif;
  font-size:12px;
  letter-spacing:.12em;
}
.product-status{
  padding:5px 9px;
  border:1px solid rgba(157,255,210,.25);
  border-radius:999px;
  color:#bbffe0;
  background:rgba(91,255,177,.08);
  font-family:"Outfit", sans-serif;
  font-size:11px;
}
.frame-nav{
  position:absolute;
  top:50%;
  z-index:10;
  width:24px;
  height:48px;
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,.15);
  border-radius:6px;
  color:rgba(255,255,255,.45);
  background:rgba(0,0,0,.35);
  font-size:18px;
  cursor:pointer;
  transform:translateY(-50%);
  transition:color .18s, background .18s;
}
.frame-nav:hover{
  border-color:rgba(122,169,244,.46);
  background:rgba(22,35,56,.78);
  color:#e7f1ff;
}
.frame-nav-prev{
  left:6px;
}
.frame-nav-next{
  right:6px;
}

.dashboard-mock{
  display:grid;
  grid-template-columns:74px 1fr;
  min-height:440px;
}
.mock-sidebar{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
  padding:20px 12px;
  border-right:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.035);
}
.mock-logo{
  display:grid;
  place-items:center;
  width:36px;
  height:36px;
  margin-bottom:8px;
  border-radius:12px;
  background:linear-gradient(145deg, rgba(159,194,255,.35), rgba(255,255,255,.08));
  color:#fff;
  font-family:"Outfit", sans-serif;
  font-weight:800;
}
.mock-nav{
  width:38px;
  height:38px;
  border-radius:13px;
  background:rgba(255,255,255,.07);
}
.mock-nav.active{
  background:linear-gradient(145deg, rgba(159,194,255,.5), rgba(219,199,255,.22));
  box-shadow:0 12px 34px rgba(111,156,255,.2);
}
.mock-main{
  padding:18px;
}
.mock-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
}
.mock-label{
  color:var(--soft);
  font-family:"Outfit", sans-serif;
  font-size:12px;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.mock-heading{
  margin-top:4px;
  font-size:21px;
  font-weight:800;
}
.mock-pill{
  padding:8px 11px;
  border:1px solid rgba(241,211,145,.35);
  border-radius:999px;
  color:#ffe5a8;
  background:rgba(241,211,145,.09);
  font-size:12px;
  font-weight:800;
}
.metric-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
  margin-bottom:16px;
}
.metric-card{
  padding:14px;
  border:1px solid rgba(255,255,255,.11);
  border-radius:16px;
  background:rgba(255,255,255,.06);
}
.metric-card span{
  display:block;
  color:var(--soft);
  font-size:12px;
}
.metric-card strong{
  display:block;
  margin-top:7px;
  font-size:20px;
}
.mini-bar{
  height:5px;
  margin-top:12px;
  border-radius:999px;
  background:rgba(255,255,255,.1);
  overflow:hidden;
}
.mini-bar i{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg, var(--accent), var(--accent2));
}

.role-switch-radio{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.role-switch-head{
  display:grid;
  grid-template-columns:1fr;
  align-items:center;
  gap:8px;
  margin-bottom:10px;
  padding:8px 48px;
  border:1px solid rgba(74,158,255,.2);
  border-radius:12px;
  background:linear-gradient(180deg,rgba(16,26,41,.64),rgba(13,21,34,.55));
}
.role-switch-title{
  min-width:0;
  text-align:center;
}
.role-label{
  display:none;
  color:#dce9ff;
  font-family:"Outfit", sans-serif;
  font-weight:700;
  font-size:14px;
  letter-spacing:.04em;
}
.role-switch-title small{
  display:block;
  margin-top:2px;
  color:#91acd2;
  font-size:10px;
  line-height:1.35;
}
.role-arrow{
  display:none;
  place-items:center;
  width:34px;
  height:34px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  color:#84a9d8;
  background:rgba(255,255,255,.03);
  font-size:22px;
  line-height:1;
  cursor:pointer;
  transition:background .18s ease, border-color .18s ease, transform .18s ease;
}
.role-arrow:hover{
  background:rgba(255,255,255,.1);
  transform:translateY(-1px);
}
.role-mock-card{
  display:none;
}
@keyframes cardSlideIn{
  from{
    opacity:0;
    transform:translateY(20px) scale(0.96);
    filter:blur(3px);
  }
  to{
    opacity:1;
    transform:none;
    filter:blur(0);
  }
}
#mock-role-manager:checked ~ .role-switch-head .role-label-manager,
#mock-role-leader:checked ~ .role-switch-head .role-label-leader,
#mock-role-player:checked ~ .role-switch-head .role-label-player{
  display:block;
}
#mock-role-manager:checked ~ .role-switch-head .arrow-manager-prev,
#mock-role-manager:checked ~ .role-switch-head .arrow-manager-next,
#mock-role-leader:checked ~ .role-switch-head .arrow-leader-prev,
#mock-role-leader:checked ~ .role-switch-head .arrow-leader-next,
#mock-role-player:checked ~ .role-switch-head .arrow-player-prev,
#mock-role-player:checked ~ .role-switch-head .arrow-player-next{
  display:grid;
}
#mock-role-manager:checked ~ .role-mock-stack .role-mock-card.is-manager,
#mock-role-leader:checked ~ .role-mock-stack .role-mock-card.is-leader,
#mock-role-player:checked ~ .role-mock-stack .role-mock-card.is-player{
  display:block;
  animation:cardSlideIn 0.45s cubic-bezier(.22,.61,.36,1) both;
}
.todo-mock-list{
  display:flex;
  flex-direction:column;
  gap:7px;
  margin-bottom:10px;
  padding:12px;
  border:1px solid rgba(74,158,255,.2);
  border-radius:12px;
  background:linear-gradient(180deg,rgba(16,26,41,.64),rgba(13,21,34,.55));
}
.todo-mock-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border:1px solid rgba(255,255,255,.09);
  border-radius:10px;
  background:rgba(255,255,255,.03);
}
.todo-mock-icon{
  width:24px;
  height:24px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:rgba(74,158,255,.14);
  border:1px solid rgba(74,158,255,.32);
  color:#8fc1ff;
  font-size:11px;
  font-weight:800;
  flex-shrink:0;
}
.todo-mock-main strong{
  display:block;
  color:#d8e8ff;
  font-size:12px;
  font-weight:600;
  line-height:1.3;
}
.todo-mock-main span{
  display:block;
  margin-top:2px;
  color:#91acd2;
  font-size:11px;
  line-height:1.35;
}
.todo-mock-arrow{
  margin-left:auto;
  color:#84a9d8;
  font-size:12px;
  line-height:1;
}
.role-menu-chips{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  padding:10px 12px 12px;
}
.role-menu-chips span{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:0 10px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:10px;
  color:#c9d6f3;
  background:rgba(18,26,42,.7);
  font-size:11px;
  white-space:nowrap;
}

.mock-panel{
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;
  background:rgba(255,255,255,.02);
  overflow:hidden;
}
.mock-panel-head{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.mock-panel-head span{
  color:#dce9ff;
  font-size:13px;
  font-weight:600;
}
.mock-panel-head em{
  color:#8fb2de;
  font-style:normal;
  font-size:11px;
}
.mock-row{
  display:grid;
  grid-template-columns:100px 1fr 64px;
  align-items:center;
  gap:12px;
  padding:14px 16px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.mock-row:last-child{border-bottom:0}
.mock-row b{
  font-size:13px;
}
.mock-row span{
  height:8px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(159,194,255,.45), rgba(255,255,255,.08));
}
.mock-row small{
  color:var(--soft);
  text-align:right;
  font-size:11px;
}
.section-stack,
.workflow-section,
.audience-section,
.cta-band,
.public-page{
  width:min(1180px, calc(100% - 36px));
  margin:0 auto;
}
.section-stack,
.workflow-section,
.public-page{
  padding:40px 0;
}
.section-heading{
  display:block;
  max-width:840px;
  margin-bottom:28px;
}
.section-heading.compact{
  display:block;
}
.section-heading h2,
.cta-band h2,
.audience-card h2,
.public-page h1{
  margin:0;
  max-width:980px;
  font-size:clamp(26px, 3.7vw, 44px);
  line-height:1.16;
  letter-spacing:-.05em;
}
.asis-tobe-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:16px;
  margin-top:28px;
}
.reality-card{
  padding:26px;
  border:1px solid rgba(255,255,255,.13);
  border-radius:18px;
  background:
    radial-gradient(circle at 18% 0%, rgba(159,194,255,.13), transparent 34%),
    rgba(255,255,255,.055);
  box-shadow:0 20px 70px rgba(0,0,0,.22);
}
.reality-card.is-to-be{
  background:
    radial-gradient(circle at 80% 0%, rgba(219,199,255,.14), transparent 34%),
    rgba(255,255,255,.06);
}
.reality-card h3{
  margin:0 0 18px;
  font-size:clamp(22px, 2.6vw, 32px);
  line-height:1.28;
  letter-spacing:-.04em;
}
.reality-card ul{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin:0;
  padding:0;
  list-style:none;
}
.reality-card li{
  position:relative;
  padding:10px 12px 10px 34px;
  border:1px solid rgba(255,255,255,.09);
  border-radius:12px;
  background:rgba(255,255,255,.035);
  color:var(--muted);
  font-size:14px;
  line-height:1.65;
}
.reality-card li::before{
  content:"";
  position:absolute;
  left:12px;
  top:18px;
  width:8px;
  height:8px;
  border-radius:999px;
  background:rgba(159,194,255,.82);
  box-shadow:0 0 16px rgba(159,194,255,.34);
}

.feature-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:16px;
}
.feature-card{
  min-height:190px;
  padding:22px;
  border:1px solid rgba(255,255,255,.13);
  border-radius:var(--radius);
  background:
    radial-gradient(circle at 18% 0%, rgba(159,194,255,.13), transparent 34%),
    rgba(255,255,255,.06);
  box-shadow:0 20px 70px rgba(0,0,0,.24);
}
.feature-card.large{
  min-height:220px;
  background:
    radial-gradient(circle at 18% 0%, rgba(159,194,255,.13), transparent 34%),
    rgba(255,255,255,.06);
}
.feature-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:32px;
  margin-bottom:28px;
  border:1px solid rgba(159,194,255,.28);
  border-radius:999px;
  color:var(--accent);
  background:rgba(159,194,255,.08);
  font-family:"Outfit", sans-serif;
  font-weight:800;
  font-size:12px;
}
.feature-card h3{
  margin:0 0 12px;
  font-size:22px;
}
.feature-card p{
  margin:0;
  color:var(--muted);
  line-height:1.85;
  font-size:14px;
}
.workflow-rail{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
  margin-top:28px;
}
.workflow-rail article{
  position:relative;
  padding:22px;
  border:1px solid rgba(255,255,255,.13);
  border-radius:18px;
  background:rgba(255,255,255,.055);
}
.workflow-rail span{
  display:inline-grid;
  place-items:center;
  width:32px;
  height:32px;
  margin-bottom:18px;
  border-radius:999px;
  color:#07111f;
  background:linear-gradient(135deg, #ffffff, var(--accent));
  font-family:"Outfit", sans-serif;
  font-weight:900;
}
.workflow-rail h3{
  margin:0 0 10px;
  font-size:17px;
}
.workflow-rail p{
  margin:0;
  color:var(--muted);
  line-height:1.75;
  font-size:13px;
}
.assign-auto-section{
  width:min(100% - 40px, 1180px);
  margin:0 auto;
  padding:22px 0 70px;
}
.assign-auto-layout{
  display:grid;
  grid-template-columns:minmax(0, .92fr) minmax(360px, 1.08fr);
  gap:18px;
  align-items:stretch;
  margin-top:28px;
}
.assign-auto-copy,
.assign-auto-visual{
  border:1px solid rgba(255,255,255,.13);
  border-radius:18px;
  background:radial-gradient(circle at 18% 0%, rgba(159,194,255,.13), transparent 34%), rgba(255,255,255,.055);
  box-shadow:0 20px 70px rgba(0,0,0,.22);
}
.assign-auto-copy{padding:26px}
.assign-auto-lead{
  margin:0 0 18px;
  color:var(--text);
  font-size:clamp(20px, 2.2vw, 28px);
  font-weight:800;
  line-height:1.35;
  letter-spacing:-.04em;
}
.assign-factor-list{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 18px}
.assign-factor-list span{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:0 10px;
  border:1px solid rgba(159,194,255,.22);
  border-radius:999px;
  color:#cfe0ff;
  background:rgba(159,194,255,.07);
  font-size:12px;
}
.assign-auto-copy p{margin:0;color:var(--muted);line-height:1.9;font-size:14px}
.assign-auto-copy p + p{margin-top:16px}
.assign-manual-callout{
  margin-top:20px;
  padding:14px 16px;
  border:1px solid rgba(159,194,255,.22);
  border-radius:14px;
  background:linear-gradient(180deg,rgba(74,158,255,.12),rgba(255,255,255,.045));
}
.assign-manual-callout strong{display:block;color:#e8f2ff;font-size:15px}
.assign-manual-callout span{display:block;margin-top:6px;color:var(--muted);font-size:13px;line-height:1.65}
.assign-auto-visual{
  position:relative;
  overflow:hidden;
  padding:20px;
  background:radial-gradient(circle at 80% 0%, rgba(219,199,255,.16), transparent 36%), rgba(255,255,255,.052);
}
.assign-auto-visual::before{
  content:"";
  position:absolute;
  inset:20px;
  border:1px dashed rgba(159,194,255,.16);
  border-radius:16px;
  pointer-events:none;
}
.assign-visual-inputs{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:12px}
.assign-visual-inputs div{padding:10px;border:1px solid rgba(255,255,255,.11);border-radius:12px;background:rgba(255,255,255,.045)}
.assign-visual-inputs span,
.assign-candidate-card span{display:block;margin-bottom:4px;color:var(--soft);font-family:"Outfit",sans-serif;font-size:10px;letter-spacing:.08em;text-transform:uppercase}
.assign-visual-inputs strong{display:block;color:var(--text);font-size:12px;line-height:1.35}
.assign-solver-core{
  position:relative;
  z-index:1;
  margin:0 auto 12px;
  padding:16px;
  border:1px solid rgba(159,194,255,.25);
  border-radius:16px;
  background:linear-gradient(135deg,rgba(74,158,255,.16),rgba(219,199,255,.08));
  text-align:center;
  box-shadow:0 16px 44px rgba(0,0,0,.22);
}
.assign-solver-core span{display:block;margin-bottom:6px;color:#9fc2ff;font-family:"Outfit",sans-serif;font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.assign-solver-core strong{display:block;color:#f2f6ff;font-size:16px;line-height:1.45}
.assign-solver-core small{display:block;margin-top:5px;color:var(--muted);font-size:12px}
.assign-candidate-board{position:relative;z-index:1;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.assign-candidate-card{padding:13px;border:1px solid rgba(74,158,255,.22);border-radius:14px;background:linear-gradient(180deg,rgba(16,26,41,.72),rgba(13,21,34,.62))}
.assign-candidate-card strong{display:block;color:#e5efff;font-size:15px;line-height:1.35}
.assign-candidate-card small{display:block;margin-top:5px;color:var(--muted);font-size:12px;line-height:1.5}
.assign-output-band{position:relative;z-index:1;margin-top:12px;padding:14px 16px;border:1px solid rgba(255,255,255,.13);border-radius:14px;background:rgba(255,255,255,.06)}
.assign-output-band strong{display:block;color:#f4f7ff;font-size:15px}
.assign-output-band span{display:block;margin-top:5px;color:var(--muted);font-size:12px;line-height:1.55}

.assign-mock-window{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  gap:12px;
  min-height:100%;
}
.assign-mock-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:14px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  background:rgba(255,255,255,.055);
}
.assign-mock-top span,
.assign-mock-side span{
  display:block;
  color:var(--soft);
  font-family:"Outfit",sans-serif;
  font-size:10px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.assign-mock-top strong{
  display:block;
  margin-top:4px;
  color:#f2f6ff;
  font-size:17px;
  line-height:1.35;
}
.assign-mock-top em{
  flex:0 0 auto;
  padding:5px 8px;
  border:1px solid rgba(159,194,255,.22);
  border-radius:999px;
  color:#bcd5ff;
  background:rgba(159,194,255,.07);
  font-family:"Outfit",sans-serif;
  font-size:10px;
  font-style:normal;
}
.assign-mock-tabs{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
}
.assign-mock-tabs span{
  min-width:0;
  padding:10px 9px;
  border:1px solid rgba(255,255,255,.11);
  border-radius:12px;
  background:rgba(255,255,255,.045);
}
.assign-mock-tabs span.is-active{
  border-color:rgba(126,190,255,.62);
  background:linear-gradient(180deg,rgba(74,158,255,.22),rgba(18,31,52,.78));
  box-shadow:0 0 0 1px rgba(108,168,255,.18),0 12px 28px rgba(16,38,68,.28);
}
.assign-mock-tabs strong{
  display:block;
  color:#f4f8ff;
  font-family:"Outfit",sans-serif;
  font-size:15px;
}
.assign-mock-tabs small{
  display:block;
  margin-top:4px;
  color:var(--muted);
  font-size:11px;
  line-height:1.25;
}
.assign-mock-body{
  display:grid;
  grid-template-columns:minmax(0,1fr) 150px;
  gap:10px;
  align-items:stretch;
}
.assign-mock-table,
.assign-mock-side{
  border:1px solid rgba(255,255,255,.11);
  border-radius:14px;
  background:rgba(255,255,255,.043);
  overflow:hidden;
}
.assign-mock-row{
  display:grid;
  grid-template-columns:1fr .8fr .85fr 58px;
  gap:8px;
  align-items:center;
  padding:10px 12px;
  border-bottom:1px solid rgba(255,255,255,.075);
  color:#dce8ff;
  font-size:12px;
}
.assign-mock-row:last-child{border-bottom:0}
.assign-mock-row.is-head{
  color:var(--soft);
  background:rgba(255,255,255,.035);
  font-size:10px;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.assign-mock-row strong{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:24px;
  border-radius:999px;
  font-size:11px;
}
.assign-mock-row strong.is-first{color:#bdeecf;background:rgba(100,200,130,.13);border:1px solid rgba(100,200,130,.35)}
.assign-mock-row strong.is-second{color:#f4ddab;background:rgba(228,180,89,.13);border:1px solid rgba(228,180,89,.34)}
.assign-mock-row strong.is-adjust{color:#cfe0ff;background:rgba(74,158,255,.13);border:1px solid rgba(74,158,255,.34)}
.assign-mock-side{
  display:grid;
  gap:0;
}
.assign-mock-side div{
  padding:12px;
  border-bottom:1px solid rgba(255,255,255,.075);
}
.assign-mock-side div:last-child{border-bottom:0}
.assign-mock-side strong{
  display:block;
  margin-top:5px;
  color:#e4efff;
  font-size:12px;
  line-height:1.4;
}
.assign-mock-footer{
  margin-top:auto;
  padding:14px 16px;
  border:1px solid rgba(159,194,255,.22);
  border-radius:14px;
  background:linear-gradient(180deg,rgba(74,158,255,.12),rgba(255,255,255,.045));
}
.assign-mock-footer strong{
  display:block;
  color:#f4f7ff;
  font-size:15px;
}
.assign-mock-footer span{
  display:block;
  margin-top:5px;
  color:var(--muted);
  font-size:12px;
  line-height:1.55;
}


.assign-option-summary{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
}
.assign-option-summary div{
  min-width:0;
  padding:12px;
  border:1px solid rgba(74,158,255,.22);
  border-radius:12px;
  background:linear-gradient(180deg,rgba(16,26,41,.72),rgba(13,21,34,.62));
}
.assign-option-summary span{
  display:block;
  margin-bottom:5px;
  color:var(--soft);
  font-family:"Outfit",sans-serif;
  font-size:10px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.assign-option-summary strong{
  display:block;
  color:#f4f8ff;
  font-size:13px;
  line-height:1.35;
}
.assign-option-summary small{
  display:block;
  margin-top:5px;
  color:var(--muted);
  font-size:11px;
  line-height:1.45;
}
.assign-diff-table{
  border:1px solid rgba(255,255,255,.11);
  border-radius:14px;
  background:rgba(255,255,255,.043);
  overflow:hidden;
}
.assign-diff-row{
  display:grid;
  grid-template-columns:1.35fr .95fr .95fr .95fr;
  gap:8px;
  align-items:center;
  padding:10px 12px;
  border-bottom:1px solid rgba(255,255,255,.075);
  color:#dce8ff;
  font-size:12px;
}
.assign-diff-row:last-child{
  border-bottom:0;
}
.assign-diff-row.is-head{
  color:var(--soft);
  background:rgba(255,255,255,.035);
  font-size:10px;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.assign-diff-row strong{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:24px;
  padding:0 8px;
  border:1px solid rgba(159,194,255,.24);
  border-radius:999px;
  color:#e5efff;
  background:rgba(159,194,255,.08);
  font-size:11px;
  white-space:nowrap;
}


.assign-plan-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.assign-plan-card{
  min-width:0;
  padding:12px;
  border:1px solid rgba(74,158,255,.2);
  border-radius:14px;
  background:linear-gradient(180deg,rgba(16,26,41,.72),rgba(13,21,34,.62));
}
.assign-plan-card.is-balanced{
  border-color:rgba(159,194,255,.34);
  background:linear-gradient(180deg,rgba(74,158,255,.16),rgba(13,21,34,.62));
}
.assign-plan-card.is-even{
  border-color:rgba(219,199,255,.3);
  background:linear-gradient(180deg,rgba(138,110,220,.14),rgba(13,21,34,.62));
}
.assign-plan-head span{
  display:block;
  margin-bottom:5px;
  color:var(--soft);
  font-family:"Outfit",sans-serif;
  font-size:10px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.assign-plan-head strong{
  display:block;
  color:#f4f8ff;
  font-size:14px;
  line-height:1.35;
}
.assign-plan-head small{
  display:block;
  margin-top:5px;
  color:var(--muted);
  font-size:11px;
  line-height:1.45;
}
.assign-plan-rows{
  display:grid;
  gap:7px;
  margin-top:10px;
}
.assign-plan-rows div{
  padding:9px 10px;
  border:1px solid rgba(255,255,255,.09);
  border-radius:10px;
  background:rgba(255,255,255,.04);
}
.assign-plan-rows span{
  display:block;
  color:var(--soft);
  font-family:"Outfit",sans-serif;
  font-size:10px;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.assign-plan-rows strong{
  display:block;
  margin-top:4px;
  color:#dce8ff;
  font-size:12px;
  line-height:1.45;
}


.logistics-section{
  width:min(100% - 40px,1180px);
  margin:0 auto;
  padding:22px 0 70px;
}
.logistics-layout{
  display:grid;
  grid-template-columns:minmax(0,.92fr) minmax(360px,1.08fr);
  gap:18px;
  align-items:stretch;
  margin-top:28px;
}
.logistics-copy,
.logistics-visual{
  border:1px solid rgba(255,255,255,.13);
  border-radius:18px;
  background:radial-gradient(circle at 18% 0%, rgba(159,194,255,.13), transparent 34%), rgba(255,255,255,.055);
  box-shadow:0 20px 70px rgba(0,0,0,.22);
}
.logistics-copy{
  padding:26px;
}
.logistics-lead{
  margin:0 0 18px;
  color:var(--text);
  font-size:clamp(20px,2.2vw,28px);
  font-weight:800;
  line-height:1.35;
  letter-spacing:-.04em;
}
.logistics-copy p{
  margin:0;
  color:var(--muted);
  line-height:1.9;
  font-size:14px;
}
.logistics-copy p+p{
  margin-top:16px;
}
.logistics-visual{
  padding:20px;
  background:radial-gradient(circle at 80% 0%, rgba(219,199,255,.14), transparent 34%), rgba(255,255,255,.052);
}
.logistics-screen{
  display:grid;
  gap:12px;
}
.logistics-screen-head,
.logistics-ledger-head{
  padding:14px;
  border:1px solid rgba(255,255,255,.11);
  border-radius:14px;
  background:rgba(255,255,255,.045);
}
.logistics-screen-head span,
.logistics-ledger-head span,
.logistics-chip span{
  display:block;
  color:var(--soft);
  font-family:"Outfit",sans-serif;
  font-size:10px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.logistics-screen-head strong,
.logistics-ledger-head strong{
  display:block;
  margin-top:4px;
  color:#f2f6ff;
  font-size:16px;
}
.logistics-chip-board{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.logistics-chip{
  min-width:0;
  padding:12px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  background:rgba(255,255,255,.045);
}
.logistics-chip strong{
  display:block;
  margin-top:5px;
  color:#f4f8ff;
  font-size:15px;
  line-height:1.35;
}
.logistics-chip small{
  display:block;
  margin-top:5px;
  color:var(--muted);
  font-size:11px;
  line-height:1.45;
}
.logistics-chip.is-need{
  border-color:rgba(235,90,90,.45);
  background:linear-gradient(180deg,rgba(221,65,65,.16),rgba(255,255,255,.04));
}
.logistics-chip.is-rented{
  border-color:rgba(228,180,89,.42);
  background:linear-gradient(180deg,rgba(228,180,89,.14),rgba(255,255,255,.04));
}
.logistics-chip.is-bring{
  border-color:rgba(107,191,95,.45);
  background:linear-gradient(180deg,rgba(76,155,68,.18),rgba(255,255,255,.04));
}
.logistics-chip.is-unused{
  border-color:rgba(162,174,190,.36);
  background:linear-gradient(180deg,rgba(132,146,162,.16),rgba(255,255,255,.035));
}
.logistics-flow-note{
  display:grid;
  place-items:center;
  min-height:30px;
  color:var(--soft);
  font-size:12px;
}
.logistics-ledger{
  display:grid;
  gap:8px;
  padding:14px;
  border:1px solid rgba(255,255,255,.11);
  border-radius:14px;
  background:rgba(255,255,255,.045);
}
.logistics-ledger-row{
  display:grid;
  grid-template-columns:1fr .8fr .8fr;
  gap:8px;
  align-items:center;
  padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,.075);
  color:#dce8ff;
  font-size:12px;
}
.logistics-ledger-row strong{
  text-align:right;
  color:#f2f6ff;
}
.logistics-total{
  display:grid;
  gap:6px;
  margin-top:6px;
}
.logistics-total div{
  display:flex;
  justify-content:space-between;
  gap:12px;
  color:var(--muted);
  font-size:12px;
}
.logistics-total strong{
  color:#f2f6ff;
}
.logistics-total .is-grand{
  padding-top:7px;
  border-top:1px solid rgba(255,255,255,.12);
  color:#e8f2ff;
  font-weight:800;
}

.role-term-list{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
  margin:24px 0 28px;
}
.role-term-list div{
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.11);
  border-radius:14px;
  background:rgba(255,255,255,.045);
}
.role-term-list strong{
  display:block;
  margin-bottom:4px;
  color:var(--text);
  font-family:"Outfit", sans-serif;
  font-size:13px;
  letter-spacing:.04em;
}
.role-term-list span{
  display:block;
  color:var(--muted);
  font-size:12px;
  line-height:1.55;
}
.role-view-section{
  width:min(100% - 40px, 1180px);
  margin:0 auto;
  padding:22px 0 70px;
}
.role-view-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
}
.role-view-card{
  padding:22px;
  border:1px solid rgba(255,255,255,.13);
  border-radius:18px;
  background:
    radial-gradient(circle at 18% 0%, rgba(159,194,255,.13), transparent 34%),
    rgba(255,255,255,.055);
  box-shadow:0 20px 70px rgba(0,0,0,.22);
}
.role-view-card h3{
  margin:0 0 10px;
  font-size:22px;
  line-height:1.35;
}
.role-view-card > p:not(.section-kicker){
  margin:0;
  color:var(--muted);
  line-height:1.75;
  font-size:14px;
}
.role-view-panel{
  margin-top:18px;
  border:1px solid rgba(74,158,255,.2);
  border-radius:12px;
  background:linear-gradient(180deg,rgba(16,26,41,.64),rgba(13,21,34,.55));
  overflow:hidden;
}
.role-view-panel-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  border-bottom:1px solid rgba(255,255,255,.08);
  color:#dce9ff;
  font-size:13px;
  font-weight:700;
}
.role-view-panel-head span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:24px;
  padding:0 8px;
  border-radius:999px;
  color:#e8c16b;
  background:rgba(228,180,89,.15);
  font-size:11px;
}
.role-view-panel ul{
  display:flex;
  flex-direction:column;
  gap:7px;
  margin:0;
  padding:10px 12px 12px;
  list-style:none;
}
.role-view-panel li{
  padding:8px 10px;
  border:1px solid rgba(255,255,255,.09);
  border-radius:10px;
  background:rgba(255,255,255,.03);
  color:#d8e8ff;
  font-size:12px;
  line-height:1.35;
}

.audience-section{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  padding:28px 0 70px;
}
.audience-card{
  padding:30px;
  border:1px solid rgba(255,255,255,.13);
  border-radius:22px;
  background:
    radial-gradient(circle at 20% 10%, rgba(159,194,255,.16), transparent 38%),
    rgba(255,255,255,.065);
}
.audience-card.muted{
  background:
    radial-gradient(circle at 80% 20%, rgba(219,199,255,.14), transparent 34%),
    rgba(255,255,255,.048);
}
.audience-card p:not(.section-kicker),
.cta-band p,
.public-page > p{
  margin:18px 0 0;
  color:var(--muted);
  line-height:1.9;
}
.cta-band h2{
  font-size:clamp(20px, 2.2vw, 28px);
  letter-spacing:-.03em;
}
.cta-band{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  margin-bottom:44px;
  padding:34px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:22px;
  background:
    linear-gradient(135deg, rgba(159,194,255,.16), rgba(219,199,255,.08)),
    rgba(255,255,255,.07);
  box-shadow:0 24px 90px rgba(0,0,0,.28);
}
.public-page{
  padding:72px 0;
}
.public-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
  margin-top:28px;
}
.public-card,
.public-policy-box{
  border:1px solid rgba(255,255,255,.13);
  border-radius:16px;
  background:rgba(255,255,255,.06);
}
.public-card{
  padding:24px;
}
.public-card h2,
.public-card h3,
.public-policy-box h2{
  margin:0 0 10px;
  font-size:18px;
}
.public-card p,
.public-policy-box p{
  margin:0;
  color:var(--muted);
  line-height:1.85;
  font-size:14px;
}
.public-policy-box{
  display:grid;
  gap:18px;
  margin-top:28px;
  padding:26px;
}
.public-footer{
  display:flex;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  padding:26px clamp(18px, 4vw, 56px);
  border-top:1px solid rgba(255,255,255,.09);
  color:var(--soft);
  font-size:12px;
}
.public-footer-links{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}
.public-footer a:hover{
  color:var(--text);
}
@media (max-width: 980px){
  .hero-shell{
    grid-template-columns:1fr;
    min-height:0;
    padding-top:54px;
  }
  .product-frame{
    max-width:720px;
  }
  .feature-grid{
    grid-template-columns:1fr 1fr;
  }
  .feature-card.large{
    grid-column:auto;
    min-height:220px;
  }
  .workflow-rail{
    grid-template-columns:1fr 1fr;
  }
  .assign-auto-layout{
    grid-template-columns:1fr;
  }
}
@media (max-width: 720px){
  .public-header{
    position:static;
    align-items:flex-start;
    flex-direction:column;
  }
  .public-nav{
    justify-content:flex-start;
  }
  .hero-shell{
    width:min(100% - 28px, 1180px);
    padding:40px 0 48px;
  }
  h1{
    font-size:clamp(38px, 11.5vw, 58px);
  }
  .hero-title-line{
    white-space:normal;
  }
  .hero-lead{
    font-size:15px;
  }
  .dashboard-mock{
    grid-template-columns:1fr;
    min-height:0;
  }
  .mock-sidebar{
    display:none;
  }
  .mock-main{
    padding:16px;
  }
  .asis-tobe-grid{
    grid-template-columns:1fr;
  }
  .reality-card{
    padding:20px;
  }
  .reality-card li{
    padding:9px 10px 9px 30px;
    font-size:13px;
  }

  .metric-grid,
  .feature-grid,
  .workflow-rail,
  .audience-section,
  .public-grid{
    grid-template-columns:1fr;
  }
  .feature-card.large{
    grid-column:auto;
  }
  .mock-row{
    grid-template-columns:86px 1fr 58px;
  }
  .section-heading{
    display:block;
  }
  .section-stack,
  .workflow-section,
  .public-page{
    width:min(100% - 28px, 1180px);
    padding:48px 0;
  }
  .audience-section{
    width:min(100% - 28px, 1180px);
    padding:18px 0 48px;
  }
  /* LP role mobile layout fix v1 */
  .assign-auto-section{
    width:min(100% - 28px, 1180px);
    padding:18px 0 48px;
  }
  .assign-auto-layout{
    gap:14px;
    margin-top:20px;
  }
  .assign-auto-copy,
  .assign-auto-visual{
    padding:20px;
  }
  .assign-candidate-board{
    grid-template-columns:1fr;
  }

  .role-view-section{
    width:min(100% - 28px, 1180px);
    padding:18px 0 48px;
  }
  .role-term-list,
  .role-view-grid{
    grid-template-columns:1fr;
  }
  .role-term-list{
    margin:18px 0 20px;
  }
  .role-view-card{
    padding:20px;
  }
  .role-view-card h3{
    font-size:21px;
  }
  .role-view-panel li{
    display:block;
    overflow-wrap:anywhere;
  }

  .cta-band{
    align-items:flex-start;
    flex-direction:column;
    width:min(100% - 28px, 1180px);
    padding:26px;
  }
}

/* LP assign auto visual mobile fix v3 */
@media (max-width: 720px){
  .assign-auto-lead{
    font-size:22px;
  }
  .assign-visual-inputs,
  .assign-candidate-board{
    grid-template-columns:1fr;
  }
}

/* LP assign mock visual mobile v1 */
@media (max-width: 720px){
  .assign-mock-tabs{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .assign-mock-body{
    grid-template-columns:1fr;
  }
  .assign-mock-row{
    grid-template-columns:1fr .85fr;
  }
  .assign-mock-row.is-head{
    display:none;
  }
}

/* LP assign exact sample mobile v1 */
@media (max-width: 720px){
  .assign-option-summary{
    grid-template-columns:1fr;
  }
  .assign-diff-row{
    grid-template-columns:1fr;
    gap:6px;
  }
  .assign-diff-row.is-head{
    display:none;
  }
  .assign-diff-row strong{
    justify-content:flex-start;
  }
}

/* LP assign grouped cards mobile v1 */
@media (max-width: 720px){
  .assign-plan-grid{
    grid-template-columns:1fr;
  }
}

/* LP logistics mobile v1 */
@media (max-width: 980px){
  .logistics-layout{
    grid-template-columns:1fr;
  }
}
@media (max-width: 720px){
  .logistics-section{
    width:min(100% - 28px,1180px);
    padding:18px 0 48px;
  }
  .logistics-chip-board{
    grid-template-columns:1fr;
  }
  .logistics-ledger-row{
    grid-template-columns:1fr .8fr;
  }
}

/* LP logistics actual screen v2 */
.logistics-real-screen{
  display:grid;
  gap:12px;
}
.logistics-real-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:14px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  background:rgba(255,255,255,.055);
}
.logistics-real-head span,
.logistics-real-section-title,
.logistics-real-chip span,
.logistics-real-ledger-head span{
  display:block;
  color:var(--soft);
  font-family:"Outfit",sans-serif;
  font-size:10px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.logistics-real-head strong{
  display:block;
  margin-top:4px;
  color:#f2f6ff;
  font-size:16px;
  line-height:1.35;
}
.logistics-real-head em{
  flex:0 0 auto;
  padding:5px 8px;
  border:1px solid rgba(159,194,255,.22);
  border-radius:999px;
  color:#bcd5ff;
  background:rgba(159,194,255,.07);
  font-family:"Outfit",sans-serif;
  font-size:10px;
  font-style:normal;
}
.logistics-real-section-title{
  padding:0 2px;
}
.logistics-real-song-card{
  padding:14px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  background:linear-gradient(180deg,rgba(18,29,48,.72),rgba(12,20,34,.62));
}
.logistics-real-song-title{
  margin-bottom:10px;
  color:#f4f8ff;
  font-weight:800;
  font-size:15px;
}
.logistics-real-chip-zone{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.logistics-real-chip{
  min-width:132px;
  flex:1 1 132px;
  padding:10px 11px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  background:rgba(255,255,255,.045);
}
.logistics-real-chip strong{
  display:block;
  margin-top:3px;
  color:#f5f8ff;
  font-size:13px;
  line-height:1.3;
}
.logistics-real-chip small{
  display:block;
  margin-top:3px;
  color:var(--muted);
  font-size:10px;
  line-height:1.35;
}
.logistics-real-chip.is-need{
  border-color:rgba(235,90,90,.5);
  background:linear-gradient(180deg,rgba(221,65,65,.2),rgba(35,18,24,.55));
}
.logistics-real-chip.is-rented{
  border-color:rgba(228,180,89,.48);
  background:linear-gradient(180deg,rgba(228,180,89,.18),rgba(38,30,18,.55));
}
.logistics-real-chip.is-bring{
  border-color:rgba(107,191,95,.5);
  background:linear-gradient(180deg,rgba(76,155,68,.2),rgba(20,34,24,.55));
}
.logistics-real-chip.is-unused{
  border-color:rgba(162,174,190,.38);
  background:linear-gradient(180deg,rgba(132,146,162,.16),rgba(22,28,36,.52));
}
.logistics-real-split{
  height:1px;
  margin:12px 0;
  background:rgba(255,255,255,.11);
}
.logistics-real-player-zone{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.logistics-real-player-zone span{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:0 10px;
  border:1px solid rgba(159,194,255,.22);
  border-radius:999px;
  color:#cfe0ff;
  background:rgba(159,194,255,.07);
  font-size:12px;
}
.logistics-real-flow{
  display:grid;
  place-items:center;
  min-height:30px;
  color:var(--soft);
  font-size:12px;
}
.logistics-real-ledger{
  display:grid;
  gap:8px;
  padding:14px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  background:rgba(255,255,255,.045);
}
.logistics-real-ledger-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding-bottom:8px;
  border-bottom:1px solid rgba(255,255,255,.09);
}
.logistics-real-ledger-head strong{
  color:#f2f6ff;
  font-size:14px;
}
.logistics-real-ledger-row{
  display:grid;
  grid-template-columns:1fr .7fr .8fr;
  gap:8px;
  align-items:center;
  padding:7px 0;
  border-bottom:1px solid rgba(255,255,255,.075);
  color:#dce8ff;
  font-size:12px;
}
.logistics-real-ledger-row strong{
  text-align:right;
  color:#f2f6ff;
}
.logistics-real-total{
  display:grid;
  gap:6px;
  margin-top:4px;
}
.logistics-real-total div{
  display:flex;
  justify-content:space-between;
  gap:12px;
  color:var(--muted);
  font-size:12px;
}
.logistics-real-total strong{
  color:#f2f6ff;
}
.logistics-real-total .is-grand{
  padding-top:7px;
  border-top:1px solid rgba(255,255,255,.12);
  color:#e8f2ff;
  font-weight:800;
}
@media (max-width: 720px){
  .logistics-real-chip{
    flex-basis:100%;
  }
  .logistics-real-ledger-row{
    grid-template-columns:1fr .8fr;
  }
}

/* LP carry chip mock v3 */
.carry-mock-screen{
  display:grid;
  gap:12px;
}
.carry-mock-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:14px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  background:rgba(255,255,255,.055);
}
.carry-mock-head span,
.carry-rental-head span{
  display:block;
  color:var(--soft);
  font-family:"Outfit",sans-serif;
  font-size:10px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.carry-mock-head strong{
  display:block;
  margin-top:4px;
  color:#f2f6ff;
  font-size:16px;
  line-height:1.35;
}
.carry-mock-head em{
  flex:0 0 auto;
  padding:5px 8px;
  border:1px solid rgba(159,194,255,.22);
  border-radius:999px;
  color:#bcd5ff;
  background:rgba(159,194,255,.07);
  font-family:"Outfit",sans-serif;
  font-size:10px;
  font-style:normal;
}
.carry-mock-filter{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
}
.carry-mock-filter span{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:0 10px;
  border:1px solid rgba(159,194,255,.22);
  border-radius:999px;
  color:#cfe0ff;
  background:rgba(159,194,255,.07);
  font-size:11px;
}
.carry-song-card{
  padding:14px;
  border:1px solid rgba(255,255,255,.11);
  border-radius:16px;
  background:linear-gradient(180deg,rgba(24,31,42,.78),rgba(14,20,30,.7));
}
.carry-song-title{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  margin-bottom:10px;
  padding:0 12px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:10px;
  color:#f3f6ff;
  background:rgba(255,255,255,.06);
  font-size:15px;
  font-weight:800;
}
.carry-chip-zone{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.carry-chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  min-height:34px;
  max-width:100%;
  padding:0 12px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:999px;
  background:rgba(255,255,255,.045);
  color:#eef4ff;
  font-size:13px;
  line-height:1;
}
.carry-chip strong{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-size:13px;
}
.carry-chip span{
  flex:0 0 auto;
  color:rgba(242,246,255,.86);
  font-size:12px;
}
.carry-chip b{
  display:inline-grid;
  place-items:center;
  width:17px;
  height:17px;
  margin:0 1px;
  border-radius:999px;
  color:#7b2d2d;
  background:rgba(255,245,235,.9);
  font-size:11px;
  line-height:1;
}
.carry-chip.is-bring{
  border-color:rgba(98,210,122,.55);
  background:linear-gradient(180deg,rgba(57,138,69,.8),rgba(35,94,47,.84));
  box-shadow:inset 0 0 0 1px rgba(180,255,190,.12);
}
.carry-chip.is-need{
  border-color:rgba(235,105,115,.55);
  background:linear-gradient(180deg,rgba(87,40,52,.78),rgba(55,29,38,.8));
}
.carry-chip.is-rented{
  border-color:rgba(228,180,89,.52);
  background:linear-gradient(180deg,rgba(83,66,35,.76),rgba(50,41,28,.82));
}
.carry-chip.is-unused{
  border-color:rgba(135,165,190,.46);
  background:linear-gradient(180deg,rgba(50,67,82,.75),rgba(34,45,56,.8));
  color:#cfdaea;
}
.carry-split{
  height:1px;
  margin:12px 0;
  background:rgba(110,166,220,.45);
}
.carry-rental-mini{
  display:grid;
  gap:8px;
  padding:14px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  background:linear-gradient(180deg,rgba(27,36,55,.76),rgba(16,25,41,.72));
}
.carry-rental-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding-bottom:8px;
  border-bottom:1px solid rgba(255,255,255,.09);
}
.carry-rental-head strong{
  color:#f2f6ff;
  font-size:14px;
}
.carry-rental-row{
  display:grid;
  grid-template-columns:1fr .7fr .8fr;
  gap:8px;
  align-items:center;
  padding:7px 0;
  border-bottom:1px solid rgba(255,255,255,.075);
  color:#dce8ff;
  font-size:12px;
}
.carry-rental-row strong{
  text-align:right;
  color:#f2f6ff;
}
.carry-total{
  display:grid;
  gap:6px;
  margin-top:4px;
}
.carry-total div{
  display:flex;
  justify-content:space-between;
  gap:12px;
  color:var(--muted);
  font-size:12px;
}
.carry-total strong{
  color:#f2f6ff;
}
.carry-total .is-grand{
  padding-top:7px;
  border-top:1px solid rgba(255,255,255,.12);
  color:#e8f2ff;
  font-weight:800;
}
@media (max-width:720px){
  .carry-chip{
    max-width:100%;
  }
  .carry-rental-row{
    grid-template-columns:1fr .8fr;
  }
}

/* LP carry fill meter v1 */
.carry-meter-legend{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
}
.carry-meter-legend span{
  display:inline-flex;
  align-items:center;
  min-height:24px;
  padding:0 9px;
  border:1px solid rgba(255,255,255,.11);
  border-radius:999px;
  color:var(--soft);
  background:rgba(255,255,255,.04);
  font-size:10px;
}
.carry-chip.has-fill{
  position:relative;
  overflow:hidden;
}
.carry-chip.has-fill::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:var(--fill,0%);
  border-radius:999px;
  background:rgba(255,255,255,.16);
  pointer-events:none;
}
.carry-chip.has-fill strong,
.carry-chip.has-fill span{
  position:relative;
  z-index:1;
}
.carry-chip.is-partial{
  border-color:rgba(228,180,89,.58);
  background:linear-gradient(180deg,rgba(112,80,36,.78),rgba(58,45,29,.84));
}
.carry-chip.is-partial::before{
  background:rgba(228,180,89,.22);
}
.carry-chip.is-bring::before{
  background:rgba(165,255,177,.2);
}
.carry-chip.is-rented::before{
  background:rgba(228,180,89,.18);
}
.carry-chip.is-need::before{
  background:rgba(255,120,130,.16);
}

/* Public header mobile single-row v1 */
@media (max-width: 720px){
  .public-header{
    position:sticky;
    align-items:center;
    flex-direction:row;
    gap:10px;
    padding:10px 14px;
  }
  .public-brand{
    flex:0 0 auto;
    gap:8px;
    max-width:44vw;
  }
  .public-brand-mark{
    width:34px;
    height:34px;
    border-radius:11px;
  }
  .public-brand strong{
    font-size:13px;
    letter-spacing:.035em;
    white-space:nowrap;
  }
  .public-brand small{
    display:none;
  }
  .public-nav{
    flex:1 1 auto;
    min-width:0;
    justify-content:flex-start;
    flex-wrap:nowrap;
    gap:6px;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    white-space:nowrap;
  }
  .public-nav::-webkit-scrollbar{
    display:none;
  }
  .public-nav a{
    flex:0 0 auto;
    padding:8px 10px;
    font-size:12px;
  }
}

/* Public header mobile login-only v2 */
@media (max-width: 720px){
  .public-header{
    position:sticky;
    align-items:center;
    flex-direction:row;
    justify-content:space-between;
    gap:10px;
    padding:10px 14px;
  }
  .public-brand{
    flex:1 1 auto;
    min-width:0;
    max-width:none;
    gap:8px;
  }
  .public-brand-mark{
    width:34px;
    height:34px;
    border-radius:11px;
    flex:0 0 auto;
  }
  .public-brand strong{
    display:block;
    max-width:calc(100vw - 170px);
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    font-size:13px;
    letter-spacing:.035em;
  }
  .public-brand small{
    display:none;
  }
  .public-nav{
    flex:0 0 auto;
    min-width:auto;
    display:flex;
    justify-content:flex-end;
    overflow:visible;
    gap:0;
    white-space:nowrap;
  }
  .public-nav a{
    display:none;
  }
  .public-nav .public-login-link{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:34px;
    padding:0 12px;
    font-size:12px;
  }
}

/* Public header mobile hamburger v4 */
.public-menu-toggle{
  display:none;
}
@media (max-width: 720px){
  .public-header{
    position:sticky;
    align-items:center;
    flex-direction:row;
    justify-content:space-between;
    gap:10px;
    padding:10px 14px;
  }
  .public-brand{
    flex:1 1 auto;
    min-width:0;
    max-width:none;
    gap:8px;
  }
  .public-brand-mark{
    width:34px;
    height:34px;
    border-radius:11px;
    flex:0 0 auto;
  }
  .public-brand strong{
    display:block;
    max-width:calc(100vw - 104px);
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    font-size:13px;
    letter-spacing:.035em;
  }
  .public-brand small{
    display:none;
  }
  .public-menu-toggle{
    flex:0 0 auto;
    display:grid;
    place-items:center;
    gap:4px;
    width:38px;
    height:38px;
    border:1px solid rgba(159,194,255,.42);
    border-radius:12px;
    color:#eef5ff;
    background:linear-gradient(135deg, rgba(159,194,255,.16), rgba(219,199,255,.08));
    box-shadow:0 10px 30px rgba(95,140,255,.12);
  }
  .public-menu-toggle span{
    display:block;
    width:17px;
    height:2px;
    border-radius:999px;
    background:#eef5ff;
  }
  .public-nav{
    position:absolute;
    top:calc(100% + 8px);
    right:14px;
    left:14px;
    z-index:40;
    display:none;
    grid-template-columns:1fr;
    gap:6px;
    min-width:0;
    padding:10px;
    border:1px solid rgba(255,255,255,.13);
    border-radius:16px;
    background:rgba(9,13,24,.96);
    box-shadow:0 22px 70px rgba(0,0,0,.38);
    backdrop-filter:blur(18px);
    overflow:visible;
    white-space:normal;
  }
  .public-header.is-menu-open .public-nav{
    display:grid;
  }
  .public-nav a{
    display:flex;
    align-items:center;
    justify-content:space-between;
    min-height:40px;
    padding:0 12px;
    border-radius:12px;
    font-size:13px;
  }
  .public-nav a:hover{
    transform:none;
  }
  .public-login-link{
    justify-content:center !important;
    margin-top:4px;
  }
}

/* Public hamburger shape fix v5 */
@media (max-width: 720px){
  .public-menu-toggle{
    appearance:none;
    -webkit-appearance:none;
    padding:0;
    margin:0;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:5px;
    width:40px;
    height:40px;
    line-height:1;
  }
  .public-menu-toggle span{
    display:block;
    width:18px;
    height:2px;
    margin:0;
    padding:0;
    border-radius:999px;
    background:#eef5ff;
    flex:0 0 auto;
  }
}
