/* ─── Bitfinco — secondary pages (page.njk layout) ─── */
/* Loaded after base.css (tokens, resets, ::selection, reduced-motion, #cookie-banner). */

/* Shared scroll reveal (mirrors the rule in home.css so secondary pages animate too) */
[data-reveal]{
  opacity:0;
  transform:translate3d(0, 24px, 0);
  transition:
    transform 900ms cubic-bezier(.2,.7,.2,1),
    opacity 700ms ease-out;
  transition-delay:var(--reveal-delay, 0ms);
}
[data-reveal="left"]  { transform:translate3d(-32px, 0, 0); }
[data-reveal="right"] { transform:translate3d( 32px, 0, 0); }
[data-reveal].is-visible{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ opacity:1; transform:none; transition:none; }
}

/* ─── Nav ─── */
nav{
  position:sticky;top:0;z-index:100;
  background:rgba(251,250,246,.88);
  backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--nav-height);max-width:var(--container-max);margin:0 auto;padding:0 var(--container-x);
}
.logo{display:flex;align-items:center;height:38px}
.logo img{height:100%;width:auto;display:block}

/* .nav-links, .nav-drawer, .nav-toggle, .btn, .btn-primary all live in
   base.css now (incl. the @media(max-width:1140px) drawer breakpoint). */

/* ─── Typography ─── */
h1{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:300;
  font-size:var(--type-section);
  letter-spacing:-.025em;line-height:1.05;
  color:var(--ink);margin:80px 0 24px;
}
h1 em{font-style:italic;color:var(--gold);font-weight:400}
h2{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:400;
  font-size:var(--type-sub);letter-spacing:-.01em;
  color:var(--ink);margin:48px 0 16px;
}
p{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:300;
  font-size:var(--type-body);line-height:1.65;color:var(--text);
  margin-bottom:16px;letter-spacing:-.005em;
}
ul{margin-left:24px;margin-bottom:16px}
li{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:300;
  font-size:var(--type-body);line-height:1.65;color:var(--text);
  margin-bottom:6px;letter-spacing:-.005em;
}
.small{
  font-size:11px;color:var(--text-dim);
  font-family:'IBM Plex Mono',monospace;letter-spacing:.04em;line-height:1.7;
  margin-top:64px;padding-top:32px;border-top:1px solid var(--line);
}

/* ─── Page-wrapper variants ─── */
.legal{max-width:var(--container-max);margin:0 auto;padding:0 var(--container-x) 120px}
.form-page{max-width:1100px;margin:0 auto;padding:0 var(--container-x) 120px;min-width:0}
.form-page.narrow{max-width:880px}

/* ─── Intro / forms ─── */
.intro{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:300;
  font-size:var(--type-lead);line-height:1.5;
  color:var(--text);max-width:680px;margin-bottom:24px;
}
/* Smaller "for X reach out to email" line that sits below an .intro paragraph */
.intro-contact{
  font-family:'IBM Plex Mono',monospace;font-size:13px;letter-spacing:.04em;
  color:var(--text-dim);max-width:680px;margin:-12px 0 32px;line-height:1.6;
}
.intro-contact a{color:var(--gold);border-bottom:1px solid var(--gold);padding-bottom:1px}
.intro-contact a:hover{color:var(--gold-hi);border-color:var(--gold-hi)}
form{margin-top:24px;min-width:0}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px 32px;min-width:0}
.form-grid .full{grid-column:1/-1}
.field{display:flex;flex-direction:column;gap:10px;min-width:0}
.field label{
  font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--text-dim);font-weight:500;
  cursor:pointer;
}
.field .req{color:var(--ink)}
.field input,.field select,.field textarea{
  padding:14px 18px;background:#fff;border:1px solid var(--line);
  font-family:'Bricolage Grotesque',sans-serif;font-weight:300;font-size:17px;
  color:var(--ink);transition:border-color .2s;
  width:100%;max-width:100%;min-width:0;
}
.field textarea{resize:vertical;line-height:1.55}
.form-page .field textarea{min-height:140px}
.form-page.narrow .field textarea{min-height:180px}
.field input[type="file"]{
  background:transparent;border:1px dashed var(--line);
  padding:22px 18px;cursor:pointer;
  font-family:'Bricolage Grotesque',sans-serif;font-size:13.5px;color:var(--text-dim);
}
.phone-wrap{display:flex;gap:8px;min-width:0}
.phone-wrap select{flex:0 0 clamp(96px, 30%, 130px);font-family:'IBM Plex Mono',monospace;font-size:14px;width:auto}
.phone-wrap input{flex:1;min-width:0;width:auto}

