/* ============================================================
   SINGULAR — Studio (corporate / competenze)
   ============================================================ */

/* ---------- hero ---------- */
.s-hero{padding:168px 0 80px;position:relative}
.s-hero .eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:28px}
.s-hero .eyebrow .rule{height:1px;width:46px;background:var(--ink-3);opacity:.5}
.s-hero h1{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(40px,6.6vw,98px);line-height:1.0;letter-spacing:-0.03em;
  max-width:17ch;
}
.s-hero h1 .em{font-style:italic;font-weight:300}
.s-hero .lede{margin-top:36px;max-width:54ch;font-size:clamp(18px,1.8vw,23px)}

/* ---------- section scaffolding ---------- */
.sec{padding:clamp(64px,9vw,128px) 0;border-top:1px solid var(--line)}
.sec-label{display:flex;align-items:center;gap:12px;margin-bottom:40px}
.sec-label .n{font-family:var(--mono);font-size:12px;letter-spacing:.16em;color:var(--blue)}
.sec-label .t{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3)}
.sec-label .line{flex:1;height:1px;background:var(--line)}

.lead-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(32px,6vw,90px);align-items:start}
.lead-grid .h2{max-width:14ch}
@media (max-width:880px){.lead-grid{grid-template-columns:1fr;gap:28px}}

/* ---------- principles (the model) ---------- */
.principles{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:8px;border-top:1px solid var(--line)}
.principle{padding:38px 30px 38px 0;border-right:1px solid var(--line)}
.principle:last-child{border-right:none;padding-right:0}
.principle .pn{font-family:var(--mono);font-size:12px;letter-spacing:.16em;color:var(--blue);margin-bottom:20px}
.principle h3{font-family:var(--serif);font-weight:400;font-size:clamp(23px,2.3vw,30px);letter-spacing:-0.02em;margin-bottom:14px;line-height:1.1}
.principle p{color:var(--ink-2);font-size:16px;line-height:1.55}
@media (max-width:760px){
  .principles{grid-template-columns:1fr}
  .principle{border-right:none;border-bottom:1px solid var(--line);padding:30px 0}
  .principle:last-child{border-bottom:none}
}

/* ---------- capabilities list ---------- */
.caps{margin-top:4px}
.cap{
  display:grid;grid-template-columns:54px 1fr auto;gap:24px;align-items:baseline;
  padding:26px 4px;border-top:1px solid var(--line);
  transition:padding-left .4s var(--ease), background .4s var(--ease);
}
.caps .cap:last-child{border-bottom:1px solid var(--line)}
.cap:hover{padding-left:16px}
.cap .ci{font-family:var(--mono);font-size:12px;color:var(--ink-3);letter-spacing:.08em}
.cap .cname{font-family:var(--serif);font-weight:400;font-size:clamp(24px,3vw,40px);letter-spacing:-0.02em;line-height:1.04}
.cap .cdesc{font-size:15.5px;color:var(--ink-2);max-width:42ch;justify-self:end;text-align:right;line-height:1.5}
@media (max-width:760px){
  .cap{grid-template-columns:1fr;gap:8px}
  .cap .cdesc{justify-self:start;text-align:left}
}

/* the honest exclusion */
.cap.exclude{opacity:1}
.cap.exclude .cname{color:var(--ink-3);text-decoration:line-through;text-decoration-thickness:1px;text-decoration-color:var(--cyan)}
.cap.exclude .cdesc{color:var(--ink-2)}
.cap.exclude .ci{color:var(--cyan)}

/* ---------- verticals (deep expertise) ---------- */
.verticals{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.4vw,30px);margin-top:6px}
.vert{
  position:relative;border:1px solid var(--line);border-radius:20px;overflow:hidden;
  background:var(--white);padding:0;
}
.vert .vcover{position:relative;aspect-ratio:16/8;background:var(--navy);overflow:hidden}
.vert .vcover canvas{position:absolute;inset:0;width:100%;height:100%}
.vert .vcover .vtag{position:absolute;top:16px;left:16px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#dff3fb;background:rgba(11,24,56,.42);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.18);border-radius:100px;padding:6px 12px;z-index:2}
.vert .vbody{padding:28px 30px 32px}
.vert h3{font-family:var(--serif);font-weight:400;font-size:clamp(26px,2.8vw,38px);letter-spacing:-0.02em;line-height:1.05;margin-bottom:16px}
.vert p{color:var(--ink-2);font-size:16.5px;line-height:1.55;max-width:46ch}
.vert .yrs{display:inline-block;margin-top:18px;font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:var(--blue)}
@media (max-width:880px){.verticals{grid-template-columns:1fr}}

/* ---------- numbers / team strip ---------- */
.stats{background:var(--navy);color:#fff;border-radius:22px;padding:clamp(40px,5vw,64px) clamp(28px,4vw,56px);display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.stat .k{font-family:var(--serif);font-weight:300;font-size:clamp(42px,5.5vw,78px);line-height:1;letter-spacing:-0.02em}
.stat .k .it{font-style:italic}
.stat .l{margin-top:14px;color:#9fb0d8;font-size:14.5px;line-height:1.4}
@media (max-width:760px){.stats{grid-template-columns:1fr 1fr;gap:34px 24px}}

/* ---------- closing ---------- */
.closing{padding:clamp(80px,11vw,150px) 0;text-align:center}
.closing .big{font-family:var(--serif);font-weight:400;font-size:clamp(34px,5.4vw,80px);line-height:1.02;letter-spacing:-0.02em;max-width:18ch;margin:0 auto 36px}
.closing .big .it{font-style:italic}
