/* ============================================================
   Kellie's Corner Thrift & Boutique — Shared Stylesheet
   Warm vintage aesthetic · Mobile-first
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --cream:       #faf6ef;
  --cream-warm:  #f2e8d9;
  --cream-deep:  #e8d9c4;
  --brown:       #5c3d2e;
  --brown-mid:   #7a5540;
  --brown-soft:  #a07858;
  --brown-faint: #c9a882;
  --rust:        #b85c38;
  --rust-dk:     #8f4428;
  --rust-lt:     #f5e6de;
  --teal:        #2d6e6e;
  --teal-lt:     #e0f0f0;
  --gold:        #c49a2a;
  --gold-lt:     #fdf4dc;
  --ink:         #2c1f14;
  --ink-mid:     #4a3728;
  --ink-soft:    #7a6555;
  --ink-faint:   #b0998a;
  --border:      rgba(92,61,46,0.12);
  --border-md:   rgba(92,61,46,0.22);
  --shadow-sm:   0 2px 8px rgba(92,61,46,.08);
  --shadow-md:   0 6px 24px rgba(92,61,46,.10);
  --shadow-lg:   0 16px 48px rgba(92,61,46,.14);
  --radius:      8px;
  --radius-lg:   14px;
  --radius-xl:   22px;
  --font-head:   'Playfair Display', Georgia, serif;
  --font-body:   'Lato', system-ui, sans-serif;
  --max:         1100px;
  --nav-h:       70px;
}

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

/* ── LAYOUT ── */
.container  { max-width: var(--max); margin: 0 auto; padding: 0 20px; }
.section    { padding: 64px 0; }
.section-sm { padding: 44px 0; }
@media (min-width: 768px) { .container { padding: 0 28px; } .section { padding: 88px 0; } .section-sm { padding: 56px 0; } }

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4 { font-family: var(--font-head); line-height: 1.15; color: var(--ink); }
h1 { font-size: clamp(32px, 7vw, 62px); }
h2 { font-size: clamp(24px, 5vw, 44px); }
h3 { font-size: clamp(17px, 3vw, 24px); }
h4 { font-size: 16px; }
p  { font-size: 15px; color: var(--ink-mid); line-height: 1.75; }
em { font-style: italic; color: var(--rust); }
@media (min-width: 768px) { p { font-size: 16px; } }

.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 11px; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--rust); margin-bottom: 12px;
  font-family: var(--font-body);
}
.eyebrow::before { content: '✦'; font-size: 9px; }

.section-intro { max-width: 560px; margin-bottom: 40px; }
.section-intro p { font-size: 16px; margin-top: 10px; }
@media (min-width: 768px) { .section-intro { margin-bottom: 52px; } }

/* ── TAGS ── */
.tag { display:inline-block; font-size:11px; font-weight:700; letter-spacing:.07em; text-transform:uppercase; padding:4px 10px; border-radius:4px; font-family:var(--font-body); }
.tag-rust  { background:var(--rust-lt);  color:var(--rust); }
.tag-teal  { background:var(--teal-lt);  color:var(--teal); }
.tag-gold  { background:var(--gold-lt);  color:var(--gold); }
.tag-brown { background:var(--cream-deep); color:var(--brown-mid); }

