/* ============================================================
   BINOBAN — Solutions, Partners, Contact modules
   Loaded after binoban-pages.css.
   ============================================================ */

/* ---- Solution routing cards (overview) ---- */
.sol-block + .sol-block{ margin-top:18px; }
.sol-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:36px; }
.sol-card{ position:relative; display:flex; flex-direction:column; border:1px solid var(--hairline-dark2);
  border-radius:12px; padding:28px 26px; background:rgba(255,255,255,.02);
  transition:transform .4s var(--ease), border-color .4s var(--ease); }
.bg-paper .sol-card,.bg-paper-2 .sol-card{ background:var(--paper); border-color:var(--paper-line); }
.sol-card:hover{ transform:translateY(-5px); border-color:var(--hairline-dark); }
.sol-card .sc-ico{ width:30px; height:30px; color:var(--gold); margin-bottom:18px; }
.bg-paper .sol-card .sc-ico{ color:var(--gold-deep); }
.sol-card h3{ font-size:18.5px; letter-spacing:-.012em; line-height:1.22; margin:0 0 10px; }
.sol-card p{ font-size:13.5px; line-height:1.55; color:var(--ink-soft); margin:0 0 18px; flex:1; }
.bg-deep .sol-card p,.bg-navy .sol-card p{ color:var(--on-dark-soft); }
.sol-modules{ display:flex; flex-wrap:wrap; gap:6px; margin-bottom:18px; }
.sol-modules span{ font-size:10.5px; font-weight:700; letter-spacing:.04em; padding:4px 9px; border-radius:4px;
  border:1px solid var(--hairline-dark2); color:var(--on-dark-mute); display:flex; align-items:center; gap:6px; }
.bg-paper .sol-modules span,.bg-paper-2 .sol-modules span{ border-color:var(--paper-line); color:var(--ink-mute); }
.sol-modules .fam{ width:6px; height:6px; border-radius:1px; transform:rotate(45deg); }
.sol-card .read{ font-size:12.5px; font-weight:700; letter-spacing:.05em; color:var(--gold-deep);
  display:flex; align-items:center; gap:8px; margin-top:auto; }
.bg-deep .sol-card .read,.bg-navy .sol-card .read{ color:var(--gold); }
.sol-card .read .arrow{ transition:transform .3s var(--ease); }
.sol-card:hover .read .arrow{ transform:translateX(5px); }

/* tab toggle between industry / outcome (overview) */
.sol-toggle{ display:inline-flex; gap:6px; padding:5px; border-radius:10px; border:1px solid var(--hairline-dark2);
  background:rgba(255,255,255,.02); margin-top:8px; }
.bg-paper .sol-toggle,.bg-paper-2 .sol-toggle{ border-color:var(--paper-line); background:#fff; }
.sol-toggle button{ font-family:inherit; font-size:13px; font-weight:700; letter-spacing:.02em; padding:10px 20px;
  border-radius:6px; border:0; background:transparent; color:var(--on-dark-mute); transition:.25s var(--ease); }
.bg-paper .sol-toggle button,.bg-paper-2 .sol-toggle button{ color:var(--ink-mute); }
.sol-toggle button.active{ background:var(--gold); color:var(--navy-950); }

/* platform-connection strip */
.connect-strip{ margin-top:36px; display:grid; grid-template-columns:repeat(7,1fr); gap:0; }
.connect-node{ position:relative; text-align:center; padding:18px 10px; border:1px solid var(--hairline-dark2);
  border-right:0; background:rgba(255,255,255,.02); }
.bg-paper .connect-node,.bg-paper-2 .connect-node{ background:var(--paper); border-color:var(--paper-line); }
.connect-node:first-child{ border-radius:8px 0 0 8px; }
.connect-node:last-child{ border-right:1px solid var(--hairline-dark2); border-radius:0 8px 8px 0; }
.bg-paper .connect-node:last-child,.bg-paper-2 .connect-node:last-child{ border-right:1px solid var(--paper-line); }
.connect-node span{ font-size:12.5px; font-weight:900; letter-spacing:-.01em; }
.connect-node small{ display:block; font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); margin-bottom:6px; }
.bg-paper .connect-node small{ color:var(--gold-deep); }