.submit-btn{
  margin-top:48px;padding:18px 36px;
  background:var(--navy);color:var(--bg);
  font-family:'Bricolage Grotesque',sans-serif;font-size:12.5px;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;
  transition:background .25s;
  display:inline-flex;align-items:center;gap:10px;
}
.submit-btn:hover{background:var(--gold);color:var(--gold-on-ink)}
.submit-btn:disabled{opacity:.6;cursor:not-allowed}

/* Spam honeypot — hidden from humans, baited for bots. */
.honeypot{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}

.form-success{
  background:var(--bg-2);border-left:3px solid var(--gold);
  padding:32px 40px;margin-top:48px;display:none;
}
.form-success.show{display:block}
.form-success h2{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:400;color:var(--ink);
  margin-bottom:10px;font-size:28px;letter-spacing:-.01em;
  margin-top:0;
}
.form-success h2 em{font-style:italic;color:var(--gold);font-weight:400}
.form-success p{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:300;color:var(--text);
  font-size:17px;line-height:1.55;
}

@media (max-width:760px){
  .form-grid{grid-template-columns:1fr;gap:24px}
}

/* ─── 404 page ─── */
.notfound{
  max-width:880px;margin:0 auto;padding:0 var(--container-x) 120px;
  min-height:calc(100dvh - 220px);
  display:flex;flex-direction:column;justify-content:center;
}
.notfound .code{
  font-family:'IBM Plex Mono',monospace;font-size:13px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--gold);font-weight:500;
  display:inline-flex;align-items:center;gap:14px;margin-bottom:24px;
}
.notfound .code::before{content:"";width:30px;height:1px;background:var(--gold)}
.notfound .lead{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:300;
  font-size:var(--type-lead);line-height:1.55;
  color:var(--text);max-width:560px;margin:24px 0 40px;
}
.notfound .actions{display:flex;gap:24px;align-items:center;flex-wrap:wrap}
.notfound .actions .primary{
  padding:14px 28px;background:var(--navy);color:var(--bg);
  font-family:'Bricolage Grotesque',sans-serif;font-size:12.5px;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;transition:background .25s;
}
.notfound .actions .primary:hover{background:var(--navy-deep)}
.notfound .actions .secondary{
  font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink);font-weight:500;
  border-bottom:1px solid var(--ink);padding-bottom:6px;
  transition:color .25s, border-color .25s;
}
.notfound .actions .secondary:hover{color:var(--gold);border-color:var(--gold)}

/* ─── Footer (full-spec; mirrors home.css so secondary pages render the same) ─── */
footer{background:var(--navy);color:var(--footer-text);padding:100px 0 40px}
footer .container{max-width:var(--container-max);margin:0 auto;padding:0 var(--container-x)}
footer .logo{display:flex;align-items:center;height:38px}
footer .logo img{height:100%;width:auto;display:block;filter:brightness(1.1)}
footer a{color:var(--footer-text);transition:color .2s}
footer a:hover{color:var(--gold-hi)}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:64px;margin-bottom:0}
.footer-brand p{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:300;
  font-size:13.5px;line-height:1.7;margin-top:24px;max-width:360px;color:var(--footer-text-2);
}
.footer-brand p.footer-hq{
  font-family:'IBM Plex Mono',monospace;font-size:11.5px;line-height:1.7;
  letter-spacing:.02em;color:var(--footer-meta);margin-top:20px;
}
.footer-hq-label{
  display:block;color:var(--gold-hi);font-size:10.5px;letter-spacing:.22em;
  text-transform:uppercase;font-weight:600;margin-bottom:8px;
}
.footer-col h4{
  font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold-hi);margin-bottom:24px;font-weight:600;
}
.footer-col ul{list-style:none;display:grid;gap:14px;margin:0;padding:0}
.footer-col ul li{margin:0}
.footer-col a{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:400;
  font-size:13.5px;letter-spacing:0;
  /* Tap target: padding gives 44px touch area without changing visual line spacing. */
  display:inline-block;padding:6px 0;
}
@media (max-width:1140px){
  .footer-top{grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px}
}
@media (max-width:900px){
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .footer-brand{grid-column:1/-1}
}
@media (max-width:600px){
  .footer-top{grid-template-columns:1fr;gap:32px}
  footer{padding:64px 0 32px}
}
