/* ============================================================
   BK bio · CONTACT page (V3). Loads AFTER bk-elevated.css.
   Reuses its tokens, topnav, mast, seam, band, cta-final, foot,
   .btn*, .ml, .rv, .grain.
   Adds page-specific blocks only:
     · process thread (what happens next)
     · the request desk (asymmetric: form light + info panel deep)
     · sample-request form (keeps Contact.js IDs/wiring intact)
   Bilingual: EN + KO twin. No SKU/reference codes. No em dashes.
   ============================================================ */

/* contact masthead: keep deck readable, CTA under the lead */
.mast .deck.cdeck{grid-template-columns:1.25fr 1fr;}
@media(max-width:680px){.mast .deck.cdeck{grid-template-columns:1fr;}}

/* visually-hidden (a11y label): CSP-clean, no inline clip */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0 0 0 0);white-space:nowrap;border:0;}

/* ---------- PROCESS THREAD (slim tinted bar) ---------- */
.c-thread{display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  padding:13px 56px;background:var(--bg-2);
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);}
.c-thread .tl{font-family:var(--ff-m);font-size:10px;font-weight:500;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-3);padding-right:14px;border-right:1px solid var(--rule);}
.c-thread .ti{font-family:var(--ff-m);font-size:12px;letter-spacing:.03em;color:var(--ink);}
.c-thread .ti.strong{color:var(--green);font-weight:500;}
.c-thread .ta{font-family:var(--ff-m);font-size:13px;color:var(--accent);}
@media(max-width:680px){.c-thread{padding:12px 22px;gap:10px;}}

/* ---------- THE REQUEST DESK (asymmetric split) ----------
   Left: the form (light, wider). Right: direct lines (deep pine). */
.c-desk{display:grid;grid-template-columns:1.18fr .82fr;align-items:stretch;}

/* form side (light) */
.c-form{padding:clamp(48px,6vh,80px) clamp(28px,4vw,56px);
  border-right:1px solid var(--rule);position:relative;}
.c-form-h{border-bottom:1px solid var(--ink);padding-bottom:18px;}
.c-form-h h2{font-family:var(--ff-d);font-weight:600;font-size:clamp(26px,3vw,40px);
  letter-spacing:-.022em;line-height:1.04;margin:12px 0 0;}
.c-form-h h2 em{font-style:italic;color:var(--green);font-weight:500;}
.c-form .lead{font-size:16.5px;line-height:1.62;color:var(--ink-2);margin:18px 0 0;max-width:52ch;}
.c-form .lead b{color:var(--ink);font-weight:600;}

/* fields */
.c-fields{margin-top:30px;max-width:540px;}
.c-field{margin-bottom:20px;}
.c-field label{font-family:var(--ff-m);font-size:10px;font-weight:500;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-3);display:block;margin-bottom:8px;}
.c-field label .req{color:var(--accent-d);margin-left:2px;}
.c-field input,.c-field textarea,.c-field select{
  width:100%;font-family:var(--ff-b);font-size:16px;color:var(--ink);
  background:var(--paper);border:1px solid var(--rule-2);padding:14px 15px;border-radius:0;
  transition:border-color .14s,box-shadow .14s;}
.c-field input::placeholder,.c-field textarea::placeholder{color:var(--ink-4);}
.c-field input:focus,.c-field textarea:focus,.c-field select:focus{
  outline:none;border-color:var(--green);box-shadow:0 0 0 1px var(--green);}
/* keyboard focus ring is preserved by bk-elevated focus-visible; this is the calmer pointer-focus look */
.c-field textarea{resize:vertical;min-height:96px;line-height:1.55;}
.c-field select{appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%236E6555' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;}
.c-field input[aria-invalid="true"],.c-field textarea[aria-invalid="true"],
.c-field select[aria-invalid="true"]{border-color:var(--accent-d);box-shadow:0 0 0 1px var(--accent-d);}

/* inline field error (created by Contact.js as span.field-err) */
.field-err{display:block;font-family:var(--ff-m);font-size:10.5px;letter-spacing:.02em;
  color:var(--accent-d);margin-top:7px;}
/* form-level send error (created by Contact.js as div#formErr) */
.c-err{font-family:var(--ff-b);font-size:14px;line-height:1.5;color:var(--accent-d);
  background:rgba(206,74,24,.07);border:1px solid rgba(206,74,24,.28);border-radius:8px;
  padding:12px 14px;margin:0 0 16px;}

/* honeypot: hidden from humans, catches bots (kept; Contact.js reads name="company_url") */
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;opacity:0;}