/* ── BUTTONS — minimum 44px touch target ── */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:7px; font-family:var(--font-body); font-weight:700; border:none; border-radius:var(--radius); cursor:pointer; text-decoration:none; transition:all .2s; white-space:nowrap; letter-spacing:.02em; min-height:44px; }
.btn-sm  { font-size:13px; padding: 8px 16px; }
.btn-md  { font-size:14px; padding:10px 20px; }
.btn-lg  { font-size:15px; padding:13px 26px; border-radius:10px; }
.btn-xl  { font-size:16px; padding:15px 30px; border-radius:12px; }
.btn-primary     { background:var(--rust); color:#fff; }
.btn-primary:hover { background:var(--rust-dk); transform:translateY(-1px); box-shadow:0 4px 16px rgba(184,92,56,.35); }
.btn-outline     { background:transparent; border:2px solid var(--brown); color:var(--brown); }
.btn-outline:hover { background:var(--brown); color:var(--cream); }
.btn-outline-rust { background:transparent; border:2px solid var(--rust); color:var(--rust); }
.btn-outline-rust:hover { background:var(--rust); color:#fff; }
.btn-teal   { background:var(--teal); color:#fff; }
.btn-teal:hover { background:#215555; transform:translateY(-1px); }
.btn-cream  { background:var(--cream); color:var(--brown); border:2px solid var(--cream-deep); }
.btn-cream:hover { background:var(--cream-warm); }
.btn-outline-white { background:transparent; border:2px solid rgba(250,246,239,.4); color:rgba(250,246,239,.9); }
.btn-outline-white:hover { background:rgba(250,246,239,.1); border-color:rgba(250,246,239,.7); }

/* ── NAV ── */
.site-nav {
  position: sticky; top: 0; z-index: 200; height: var(--nav-h);
  background: rgba(250,246,239,.97); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}
.nav-inner { display:flex; align-items:center; justify-content:space-between; height:100%; gap:12px; padding:0 20px; }
@media (min-width: 768px) { .nav-inner { padding:0 28px; } }
.nav-logo  { font-family:var(--font-head); font-size:18px; color:var(--ink); text-decoration:none; line-height:1.1; flex-shrink:0; }
.nav-logo span { color:var(--rust); }
.nav-logo small { display:none; font-size:10px; font-family:var(--font-body); letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); font-weight:400; }
@media (min-width: 480px) { .nav-logo small { display:block; } .nav-logo { font-size:20px; } }
.nav-links { display:none; align-items:center; gap:24px; list-style:none; }
.nav-links a { font-size:14px; font-weight:700; color:var(--ink-soft); text-decoration:none; transition:color .15s; font-family:var(--font-body); padding:4px 0; border-bottom:2px solid transparent; }
.nav-links a:hover, .nav-links a.active { color:var(--rust); border-bottom-color:var(--rust); }
.nav-ebay { display:none; }
.nav-toggle { display:flex; background:none; border:1px solid var(--border); border-radius:var(--radius); cursor:pointer; padding:8px; flex-direction:column; gap:4px; min-width:44px; min-height:44px; align-items:center; justify-content:center; flex-shrink:0; }
.nav-toggle span { display:block; width:20px; height:2px; background:var(--ink); border-radius:2px; transition:all .2s; }
@media (min-width: 900px) {
  .nav-links { display:flex; }
  .nav-ebay  { display:inline-flex; }
  .nav-toggle { display:none; }
}
.nav-mobile { display:none; position:fixed; inset:var(--nav-h) 0 0 0; background:var(--cream); z-index:199; padding:28px 20px; flex-direction:column; gap:4px; overflow-y:auto; }
.nav-mobile.open { display:flex; }
.nav-mobile a { font-size:20px; font-family:var(--font-head); color:var(--ink); text-decoration:none; padding:16px 0; border-bottom:1px solid var(--border); display:block; }
.nav-mobile .btn { margin-top:20px; }

/* ── FOOTER ── */
.site-footer { background:var(--brown); color:rgba(250,246,239,.65); padding:56px 0 32px; }
.footer-grid { display:grid; grid-template-columns:1fr; gap:32px; margin-bottom:40px; }
@media (min-width: 600px) { .footer-grid { grid-template-columns:1fr 1fr; gap:36px; } }
@media (min-width: 900px) { .footer-grid { grid-template-columns:2fr 1fr 1fr; gap:48px; } }
.footer-logo { font-family:var(--font-head); font-size:22px; color:var(--cream); text-decoration:none; }
.footer-logo span { color:var(--brown-faint); }
.footer-brand p { font-size:14px; margin-top:12px; line-height:1.7; }
.footer-col h5 { font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(250,246,239,.35); margin-bottom:14px; font-family:var(--font-body); }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col ul a { font-size:14px; color:rgba(250,246,239,.6); text-decoration:none; transition:color .15s; }
.footer-col ul a:hover { color:var(--cream); }
.footer-bottom { border-top:1px solid rgba(250,246,239,.1); padding-top:24px; display:flex; flex-direction:column; gap:8px; font-size:13px; }
@media (min-width: 600px) { .footer-bottom { flex-direction:row; justify-content:space-between; align-items:center; } }
.footer-ebay-badge { display:inline-flex; align-items:center; gap:8px; background:rgba(250,246,239,.08); border:1px solid rgba(250,246,239,.12); border-radius:8px; padding:10px 14px; font-size:13px; color:rgba(250,246,239,.7); text-decoration:none; transition:all .15s; margin-top:16px; }
.footer-ebay-badge:hover { background:rgba(250,246,239,.14); color:var(--cream); }

/* ── PRODUCT / LISTING CARDS ── */
.listing-grid { display:grid; grid-template-columns:repeat(2, 1fr); gap:12px; }
@media (min-width: 480px)  { .listing-grid { gap:14px; } }
@media (min-width: 640px)  { .listing-grid { grid-template-columns:repeat(3, 1fr); } }
@media (min-width: 900px)  { .listing-grid { grid-template-columns:repeat(auto-fill, minmax(200px, 1fr)); gap:16px; } }

.listing-card { border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--border); background:var(--cream); transition:all .2s; text-decoration:none; display:block; }
.listing-card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); }
.listing-img { aspect-ratio:1; overflow:hidden; background:var(--cream-warm); }
.listing-img img { width:100%; height:100%; object-fit:cover; transition:transform .3s; }
.listing-card:hover .listing-img img { transform:scale(1.05); }
.listing-body { padding:10px; }
@media (min-width: 600px) { .listing-body { padding:14px; } }
.listing-body h3 { font-size:12px; color:var(--ink); margin-bottom:5px; line-height:1.35; font-family:var(--font-body); font-weight:700; }
@media (min-width: 600px) { .listing-body h3 { font-size:13px; } }
.listing-price { font-size:14px; font-weight:700; color:var(--rust); font-family:var(--font-body); }

