/* ═══════════════════════════════════════════════
   base.css — idprint.dev
   Shared across every page.
   Edit here to change nav, footer, buttons, vars.
═══════════════════════════════════════════════ */

/* ── Reset & base ──────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --red:     #A7012A;
  --red-lt:  #c4183a;
  --red-dk:  #820020;
  --ink:     #111111;
  --ink-2:   #1e1e1e;
  --white:   #ffffff;
  --paper:   #f5f5f5;
  --paper-2: #eeeeee;
  --paper-3: #e0e0e0;
  --mute:    #888888;
  --rule:    rgba(255,255,255,.07);
  --rule-lt: rgba(0,0,0,.08);
  --fd: 'Cormorant Garamond',Georgia,serif;
  --fb: 'Instrument Sans',system-ui,sans-serif;
  --ease: cubic-bezier(.16,1,.3,1);
  --max: 1400px;
}

html{scroll-behavior:smooth}
body{font-family:var(--fb);font-size:16px;line-height:1.6;color:var(--ink);background:var(--white);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ── Container ─────────────────────────────── */
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 56px}

/* ── Utility ───────────────────────────────── */
.eyebrow{font-size:10.5px;letter-spacing:2.5px;text-transform:uppercase;color:var(--red);font-family:var(--fb);font-weight:500}
.eyebrow-lt{font-size:10.5px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(167,1,42,.8);font-family:var(--fb);font-weight:500}

.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;font-size:13.5px;font-weight:500;letter-spacing:.4px;padding:14px 32px;font-family:var(--fb);transition:background .2s,transform .15s;cursor:pointer;border:none;white-space:nowrap}
.btn-primary:hover{background:var(--red-lt);transform:translateY(-1px)}
.btn-primary svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;flex-shrink:0}

