/* Trade Show T-Shirt Printing — expo-hall theme (bespoke, 2026-07-01) */
:root{
  --accent:#c1121f;
  --accent-2:#003049;
  --bg:#f2f4f7;
  --ink:#1b2430;
  --surface:#ffffff;
  --muted:#5a6473;
  --line:#dde3ec;
  --navy-tint:#e7edf4;
  --red-tint:#fbe6e8;
  --radius:14px;
  --shadow:0 10px 30px rgba(0,48,73,.08);
  --shadow-lg:0 24px 60px rgba(0,48,73,.14);
  --maxw:1160px;
  --disp:"Oswald",system-ui,sans-serif;
  --body:"IBM Plex Sans",system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--body);color:var(--ink);background:var(--bg);
  line-height:1.6;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--accent)}
h1,h2,h3{font-family:var(--disp);font-weight:600;line-height:1.05;letter-spacing:.01em;margin:0 0 .4em}
h1{font-size:clamp(2.1rem,5.4vw,3.6rem);text-transform:uppercase}
h2{font-size:clamp(1.6rem,3.4vw,2.4rem);text-transform:uppercase}
h3{font-size:1.2rem;text-transform:uppercase;letter-spacing:.03em}
p{margin:0 0 1rem}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* scroll progress */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:100%;background:var(--accent);
  transform:scaleX(0);transform-origin:0 50%;z-index:1200;transition:transform .1s linear}

/* directional-arrow motif divider */
.arrow-rule{height:14px;background:
  repeating-linear-gradient(135deg,var(--accent) 0 18px,transparent 18px 30px);
  opacity:.5;border:0;margin:0}