/* ---- Solution detail: start-with / expand-into ---- */
.expand-row{ display:grid; grid-template-columns:1fr auto 1fr; gap:24px; align-items:stretch; margin-top:36px; }
.expand-box{ border:1px solid var(--hairline-dark2); border-radius:12px; padding:28px 30px; background:rgba(255,255,255,.02); }
.bg-paper .expand-box,.bg-paper-2 .expand-box{ background:var(--paper); border-color:var(--paper-line); }
.expand-box.is-start{ border-color:var(--gold); background:linear-gradient(180deg, rgba(181,135,80,.10), rgba(181,135,80,.02)); }
.expand-box .eb-label{ font-size:11px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-bottom:12px; }
.bg-paper .expand-box .eb-label,.bg-paper-2 .expand-box .eb-label{ color:var(--gold-deep); }
.expand-box h4{ font-size:19px; letter-spacing:-.01em; margin:0 0 10px; }
.expand-box p{ font-size:14px; line-height:1.6; color:var(--ink-soft); margin:0; }
.bg-deep .expand-box p,.bg-navy .expand-box p{ color:var(--on-dark-soft); }
.expand-arrow{ display:grid; place-items:center; color:var(--gold); }

/* ---- Contact: conversation paths ---- */
.path-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:14px; margin-top:48px; }
.conv-path{ text-align:left; border:1px solid var(--hairline-dark2); border-radius:12px; padding:24px 22px;
  background:rgba(255,255,255,.02); cursor:pointer; transition:transform .35s var(--ease), border-color .35s var(--ease), background .35s; display:flex; flex-direction:column; }
.conv-path:hover{ transform:translateY(-4px); border-color:var(--hairline-dark); background:rgba(255,255,255,.04); }
.conv-path.active{ border-color:var(--gold); background:linear-gradient(180deg, rgba(181,135,80,.12), rgba(181,135,80,.02)); }
.conv-path .cp-ico{ width:26px; height:26px; color:var(--gold); margin-bottom:16px; }
.conv-path h4{ font-size:15px; letter-spacing:-.01em; margin:0 0 8px; line-height:1.2; }
.conv-path .cp-who{ font-size:11.5px; font-weight:700; letter-spacing:.03em; color:var(--gold); text-transform:uppercase; margin-bottom:10px; }
.conv-path p{ font-size:12.5px; line-height:1.5; color:var(--on-dark-mute); margin:0; }

/* ---- Contact: intake form (inline, enterprise) ---- */
.intake{ display:grid; grid-template-columns:1.35fr .85fr; gap:48px; margin-top:8px; align-items:start; }
.intake-form{ border:1px solid var(--hairline-dark2); border-radius:14px; padding:36px; background:rgba(255,255,255,.02); }
.intake-form .form-grid{ grid-template-columns:1fr 1fr; }
.intake-form .selected-path{ font-size:12px; font-weight:700; letter-spacing:.04em; color:var(--gold);
  display:flex; align-items:center; gap:8px; margin-bottom:22px; padding:11px 14px; border-radius:8px;
  background:rgba(181,135,80,.1); border:1px solid var(--hairline-dark); }
.chip-select{ display:flex; flex-wrap:wrap; gap:8px; }
.chip-select label{ position:relative; cursor:pointer; }
.chip-select input{ position:absolute; opacity:0; pointer-events:none; }
.chip-select span{ display:inline-block; font-size:12.5px; font-weight:600; padding:9px 14px; border-radius:30px;
  border:1px solid var(--hairline-dark2); color:var(--on-dark-soft); transition:.2s var(--ease); }
.chip-select input:checked + span{ background:var(--gold); border-color:var(--gold); color:var(--navy-950); font-weight:700; }
.chip-select label:hover span{ border-color:var(--gold); }
.intake-aside{ position:sticky; top:100px; display:flex; flex-direction:column; gap:24px; }
.aside-card{ border:1px solid var(--hairline-dark2); border-radius:12px; padding:26px 28px; background:rgba(255,255,255,.02); }
.aside-card h4{ font-size:16px; letter-spacing:-.01em; margin:0 0 10px; display:flex; align-items:center; gap:10px; }
.aside-card h4 .star{ font-size:13px; color:var(--gold); }
.aside-card p{ font-size:13px; line-height:1.6; color:var(--on-dark-soft); margin:0; }
.aside-contact{ display:flex; flex-direction:column; gap:14px; }
.aside-contact a{ display:flex; align-items:center; gap:12px; font-size:14px; color:var(--on-dark); transition:color .2s; }
.aside-contact a:hover{ color:var(--gold-bright); }
.aside-contact a svg{ width:18px; height:18px; color:var(--gold); flex:none; }
.privacy-micro{ font-size:11.5px; line-height:1.5; color:var(--on-dark-mute); margin-top:18px; }