.btn-ghost{display:inline-flex;align-items:center;gap:8px;color:#fff;font-size:13.5px;font-weight:500;letter-spacing:.4px;padding:14px 32px;border:1px solid rgba(255,255,255,.2);transition:border-color .2s,color .2s;cursor:pointer;white-space:nowrap}
.btn-ghost:hover{border-color:rgba(255,255,255,.5);color:#fff}

.btn-ghost-dk{display:inline-flex;align-items:center;gap:8px;color:var(--ink);font-size:13.5px;font-weight:500;letter-spacing:.4px;padding:14px 32px;border:1px solid rgba(0,0,0,.15);transition:border-color .2s,background .2s;cursor:pointer;white-space:nowrap}
.btn-ghost-dk:hover{border-color:var(--ink);background:var(--ink);color:#fff}

/* ── Navigation ────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:500;height:68px;background:var(--ink);border-bottom:.5px solid var(--rule)}
.nav-in{max-width:var(--max);margin:0 auto;padding:0 56px;height:100%;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:14px;text-decoration:none}
.nav-mark{width:34px;height:34px;background:var(--red);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:16px;font-weight:500;color:#fff;flex-shrink:0;letter-spacing:-.5px}
.nav-wordmark{display:flex;flex-direction:column}
.nav-name{font-family:var(--fd);font-size:19px;font-weight:500;color:#fff;line-height:1;letter-spacing:.2px}
.nav-sub{font-size:9.5px;color:var(--mute);letter-spacing:1.4px;text-transform:uppercase;margin-top:3px}
.nav-links{display:flex;align-items:center;gap:32px;list-style:none}
.nav-links a{font-size:13px;color:rgba(255,255,255,.5);letter-spacing:.2px;transition:color .2s}
.nav-links a:hover{color:#fff}
.nav-right{display:flex;align-items:center;gap:24px}
.nav-phone{font-size:12.5px;color:var(--mute);letter-spacing:.2px}
.nav-cta{background:var(--red);color:#fff;font-size:12.5px;font-weight:500;padding:9px 22px;letter-spacing:.3px;transition:background .2s;font-family:var(--fb);white-space:nowrap}
.nav-cta:hover{background:var(--red-lt)}

/* ── Footer ────────────────────────────────── */
footer{background:#0a0a0a}
.footer-in{max-width:var(--max);margin:0 auto;padding:72px 56px 40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:64px;margin-bottom:64px}
.footer-logo{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.footer-about{font-size:13px;color:#3a3a3a;line-height:1.8;max-width:260px;margin-bottom:16px}
.footer-address{font-size:12px;color:#2e2e2e;line-height:1.7}
.footer-col h5{font-size:9.5px;letter-spacing:2.5px;text-transform:uppercase;color:#333;margin-bottom:22px;font-weight:500}
.footer-col a{display:block;font-size:13px;color:#404040;margin-bottom:11px;transition:color .2s}
.footer-col a:hover{color:#888}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;border-top:.5px solid #171717;flex-wrap:wrap;gap:12px}
.footer-bottom p{font-size:11.5px;color:#252525}
.footer-legal{display:flex;gap:24px}
.footer-legal a{font-size:11.5px;color:#252525;transition:color .2s}
.footer-legal a:hover{color:#555}

/* ── Section base ─────────────────────────── */
.section{padding:100px 0}
.section-inner{max-width:var(--max);margin:0 auto;padding:0 56px}
.section-hd{margin-bottom:64px}
.section-hd .eyebrow{margin-bottom:16px}
.section-hd h2{font-family:var(--fd);font-size:52px;font-weight:300;line-height:1.05;letter-spacing:-1.5px;color:var(--ink);margin-bottom:16px}
.section-hd p{font-size:15.5px;color:var(--mute);line-height:1.8;max-width:560px}

/* ── Reveal animations ─────────────────────── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── Responsive base ───────────────────────── */
@media(max-width:1024px){
  .container,.nav-in,.footer-in,.section-inner{padding-left:32px;padding-right:32px}
  .nav-links{display:none}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .section-hd h2{font-size:44px}
}
@media(max-width:640px){
  .container,.nav-in,.footer-in,.section-inner{padding-left:20px;padding-right:20px}
  .footer-grid{grid-template-columns:1fr}
  .section-hd h2{font-size:36px}
  /* Nav logo — hide tagline on small phones to prevent wrapping */
  .nav-tag{display:none}
  .nav-name{font-size:17px}
}

/* ── Active nav state ──────────────────────────── */
.nav-links a.active{color:#fff;position:relative}
.nav-links a.active::after{
  content:'';
  position:absolute;
  bottom:-4px;left:0;right:0;
  height:1.5px;
  background:var(--red);
}

/* ── Mobile nav ──────────────────────────────── */
.nav-burger{
  display:none;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
  padding:4px;
  background:none;
  border:none;
}
.nav-burger span{
  display:block;
  width:22px;height:1.5px;
  background:#fff;
  transition:transform .25s,opacity .25s;
}
.nav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

.nav-mobile{
  display:none;
  position:fixed;
  top:68px;left:0;right:0;
  background:var(--ink-2,#1e1e1e);
  border-bottom:.5px solid rgba(255,255,255,.07);
  z-index:499;
  flex-direction:column;
  padding:16px 0 20px;
}
.nav-mobile.open{display:flex}
.nav-mobile a{
  padding:13px 32px;
  font-size:15px;
  color:rgba(255,255,255,.6);
  transition:color .15s,background .15s;
  letter-spacing:.2px;
}
.nav-mobile a:hover,.nav-mobile a.active{
  color:#fff;
  background:rgba(255,255,255,.04);
}
.nav-mobile a.active{color:var(--red-lt,#c4183a)}
.nav-mobile-cta{
  margin:8px 32px 0;
  padding:12px 24px;
  background:var(--red,#A7012A);
  color:#fff !important;
  font-size:13px;
  font-weight:500;
  letter-spacing:.4px;
  text-align:center;
}
.nav-mobile-cta:hover{background:var(--red-lt,#c4183a) !important}

@media(max-width:1024px){
  .nav-burger{display:flex}
  .nav-right .nav-phone{display:none}
  .nav-cta{display:none}
}

/* ── Nav auth (Sign in / My Account) ─────────── */
.nav-auth{display:flex;align-items:center}
.nav-auth-link{font-size:13px;color:rgba(255,255,255,.45);margin-right:20px;transition:color .2s;white-space:nowrap;text-decoration:none}
.nav-auth-link:hover{color:#fff}
.nav-auth-account{display:none;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.65);margin-right:20px;transition:color .2s;white-space:nowrap;text-decoration:none}
.nav-auth-account:hover{color:#fff}
.nav-auth-icon{width:8px;height:8px;border-radius:50%;background:var(--red);display:inline-block;flex-shrink:0}
.nav-mobile-auth{padding:13px 32px;font-size:15px;color:rgba(255,255,255,.6);transition:color .15s,background .15s;display:block}
.nav-mobile-auth:hover{color:#fff;background:rgba(255,255,255,.04)}
@media(max-width:1024px){.nav-auth{display:none}}