/* consent */
.c-consent{display:grid;grid-template-columns:44px minmax(0,1fr);align-items:flex-start;gap:11px;margin:6px 0 24px;position:relative;}
.c-consent input{width:44px;height:44px;margin:0;opacity:0;cursor:pointer;grid-column:1;grid-row:1;}
.c-consent label{font-size:14px;line-height:1.55;color:var(--ink-2);grid-column:2;min-height:44px;padding-top:1px;}
.c-consent label::before{content:'';position:absolute;left:11px;top:2px;width:18px;height:18px;border:1px solid var(--rule-2);background:var(--paper);}
.c-consent input:checked + label::before{background:var(--green);border-color:var(--green);}
.c-consent input:checked + label::after{content:'';position:absolute;left:17px;top:6px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);}
.c-consent input:focus-visible + label::before{outline:2px solid var(--accent);outline-offset:3px;}
.c-consent label .req{color:var(--accent-d);}
.c-consent a{color:var(--green);border-bottom:1px solid var(--rule);}
.c-consent a:hover{border-color:var(--green);}

/* submit row */
.c-submit{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:8px;}
.c-expect{display:inline-flex;align-items:center;gap:9px;font-family:var(--ff-m);font-size:11px;
  letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
.c-expect i{width:6px;height:6px;background:var(--accent);display:inline-block;border-radius:50%;}

/* success message (Contact.js toggles .show, focuses it) */
.c-ok{display:none;margin-top:20px;padding:18px 20px;background:var(--bg-2);
  border:1px solid var(--rule);font-size:15px;color:var(--ink);line-height:1.6;}
.c-ok.show{display:block;}
.c-ok b{color:var(--green);}
.c-ok:focus-visible{outline:2px solid var(--accent);outline-offset:3px;}

/* foot note under the form */
.c-note{font-family:var(--ff-m);font-size:11px;letter-spacing:.03em;color:var(--ink-3);
  margin-top:20px;line-height:1.65;max-width:54ch;}

/* ---------- INFO PANEL (deep pine) ---------- */
.c-info{background:var(--pine-d);color:#EFEADE;
  padding:clamp(48px,6vh,80px) clamp(28px,4vw,52px);position:relative;overflow:hidden;}
.c-info .glow{position:absolute;left:-25%;top:-45%;width:150%;height:190%;
  background:radial-gradient(circle at 58% 32%,rgba(44,106,72,.26),transparent 62%);pointer-events:none;z-index:0;}
.c-info>*{position:relative;z-index:2;}
.c-info-h{border-bottom:1px solid rgba(200,162,78,.7);padding-bottom:16px;}
.c-info-h .ml{color:rgba(239,234,222,.62);}
.c-info-h .ml .dot{background:var(--accent-l);}
.c-info-h h2{font-family:var(--ff-d);font-weight:600;font-size:clamp(24px,2.6vw,34px);
  letter-spacing:-.02em;line-height:1.06;margin:12px 0 0;color:#fff;}
.c-info-h h2 em{font-style:italic;color:var(--accent-l);font-weight:500;}

.c-block{margin-top:28px;padding-top:22px;border-top:1px solid rgba(255,255,255,.1);}
.c-block:first-of-type{border-top:none;padding-top:26px;}
.c-block .bk{font-family:var(--ff-m);font-size:9.5px;font-weight:500;letter-spacing:.14em;
  text-transform:uppercase;color:rgba(239,234,222,.56);margin-bottom:12px;}
.c-block .bv{font-size:16px;color:#fff;line-height:1.55;}
.c-block .bv a{border-bottom:1px solid rgba(200,162,78,.55);transition:border-color .15s,color .15s;}
.c-block .bv a:hover{border-color:#fff;color:#fff;}
.c-block .bsub{font-size:14px;color:rgba(239,234,222,.72);line-height:1.55;margin-top:6px;}
.c-block .bsub .kr{font-family:var(--ff-kr-b);}

/* phones: two tabular numbers, by purpose */
.c-phones{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.c-phones .p .pl{font-family:var(--ff-m);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(239,234,222,.56);}
.c-phones .p .pn{font-family:var(--ff-m);font-size:16px;color:#fff;margin-top:7px;
  font-variant-numeric:tabular-nums;display:inline-flex;align-items:center;min-height:44px;}
.c-phones .p a.pn{border-bottom:1px solid rgba(200,162,78,.45);}
.c-phones .p a.pn:hover{border-color:#fff;}

/* expectation note inside the info panel */
.c-info .bv.soft{font-size:15px;color:rgba(239,234,222,.82);line-height:1.62;}

@media(max-width:860px){
  .c-desk{grid-template-columns:1fr;}
  .c-form{border-right:none;border-bottom:1px solid var(--rule);}
}
@media(max-width:520px){
  .c-fields{max-width:100%;}
  .c-phones{grid-template-columns:1fr;gap:18px;}
}

/* ---------- LOCATIONS (two office records + maps) ---------- */
.c-locations{padding:clamp(54px,7vh,92px) 56px;background:var(--bg-2);border-top:1px solid var(--rule);}
.locs-h{display:flex;justify-content:space-between;align-items:flex-end;gap:28px;flex-wrap:wrap;
  border-bottom:1px solid var(--ink);padding-bottom:18px;}
.locs-h h2{font-family:var(--ff-d);font-weight:600;font-size:clamp(28px,3.2vw,46px);
  letter-spacing:-.022em;line-height:1.04;margin:12px 0 0;}
.locs-h p{font-size:15px;line-height:1.58;color:var(--ink-2);max-width:46ch;margin:0;}
.loc-grid{display:grid;gap:18px;margin-top:26px;}
.loc-card{display:grid;grid-template-columns:minmax(0,.86fr) minmax(320px,1.14fr);
  background:var(--paper);border:1px solid var(--rule);box-shadow:0 18px 38px -34px rgba(22,20,18,.52);}
.loc-copy{padding:26px 28px 28px;}
.loc-k{font-family:var(--ff-m);font-size:9.5px;font-weight:500;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent-d);}
.loc-copy h3{font-family:var(--ff-d);font-weight:600;font-size:24px;line-height:1.08;
  letter-spacing:-.012em;margin:10px 0 0;color:var(--ink);}
.loc-addr{font-size:16px;line-height:1.6;color:var(--ink-2);margin:14px 0 0;max-width:46ch;}
.loc-addr span{color:var(--ink-3);}
.loc-list{display:grid;grid-template-columns:1fr 1fr;gap:1px;margin:22px 0 0;background:var(--rule);border:1px solid var(--rule);}
.loc-list div{background:var(--paper);padding:13px 14px;}
.loc-list dt{font-family:var(--ff-m);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-3);margin:0 0 5px;}
.loc-list dd{margin:0;font-family:var(--ff-m);font-size:14px;color:var(--ink);
  font-variant-numeric:tabular-nums;overflow-wrap:anywhere;}
.loc-list a{border-bottom:1px solid var(--rule);transition:border-color .15s,color .15s;}
.loc-list a:hover{color:var(--green);border-color:var(--green);}
/* static office map (self-hosted image + "view on map" link; no third-party embed) */
.loc-map{margin:0;display:flex;flex-direction:column;background:var(--bg);
  border-left:1px solid var(--rule);}
.loc-map picture{display:block;flex:1 1 auto;min-height:300px;position:relative;}
.loc-map img{display:block;width:100%;height:100%;min-height:300px;
  object-fit:cover;filter:saturate(.97);}
.loc-mapbar{display:flex;align-items:center;justify-content:space-between;gap:14px;
  flex-wrap:wrap;padding:14px 18px;background:var(--paper);
  border-top:1px solid var(--rule);}
.loc-mapbar .lm-tag{font-family:var(--ff-m);font-size:11px;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);}
.loc-mapbar .lm-link{display:inline-flex;align-items:center;gap:7px;min-height:44px;
  font-family:var(--ff-m);font-size:13px;font-weight:600;letter-spacing:.01em;
  color:var(--accent-d);}
.loc-mapbar .lm-link:hover{color:var(--accent);text-decoration:underline;}
.loc-mapbar .lm-link .arr{font-style:normal;}
@media(max-width:900px){
  .c-locations{padding-left:28px;padding-right:28px;}
  .loc-card{grid-template-columns:1fr;}
  .loc-map{border-left:none;border-top:1px solid var(--rule);}
}
@media(max-width:520px){
  .c-locations{padding-left:22px;padding-right:22px;}
  .loc-copy{padding:22px;}
  .loc-list{grid-template-columns:1fr;}
}

/* ---------- closing band caption override ---------- */
.c-band .bc h2{max-width:18ch;}