/* contact success */
.intake-form.done .form-body{ display:none; }
.intake-success{ display:none; text-align:center; padding:30px 10px; }
.intake-form.done .intake-success{ display:block; }
.intake-success .star{ font-size:48px; color:var(--gold); margin-bottom:20px; }
.intake-success h3{ font-size:24px; margin-bottom:12px; }
.intake-success p{ font-size:14px; color:var(--on-dark-soft); max-width:44ch; margin:0 auto; line-height:1.6; }

/* ---- Partners: model rows ---- */
.pmodels{ margin-top:40px; border:1px solid var(--hairline-dark2); border-radius:14px; overflow:hidden; }
.bg-paper .pmodels,.bg-paper-2 .pmodels{ border-color:var(--paper-line); }
.pmodel{ display:grid; grid-template-columns:.95fr 1.5fr .9fr; gap:0; align-items:center; }
.pmodel + .pmodel{ border-top:1px solid var(--hairline-dark2); }
.bg-paper .pmodel + .pmodel,.bg-paper-2 .pmodel + .pmodel{ border-top-color:var(--paper-line); }
.pmodel > div{ padding:26px 28px; }
.pmodel .pm-name{ display:flex; align-items:center; gap:12px; font-size:17px; font-weight:900; letter-spacing:-.015em; }
.pmodel .pm-name .star{ font-size:13px; color:var(--gold); flex:none; }
.bg-paper .pmodel .pm-name .star{ color:var(--gold-deep); }
.pmodel .pm-desc{ font-size:13.5px; line-height:1.58; color:var(--on-dark-soft); border-left:1px solid var(--hairline-dark2); }
.bg-paper .pmodel .pm-desc,.bg-paper-2 .pmodel .pm-desc{ color:var(--ink-soft); border-left-color:var(--paper-line); }
.pmodel .pm-fit{ border-left:1px solid var(--hairline-dark2); }
.bg-paper .pmodel .pm-fit,.bg-paper-2 .pmodel .pm-fit{ border-left-color:var(--paper-line); }
.pmodel .pm-fit small{ display:block; font-size:10px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); margin-bottom:7px; }
.bg-paper .pmodel .pm-fit small{ color:var(--gold-deep); }
.pmodel .pm-fit span{ font-size:12.5px; line-height:1.45; color:var(--on-dark-mute); }
.bg-paper .pmodel .pm-fit span{ color:var(--ink-mute); }

/* ---- Partners: build grid ---- */
.build-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:40px; }
.build-item{ border:1px solid var(--hairline-dark2); border-radius:12px; padding:26px 24px; background:rgba(255,255,255,.02);
  display:flex; align-items:flex-start; gap:14px; transition:transform .35s var(--ease), border-color .35s; }
.bg-paper .build-item,.bg-paper-2 .build-item{ background:var(--paper); border-color:var(--paper-line); }
.build-item:hover{ transform:translateY(-4px); border-color:var(--hairline-dark); }
.build-item .bi-ico{ width:24px; height:24px; color:var(--gold); flex:none; margin-top:2px; }
.bg-paper .build-item .bi-ico{ color:var(--gold-deep); }
.build-item p{ font-size:14px; line-height:1.5; color:var(--on-dark-soft); margin:0; }
.bg-paper .build-item p,.bg-paper-2 .build-item p{ color:var(--ink-soft); }

@media (max-width:980px){
  .pmodel{ grid-template-columns:1fr; }
  .pmodel .pm-desc,.pmodel .pm-fit{ border-left:0; border-top:1px solid var(--hairline-dark2); }
  .bg-paper .pmodel .pm-desc,.bg-paper .pmodel .pm-fit{ border-top-color:var(--paper-line); }
  .build-grid{ grid-template-columns:1fr; }
  .sol-grid,.connect-strip{ grid-template-columns:1fr; }
  .connect-node{ border-right:1px solid var(--hairline-dark2) !important; border-radius:0 !important; }
  .bg-paper .connect-node{ border-right:1px solid var(--paper-line) !important; }
  .expand-row{ grid-template-columns:1fr; }
  .expand-arrow{ transform:rotate(90deg); }
  .path-grid{ grid-template-columns:repeat(2,1fr); }
  .intake{ grid-template-columns:1fr; gap:32px; }
  .intake-aside{ position:static; }
  .intake-form .form-grid{ grid-template-columns:1fr; }
}
@media (max-width:560px){
  .sol-grid{ grid-template-columns:1fr; }
  .path-grid{ grid-template-columns:1fr; }
  .intake-form{ padding:24px; }
}