/* header */
.site-header{position:sticky;top:0;z-index:1100;background:var(--accent-2);color:#fff;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:12px 22px;border-bottom:4px solid var(--accent)}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff}
.brand-mark{display:grid;place-items:center;width:44px;height:44px;border-radius:8px;
  background:var(--accent);color:#fff;font-family:var(--disp);font-size:1.15rem;letter-spacing:.02em;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.25)}
.brand strong{font-family:var(--disp);font-size:1.15rem;letter-spacing:.04em;text-transform:uppercase;display:block;line-height:1}
.brand small{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#a9c1d4}
.nav-toggle{display:none;background:transparent;border:1.5px solid rgba(255,255,255,.4);color:#fff;
  font-family:var(--disp);letter-spacing:.1em;text-transform:uppercase;padding:8px 14px;border-radius:8px;cursor:pointer}
.site-nav{display:flex;gap:6px;flex-wrap:wrap}
.site-nav a{color:#dbe6ef;text-decoration:none;font-weight:600;font-size:.92rem;padding:8px 12px;border-radius:8px;
  text-transform:uppercase;letter-spacing:.05em;font-family:var(--disp);transition:background .15s,color .15s}
.site-nav a:hover{background:rgba(255,255,255,.1);color:#fff}
.site-nav a.cta{background:var(--accent);color:#fff}
.site-nav a.cta:hover{background:#e01e2b}

/* buttons */
.button{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff;text-decoration:none;
  font-family:var(--disp);letter-spacing:.06em;text-transform:uppercase;font-size:1rem;
  padding:13px 22px;border-radius:10px;box-shadow:var(--shadow);transition:transform .12s,background .15s}
.button:hover{transform:translateY(-2px);background:#e01e2b}
.button::after{content:"\2192";font-weight:700}
.button-ghost{background:transparent;color:var(--accent-2);border:2px solid var(--accent-2);box-shadow:none}
.button-ghost::after{content:""}
.button-ghost:hover{background:var(--accent-2);color:#fff}

/* hero — split-left with badge cluster */
.hero{background:
    radial-gradient(1100px 500px at 88% -10%,var(--navy-tint),transparent),
    linear-gradient(180deg,#fff,var(--bg));
  padding:56px 0 44px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:44px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--disp);text-transform:uppercase;
  letter-spacing:.16em;font-size:.8rem;color:var(--accent-2);margin:0 0 14px}
.eyebrow .tag{background:var(--accent);color:#fff;padding:3px 9px;border-radius:5px;letter-spacing:.14em}
.lede{font-size:1.18rem;color:var(--muted);max-width:36ch}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin:22px 0 14px}
.hero-note{font-size:.86rem;color:var(--muted);max-width:44ch}

/* badge card cluster */
.badge-cluster{position:relative;perspective:1000px}
.badge{background:var(--surface);border-radius:16px;box-shadow:var(--shadow-lg);overflow:hidden;
  border:1px solid var(--line);position:relative}
.badge-lanyard{height:26px;background:linear-gradient(90deg,var(--accent),var(--accent-2));
  display:flex;align-items:center;justify-content:center}
.badge-lanyard span{width:44px;height:8px;background:rgba(255,255,255,.65);border-radius:4px}
.badge-body{padding:16px}
.badge-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.badge-tag{background:var(--accent-2);color:#fff;font-family:var(--disp);letter-spacing:.14em;
  text-transform:uppercase;font-size:.7rem;padding:4px 9px;border-radius:5px}
.badge-no{font-family:var(--disp);color:var(--accent);letter-spacing:.1em}
.badge-photo{margin:0;border-radius:10px;overflow:hidden;aspect-ratio:3/2;background:var(--navy-tint)}
.badge-photo img{width:100%;height:100%;object-fit:cover}
.badge-name{font-family:var(--disp);text-transform:uppercase;letter-spacing:.08em;margin:12px 0 2px;font-size:1.1rem}
.badge-role{color:var(--muted);font-size:.85rem;margin:0 0 10px}
.badge-barcode{height:34px;background:repeating-linear-gradient(90deg,var(--ink) 0 2px,transparent 2px 5px);border-radius:4px}
.badge-code{display:block;margin-top:8px;font-size:.7rem;letter-spacing:.1em;color:var(--muted);font-family:var(--disp)}
.badge.tilt-1{transform:rotate(-3deg);position:absolute;inset:14px -10px auto 20px;opacity:.55;z-index:-1}

/* trust strip */
.trust{background:var(--accent-2);color:#fff;padding:26px 0}
.trust .eyebrow{color:#9fbdd2;margin-bottom:10px}
.trust-logos{display:flex;flex-wrap:wrap;gap:10px 26px;align-items:center}
.trust-logos span{font-family:var(--disp);letter-spacing:.1em;text-transform:uppercase;color:#cfe0ec;font-size:.95rem}

/* sections */
section{padding:52px 0}
.section-head{max-width:60ch;margin-bottom:26px}
.section-head p{color:var(--muted)}

/* station lineup (numbered arrow list) */
.stations{display:grid;gap:14px}
.station{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;
  background:var(--surface);border:1px solid var(--line);border-left:5px solid var(--accent);
  border-radius:12px;padding:18px 20px;box-shadow:var(--shadow)}
.station-no{font-family:var(--disp);font-size:1.7rem;color:var(--accent);letter-spacing:.02em}
.station h3{margin:0 0 4px}
.station p{margin:0;color:var(--muted);font-size:.96rem}
.station-tag{font-family:var(--disp);text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;
  color:var(--accent-2);background:var(--navy-tint);padding:6px 11px;border-radius:6px;white-space:nowrap}

/* card grid */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:22px;box-shadow:var(--shadow);
  position:relative;transition:transform .12s,box-shadow .15s}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.card::before{content:"";position:absolute;top:0;left:22px;right:22px;height:3px;background:var(--accent);border-radius:0 0 3px 3px}
.card h3{margin-top:8px}
.card p{color:var(--muted);margin:0}
.card a.cardlink{display:inline-block;margin-top:12px;font-family:var(--disp);text-transform:uppercase;
  letter-spacing:.06em;font-size:.85rem;text-decoration:none}

/* flow steps with arrows */
.flow{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;counter-reset:step}
.flow .step{background:var(--red-tint);border-radius:12px;padding:20px;position:relative}
.flow .step .num{font-family:var(--disp);color:var(--accent);letter-spacing:.1em;font-size:.78rem;text-transform:uppercase}
.flow .step h3{margin:6px 0 6px;font-size:1.05rem}
.flow .step p{margin:0;color:var(--muted);font-size:.92rem}

/* photo grid */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.photo-grid figure{margin:0;border-radius:12px;overflow:hidden;box-shadow:var(--shadow);background:var(--surface);border:1px solid var(--line)}
.photo-grid img{aspect-ratio:4/3;object-fit:cover;width:100%}
.photo-grid figcaption{padding:11px 14px;font-size:.86rem;color:var(--muted)}

/* section with tinted background */
.band-navy{background:var(--accent-2);color:#fff}
.band-navy .section-head p,.band-navy p{color:#c6d7e4}
.band-navy h2,.band-navy h3{color:#fff}
.band-tint{background:var(--navy-tint)}

/* prose */
.prose{max-width:70ch}
.prose h2{margin-top:1.6em}
.prose ul{padding-left:1.2em;color:var(--muted)}
.prose li{margin-bottom:.4em}

/* intent ribbon */
.ribbon{background:var(--accent);color:#fff;padding:16px 0}
.ribbon .wrap{display:flex;flex-wrap:wrap;gap:8px 22px;font-family:var(--disp);text-transform:uppercase;letter-spacing:.08em;font-size:.9rem}
.ribbon span::before{content:"\2192 ";opacity:.7}

/* FAQ */
.faq details{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:4px 18px;margin-bottom:10px}
.faq summary{cursor:pointer;font-family:var(--disp);text-transform:uppercase;letter-spacing:.03em;padding:12px 0;font-size:1rem}
.faq details[open] summary{color:var(--accent)}
.faq p{color:var(--muted);margin:0 0 14px}

/* pricing table */
.ptable{width:100%;border-collapse:collapse;background:var(--surface);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.ptable th,.ptable td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--line)}
.ptable th{background:var(--accent-2);color:#fff;font-family:var(--disp);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem}
.ptable td:last-child{font-weight:600;white-space:nowrap}

/* quote / form */
.quote-band{background:linear-gradient(180deg,var(--bg),#fff)}
.quote-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:36px;align-items:start}
.lead-form{background:var(--surface);border:1px solid var(--line);border-top:5px solid var(--accent);
  border-radius:14px;padding:24px;box-shadow:var(--shadow-lg)}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.lead-form label{display:block;font-family:var(--disp);text-transform:uppercase;letter-spacing:.05em;
  font-size:.78rem;color:var(--accent-2);margin-bottom:14px}
.lead-form input,.lead-form textarea{width:100%;margin-top:6px;padding:11px 12px;border:1px solid var(--line);
  border-radius:9px;font-family:var(--body);font-size:1rem;background:#fbfcfe;color:var(--ink)}
.lead-form input:focus,.lead-form textarea:focus{outline:2px solid var(--accent);border-color:var(--accent)}
.hp-wrap{position:absolute;left:-9999px;height:0;overflow:hidden}
.form-submit{width:100%;margin-top:6px;background:var(--accent);color:#fff;border:0;cursor:pointer;
  font-family:var(--disp);text-transform:uppercase;letter-spacing:.06em;font-size:1.05rem;padding:15px;border-radius:10px;transition:background .15s}
.form-submit:hover{background:#e01e2b}
.form-note{font-size:.82rem;color:var(--muted);margin:12px 0 0}
.lead-form.is-success{border-top-color:#1a7f4b}

/* breadcrumb */
.crumbs{font-size:.82rem;color:var(--muted);padding:14px 0 0}
.crumbs a{color:var(--accent-2);text-decoration:none}
.crumbs a:hover{text-decoration:underline}

/* subpage hero */
.page-hero{background:var(--accent-2);color:#fff;padding:44px 0 40px;border-bottom:4px solid var(--accent)}
.page-hero h1{color:#fff}
.page-hero .lede{color:#c6d7e4;max-width:60ch}
.page-hero .eyebrow{color:#9fbdd2}

/* footer */
.site-footer{background:var(--ink);color:#c4ccd6;padding:40px 0}
.site-footer .wrap{display:grid;grid-template-columns:1.4fr 1fr;gap:26px}
.site-footer strong{color:#fff;font-family:var(--disp);text-transform:uppercase;letter-spacing:.06em;font-size:1.1rem;display:block;margin-bottom:8px}
.site-footer p{font-size:.9rem;max-width:44ch}
.site-footer nav{display:flex;flex-direction:column;gap:8px}
.site-footer a{color:#c4ccd6;text-decoration:none;font-size:.92rem}
.site-footer a:hover{color:#fff}
.foot-contact{margin-top:14px;font-size:.9rem}
.foot-contact a{color:#fff;font-weight:600}

/* utility */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center}
.grid-2 img{border-radius:12px;box-shadow:var(--shadow);aspect-ratio:4/3;object-fit:cover;width:100%}
.center{text-align:center}
.mt{margin-top:22px}

@media(max-width:860px){
  .hero-grid,.quote-grid,.grid-2,.site-footer .wrap{grid-template-columns:1fr}
  .badge.tilt-1{display:none}
  .station{grid-template-columns:auto 1fr}
  .station-tag{grid-column:2;justify-self:start}
}
@media(max-width:680px){
  .nav-toggle{display:block}
  .site-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--accent-2);
    flex-direction:column;padding:12px 18px;border-bottom:4px solid var(--accent)}
  .site-nav.is-open{display:flex}
  .site-header{position:relative}
  .field-grid{grid-template-columns:1fr}
}