/* ── CATEGORY CARDS ── */
.category-grid { display:grid; grid-template-columns:repeat(2, 1fr); gap:12px; }
@media (min-width: 600px) { .category-grid { grid-template-columns:repeat(3, 1fr); gap:14px; } }
@media (min-width: 900px) { .category-grid { grid-template-columns:repeat(6, 1fr); gap:16px; } }

.cat-card { background:var(--cream-warm); border:1px solid var(--border); border-radius:var(--radius-lg); padding:20px 14px; text-align:center; text-decoration:none; transition:all .2s; display:block; }
@media (min-width: 600px) { .cat-card { padding:28px 20px; } }
.cat-card:hover { background:var(--rust); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.cat-card:hover .cat-icon, .cat-card:hover h3, .cat-card:hover p { color:#fff !important; }
.cat-icon { font-size:26px; margin-bottom:10px; display:block; }
@media (min-width: 600px) { .cat-icon { font-size:32px; } }
.cat-card h3 { font-size:14px; margin-bottom:3px; color:var(--ink); font-family:var(--font-head); }
.cat-card p  { font-size:11px; color:var(--ink-soft); display:none; }
@media (min-width: 600px) { .cat-card p { display:block; font-size:12px; } }

/* ── PAGE HERO ── */
.page-hero { background:var(--cream-warm); padding:48px 0 44px; border-bottom:1px solid var(--border); }
@media (min-width: 768px) { .page-hero { padding:64px 0 56px; } }
.page-hero h1 { margin-bottom:12px; }
.page-hero p  { font-size:16px; max-width:560px; }
@media (min-width: 768px) { .page-hero p { font-size:18px; } }

/* ── TRUST BADGES ── */
.trust-row { display:flex; flex-wrap:wrap; gap:12px; align-items:center; }
.trust-item { display:flex; align-items:center; gap:7px; font-size:13px; color:var(--ink-soft); font-family:var(--font-body); }
.trust-item .dot { width:16px; height:16px; border-radius:50%; background:var(--teal-lt); display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:9px; color:var(--teal); font-weight:700; }

/* ── TRUST STRIP ── */
.trust-strip { background:var(--brown); padding:36px 0; }
@media (min-width:768px) { .trust-strip { padding:44px 0; } }
.trust-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
@media (min-width:768px) { .trust-grid { grid-template-columns:repeat(4,1fr); } }
.trust-cell  { text-align:center; }
.trust-cell .icon { font-size:26px; margin-bottom:8px; }
@media (min-width:768px) { .trust-cell .icon { font-size:30px; } }
.trust-cell h4 { font-size:13px; font-weight:700; color:var(--cream); font-family:var(--font-body); margin-bottom:3px; }
.trust-cell p  { font-size:11px; color:rgba(250,246,239,.55); }

/* ── HERO ── */
.hero { position:relative; overflow:hidden; background:var(--cream-warm); border-bottom:1px solid var(--border); }
.hero-inner { padding:48px 0 56px; }
@media (min-width:768px) { .hero-inner { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; padding:72px 0 80px; } }
.hero-kicker { font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--rust); margin-bottom:14px; font-family:var(--font-body); display:flex; align-items:center; gap:8px; }
.hero-kicker::before { content:''; width:20px; height:1px; background:var(--rust); }
.hero h1 { margin-bottom:16px; }
.hero-sub { font-size:16px; color:var(--ink-mid); margin-bottom:28px; line-height:1.75; }
@media (min-width:768px) { .hero-sub { font-size:17px; max-width:440px; margin-bottom:32px; } }
.hero-btns { display:flex; flex-direction:column; gap:10px; margin-bottom:32px; }
@media (min-width:480px) { .hero-btns { flex-direction:row; flex-wrap:wrap; gap:12px; } }
.hero-stats { display:flex; gap:24px; flex-wrap:wrap; padding-top:24px; border-top:1px solid var(--border); }
.stat-item { text-align:left; }
.stat-num  { font-family:var(--font-head); font-size:24px; color:var(--ink); line-height:1; }
@media (min-width:600px) { .stat-num { font-size:28px; } }
.stat-lbl  { font-size:11px; color:var(--ink-soft); margin-top:3px; font-family:var(--font-body); text-transform:uppercase; letter-spacing:.06em; }

/* Hero image */
.hero-visual { display:none; position:relative; }
@media (min-width:768px) { .hero-visual { display:block; } }
.hero-mobile-img { display:block; width:100%; aspect-ratio:16/9; object-fit:cover; border-radius:var(--radius-lg); margin-bottom:28px; }
@media (min-width:768px) { .hero-mobile-img { display:none; } }
.hero-collage { display:grid; grid-template-columns:1fr 1fr; grid-template-rows:1fr 1fr; gap:10px; aspect-ratio:1; }
.collage-img { border-radius:var(--radius-lg); overflow:hidden; background:var(--cream-deep); }
.collage-img img { width:100%; height:100%; object-fit:cover; }
.collage-img.tall { grid-row:1/3; }
.collage-badge { position:absolute; bottom:-16px; right:-16px; background:var(--rust); color:#fff; border-radius:var(--radius-lg); padding:14px 18px; box-shadow:var(--shadow-md); text-align:center; }
.collage-badge .big { font-family:var(--font-head); font-size:22px; line-height:1; }
.collage-badge .sm  { font-size:11px; opacity:.85; margin-top:3px; font-family:var(--font-body); }

/* ── CRAFT SECTION ── */
.craft-inner, .craft-grid { display:flex; flex-direction:column; gap:36px; }
@media (min-width:768px) { 
  .craft-inner { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
  .craft-grid  { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
  .craft-grid.flip { direction:rtl; }
  .craft-grid.flip > * { direction:ltr; }
}
.craft-img, .craft-img-wrap { border-radius:var(--radius-xl); overflow:hidden; background:var(--cream-warm); box-shadow:var(--shadow-md); aspect-ratio:4/3; display:flex; align-items:center; justify-content:center; }
.craft-img-ph, .craft-img-placeholder { text-align:center; padding:32px; }
.craft-img-ph .icon, .craft-img-placeholder .icon { font-size:56px; opacity:.35; }
@media (min-width:600px) { .craft-img-ph .icon, .craft-img-placeholder .icon { font-size:72px; } }
.craft-img-ph p, .craft-img-placeholder p { font-size:13px; color:var(--ink-faint); margin-top:10px; }
.craft-bullets { list-style:none; display:flex; flex-direction:column; gap:10px; margin:18px 0 24px; }
.craft-bullets li { display:flex; align-items:flex-start; gap:10px; font-size:14px; color:var(--ink-mid); }
.craft-bullets li::before { content:'✦'; color:var(--rust); font-size:10px; margin-top:4px; flex-shrink:0; }

/* ── ABOUT ── */
.about-hero-inner { display:flex; flex-direction:column; gap:36px; }
@media (min-width:768px) { .about-hero-inner { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; } }
.about-img { border-radius:var(--radius-xl); overflow:hidden; background:var(--cream-deep); box-shadow:var(--shadow-lg); aspect-ratio:3/4; display:flex; align-items:center; justify-content:center; }
.story-inner { display:flex; flex-direction:column; gap:36px; }
@media (min-width:900px) { .story-inner { display:grid; grid-template-columns:1.1fr 1fr; gap:64px; align-items:start; } }
blockquote { border-left:3px solid var(--rust); padding:16px 20px; background:var(--rust-lt); border-radius:0 10px 10px 0; margin:20px 0; }
blockquote p { font-family:var(--font-head); font-size:17px; color:var(--ink); font-style:italic; margin-bottom:6px; }
blockquote cite { font-size:13px; color:var(--ink-soft); font-style:normal; font-family:var(--font-body); }
.values-grid { display:flex; flex-direction:column; gap:14px; }
.value-item { display:flex; align-items:flex-start; gap:12px; padding:16px; background:var(--cream-warm); border-radius:var(--radius-lg); }
.value-icon { width:38px; height:38px; border-radius:10px; background:var(--rust-lt); display:flex; align-items:center; justify-content:center; font-size:17px; flex-shrink:0; }
.value-item h4 { font-size:14px; margin-bottom:3px; font-family:var(--font-body); font-weight:700; }
.value-item p  { font-size:13px; }
.stats-row { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:32px; }
.stat-box { background:var(--brown); border-radius:var(--radius-lg); padding:20px 12px; text-align:center; }
.stat-box .num { font-family:var(--font-head); font-size:28px; color:var(--cream); line-height:1; }
@media (min-width:600px) { .stat-box .num { font-size:34px; } }
.stat-box .lbl { font-size:11px; color:rgba(250,246,239,.55); margin-top:6px; font-family:var(--font-body); text-transform:uppercase; letter-spacing:.06em; }

/* ── CONTACT ── */
.contact-layout { display:flex; flex-direction:column; gap:40px; padding:48px 0 72px; }
@media (min-width:768px) { .contact-layout { display:grid; grid-template-columns:1fr 1fr; gap:56px; padding:64px 0 88px; align-items:start; } }
.contact-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius-xl); padding:28px; box-shadow:var(--shadow-sm); }
@media (min-width:600px) { .contact-card { padding:36px; } }
.contact-card h2 { margin-bottom:8px; }
.contact-card .sub { font-size:14px; color:var(--ink-soft); margin-bottom:28px; }
.contact-option { display:flex; align-items:flex-start; gap:14px; padding:18px; background:var(--cream-warm); border-radius:var(--radius-lg); margin-bottom:10px; text-decoration:none; transition:all .15s; border:1px solid transparent; }
.contact-option:hover { border-color:var(--rust); background:var(--rust-lt); }
.contact-option .opt-icon { width:42px; height:42px; border-radius:12px; background:var(--rust-lt); display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.contact-option:hover .opt-icon { background:#fff; }
.contact-option h4 { font-size:14px; font-weight:700; color:var(--ink); margin-bottom:3px; font-family:var(--font-body); }
.contact-option p  { font-size:13px; color:var(--ink-soft); }
.faq-item { border-bottom:1px solid var(--border); padding:18px 0; }
.faq-item:last-child { border-bottom:none; }
.faq-item h3 { font-size:15px; margin-bottom:8px; color:var(--ink); font-family:var(--font-body); font-weight:700; }
.faq-item p  { font-size:14px; }

/* ── SHOP ── */
.shop-note { background:var(--gold-lt); border:1px solid rgba(196,154,42,.2); border-radius:var(--radius-lg); padding:14px 18px; display:flex; align-items:flex-start; gap:10px; margin-bottom:32px; font-size:14px; color:var(--ink-mid); }
.cat-section { padding:48px 0; border-bottom:1px solid var(--border); }
.cat-section:last-child { border-bottom:none; }
.cat-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:24px; flex-wrap:wrap; gap:12px; }
.cat-header h2 { font-size:clamp(20px,4vw,30px); }
.ebay-cta-box { background:var(--brown); border-radius:var(--radius-xl); padding:36px 24px; text-align:center; margin-top:48px; }
@media (min-width:600px) { .ebay-cta-box { padding:48px; } }
.ebay-cta-box h2 { color:var(--cream); margin-bottom:12px; }
.ebay-cta-box p  { color:rgba(250,246,239,.65); margin-bottom:24px; max-width:480px; margin-left:auto; margin-right:auto; }

/* ── HANDCRAFTED ── */
.craft-hero { background:var(--cream-warm); padding:56px 0 52px; border-bottom:1px solid var(--border); }
@media (min-width:768px) { .craft-hero { padding:80px 0 72px; } }
.craft-hero-inner { display:flex; flex-direction:column; gap:36px; }
@media (min-width:768px) { .craft-hero-inner { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; } }
.craft-hero h1 { margin-bottom:16px; }
.craft-hero p  { font-size:16px; margin-bottom:24px; }
.craft-section { padding:52px 0; border-bottom:1px solid var(--border); }
.craft-section:last-of-type { border-bottom:none; }
.handcrafted-promise { display:grid; grid-template-columns:1fr; gap:16px; margin-bottom:48px; }
@media (min-width:600px) { .handcrafted-promise { grid-template-columns:repeat(3,1fr); } }
.promise-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:24px; text-align:center; }
.promise-card .icon { font-size:28px; margin-bottom:12px; }
.promise-card h3 { font-size:17px; margin-bottom:8px; }
.promise-card p  { font-size:14px; }
.ebay-note { background:var(--gold-lt); border:1px solid rgba(196,154,42,.2); border-radius:var(--radius-lg); padding:16px 20px; display:flex; align-items:flex-start; gap:12px; margin-top:24px; }
.ebay-note p { font-size:14px; margin:0; }
.custom-section { background:var(--brown); border-radius:var(--radius-xl); padding:40px 24px; text-align:center; margin:48px 0; }
@media (min-width:600px) { .custom-section { padding:56px; } }
.custom-section h2 { color:var(--cream); margin-bottom:12px; }
.custom-section p  { color:rgba(250,246,239,.65); max-width:480px; margin:0 auto 24px; }

/* ── 404 ── */
.error-page { min-height:calc(100vh - var(--nav-h) - 180px); display:flex; align-items:center; justify-content:center; padding:60px 20px; }
.error-inner { text-align:center; max-width:520px; }
.error-num { font-family:var(--font-head); font-size:clamp(80px,20vw,150px); line-height:1; color:var(--cream-deep); -webkit-text-stroke:2px var(--border-md); margin-bottom:8px; display:block; }
.error-inner h1 { margin-bottom:14px; }
.error-links { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-bottom:36px; }

/* ── UTILITY FLEX HELPERS ── */
.flex-col    { display:flex; flex-direction:column; gap:12px; }
.flex-row    { display:flex; flex-wrap:wrap; gap:12px; }
@media (min-width:480px) { .flex-col-to-row { flex-direction:row; } }
