/* ============================================================
   AG Shopfitters — Cape Town editorial craftsman aesthetic
   ============================================================ */
:root {
  --bg: #f5efe6;
  --ink: #181412;
  --ink-soft: rgba(24,20,18,.7);
  --ink-mute: rgba(24,20,18,.55);
  --ink-line: rgba(24,20,18,.15);
  --primary: #c12227;
  --primary-foreground: #fbf8f3;
  --background: #f5efe6;
  --foreground: #181412;
  --serif: 'Fraunces', Georgia, serif;
  --sans: 'Albert Sans', system-ui, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--sans);
  background: var(--background);
  color: var(--foreground);
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--primary); color: var(--primary-foreground); }

.container { max-width: 1400px; margin: 0 auto; padding: 0 24px; }
@media (min-width: 768px) { .container { padding: 0 40px; } }

.display { font-family: var(--serif); font-optical-sizing: auto; font-weight: 300; letter-spacing: -.01em; }
.accent { color: var(--primary); font-style: italic; font-weight: 400; }
.caps { font-size: 11px; letter-spacing: .28em; text-transform: uppercase; }

/* Eyebrow */
.eyebrow { display: flex; align-items: center; gap: 12px; font-size: 11px; font-weight: 500; letter-spacing: .28em; text-transform: uppercase; color: var(--ink-soft); }
.eyebrow .bar { display: block; width: 40px; height: 1px; background: var(--primary); }
.eyebrow-light { color: rgba(255,255,255,.6); }

/* Buttons */
.btn { display: inline-flex; align-items: center; gap: 12px; padding: 14px 24px; border-radius: 3px; font-size: 13px; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; transition: all .25s ease; cursor: pointer; border: none; }
.btn span { transition: transform .25s ease; }
.btn:hover span { transform: translateX(4px); }
.btn-primary { background: var(--primary); color: var(--primary-foreground); box-shadow: 0 20px 40px -20px rgba(193,34,39,.55); }
.btn-primary:hover { background: var(--ink); transform: translateY(-2px); }
.btn-dark { background: var(--ink); color: var(--background); padding: 10px 20px; }
.btn-dark:hover { background: var(--primary); }
.link-underline { display: inline-block; padding-bottom: 4px; border-bottom: 1px solid var(--ink-line); font-size: 13px; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; transition: all .2s; }
.link-underline:hover { border-color: var(--primary); color: var(--primary); }
.link-quiet { font-size: 13px; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); transition: color .2s; }
.link-quiet:hover { color: var(--primary); }

/* Header */
.site-header { position: absolute; inset: 0 0 auto 0; z-index: 30; }
.header-row { display: flex; align-items: center; justify-content: space-between; padding: 24px 0; }
.brand { display: flex; align-items: center; gap: 12px; }
.brand img { width: 40px; height: 40px; object-fit: contain; }
.brand-name { font-family: var(--serif); font-size: 16px; font-weight: 600; letter-spacing: -.01em; }
.nav { display: none; align-items: center; gap: 36px; font-size: 14px; font-weight: 500; color: var(--ink-soft); }
.nav a { transition: color .2s; }
.nav a:hover { color: var(--primary); }
@media (min-width: 768px) { .nav { display: flex; } }

/* Hero */
.hero { position: relative; min-height: 100vh; overflow: hidden; background: var(--background); background-image: radial-gradient(rgba(24,20,18,.08) 1px, transparent 1px); background-size: 4px 4px; }
.hero-grid { display: grid; grid-template-columns: 1fr; gap: 40px; padding-top: 128px; padding-bottom: 48px; min-height: 100vh; }
@media (min-width: 1024px) { .hero-grid { grid-template-columns: 7fr 5fr; gap: 48px; padding-top: 160px; } }
.hero-left { display: flex; flex-direction: column; justify-content: space-between; }
.headline { font-size: clamp(3rem, 8.5vw, 7.5rem); line-height: .92; letter-spacing: -.035em; margin: 32px 0 0; color: var(--ink); }
.lede { max-width: 36rem; margin: 40px 0 0; font-size: 18px; line-height: 1.65; color: var(--ink-soft); }
.cta-row { display: flex; flex-wrap: wrap; align-items: center; gap: 16px; margin-top: 40px; }
.stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin: 56px 0 0; padding-top: 32px; border-top: 1px solid var(--ink-line); }
.stats dt { font-size: 36px; font-weight: 500; letter-spacing: -.02em; color: var(--ink); margin: 0; }
.stats dd { margin: 4px 0 0; font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-mute); }

/* Hero right */
.hero-image-wrap { position: relative; height: 420px; }
@media (min-width: 640px) { .hero-image-wrap { height: 540px; } }
@media (min-width: 1024px) { .hero-image-wrap { height: 100%; min-height: 640px; } }
.hero-plate { display: none; position: absolute; inset: -16px auto auto -16px; width: 100%; height: 100%; background: var(--primary); border-radius: 3px; }
@media (min-width: 1024px) { .hero-plate { display: block; } }
.hero-image { position: relative; height: 100%; width: 100%; overflow: hidden; border-radius: 3px; box-shadow: 0 40px 80px -30px rgba(24,20,18,.5); }
.hero-image img { height: 100%; width: 100%; object-fit: cover; animation: slow-zoom 12s ease-out both; }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(24,20,18,.5), transparent 50%); pointer-events: none; }
.hero-badge-row { position: absolute; inset: auto 24px 24px 24px; display: flex; align-items: end; justify-content: space-between; gap: 16px; }
.hero-badge { background: rgba(245,239,230,.95); padding: 12px 16px; border-radius: 3px; backdrop-filter: blur(8px); }
.hero-badge p { margin: 0; }
.hero-badge .small { font-size: 14px; margin-top: 4px; color: var(--ink); }
.hero-pill { display: none; padding: 8px 16px; border: 1px solid rgba(245,239,230,.3); background: rgba(245,239,230,.1); border-radius: 999px; font-size: 11px; font-weight: 500; letter-spacing: .22em; text-transform: uppercase; color: var(--background); backdrop-filter: blur(8px); }
@media (min-width: 640px) { .hero-pill { display: block; } }

/* Marquee */
.marquee { position: relative; margin-top: 8px; overflow: hidden; border-top: 1px solid var(--ink-line); border-bottom: 1px solid var(--ink-line); background: var(--ink); color: var(--background); padding: 20px 0; }
.marquee-track { display: flex; width: max-content; gap: 56px; white-space: nowrap; font-family: var(--serif); font-size: 28px; letter-spacing: -.01em; animation: marquee 40s linear infinite; }
.marquee-item { display: flex; align-items: center; gap: 56px; }
.marquee-item em { font-style: italic; font-weight: 300; }
.marquee-item .star { color: var(--primary); }

/* Ridgeline divider */
.ridge-divider { background: var(--background); padding: 40px 0; }
.ridge-inner { display: flex; align-items: center; gap: 24px; color: var(--ink-mute); }
.ridge-label { display: none; font-family: var(--serif); font-size: 10px; letter-spacing: .32em; text-transform: uppercase; }
@media (min-width: 640px) { .ridge-label { display: inline; } }
.ridge-svg-wrap { position: relative; flex: 1; height: 80px; color: var(--ink); }
.ridge-svg-wrap.flip { transform: scaleX(-1); }
.ridge-svg-wrap svg { position: absolute; inset: 0; height: 100%; width: 100%; }

/* Sections */
.section { background: var(--background); padding: 96px 0; }
@media (min-width: 768px) { .section { padding: 128px 0; } }
.section-dark { background: var(--ink); color: var(--background); }
.section-title { font-size: clamp(2.25rem, 5vw, 4rem); line-height: 1.02; letter-spacing: -.025em; margin: 24px 0 0; }

/* Grid helpers */
.grid-12 { display: grid; grid-template-columns: 1fr; gap: 48px; }
@media (min-width: 1024px) { .grid-12 { grid-template-columns: repeat(12, 1fr); gap: 64px; } .col-5 { grid-column: span 5; } .col-6 { grid-column: span 6; } .col-7 { grid-column: span 7; } }

/* About */
.about-body { display: flex; flex-direction: column; gap: 24px; }
.lede-lg { font-size: 24px; line-height: 1.45; color: rgba(24,20,18,.85); margin: 0; }
.body { font-size: 16px; line-height: 1.7; color: var(--ink-soft); margin: 0; }
.mini-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; padding-top: 32px; margin-top: 16px; border-top: 1px solid var(--ink-line); }
@media (min-width: 640px) { .mini-stats { grid-template-columns: repeat(3, 1fr); } }
.mini-stats p:first-child { margin: 0; font-size: 24px; color: var(--ink); }
.mini-stats p.caps { margin: 4px 0 0; color: var(--ink-mute); }

/* Services */
.services-head { display: flex; flex-direction: column; gap: 32px; align-items: flex-start; }
@media (min-width: 768px) { .services-head { flex-direction: row; justify-content: space-between; align-items: end; } }
.services-intro { max-width: 28rem; font-size: 14px; line-height: 1.7; color: rgba(255,255,255,.65); }
.services-grid { display: grid; grid-template-columns: 1fr; gap: 1px; background: rgba(245,239,230,.15); border-radius: 3px; overflow: hidden; margin-top: 64px; }
@media (min-width: 640px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .services-grid { grid-template-columns: repeat(3, 1fr); } }
.svc { position: relative; display: flex; flex-direction: column; gap: 16px; padding: 32px; background: var(--ink); transition: background .3s; }
@media (min-width: 768px) { .svc { padding: 40px; } }
.svc:hover { background: #211b18; }
.svc-top { display: flex; align-items: center; justify-content: space-between; }
.svc-top .arrow { color: rgba(245,239,230,.4); transition: all .2s; }
.svc:hover .svc-top .arrow { color: var(--primary); transform: translateX(4px); }
.svc h3 { font-size: 24px; font-weight: 300; margin: 0; }
.svc p { font-size: 14px; line-height: 1.7; color: rgba(245,239,230,.65); margin: 0; }

/* Portfolio */
.portfolio-head { display: flex; align-items: end; justify-content: space-between; gap: 32px; }
.portfolio-head .link-quiet { display: none; }
@media (min-width: 768px) { .portfolio-head .link-quiet { display: inline; } }
.portfolio-grid { display: grid; grid-template-columns: 1fr; gap: 32px; margin-top: 64px; }
@media (min-width: 768px) { .portfolio-grid { grid-template-columns: repeat(2, 1fr); gap: 40px; } .portfolio-grid figure.offset { margin-top: 64px; } }
.portfolio-grid figure { margin: 0; }
.portfolio-grid .img-wrap { position: relative; overflow: hidden; border-radius: 3px; background: rgba(24,20,18,.05); }
.portfolio-grid img { height: 420px; width: 100%; object-fit: cover; transition: transform .7s cubic-bezier(.22,1,.36,1); }
@media (min-width: 768px) { .portfolio-grid img { height: 520px; } }
.portfolio-grid figure:hover img { transform: scale(1.04); }
.portfolio-grid .img-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(24,20,18,.55), transparent 50%); pointer-events: none; }
.portfolio-grid figcaption { display: flex; align-items: end; justify-content: space-between; gap: 24px; margin-top: 20px; }
.portfolio-grid figcaption .display { font-size: 22px; margin: 8px 0 0; color: var(--ink); }
.portfolio-grid figcaption .year { font-size: 14px; color: var(--ink-mute); margin: 0; }
.portfolio-grid figcaption .caps { color: var(--primary); }

/* Process */
.process-grid { list-style: none; padding: 0; margin: 64px 0 0; display: grid; grid-template-columns: 1fr; gap: 1px; background: var(--ink-line); border: 1px solid var(--ink-line); border-radius: 3px; overflow: hidden; }
@media (min-width: 640px) { .process-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .process-grid { grid-template-columns: repeat(4, 1fr); } }
.process-grid li { background: var(--background); padding: 32px; }
@media (min-width: 768px) { .process-grid li { padding: 40px; } }
.step-roman { font-family: var(--serif); font-size: 56px; font-weight: 300; color: var(--primary); margin: 0; }
.process-grid h3 { font-size: 22px; margin: 24px 0 12px; color: var(--ink); }
.process-grid p { font-size: 14px; line-height: 1.7; color: var(--ink-soft); margin: 0; }

/* Testimonials */
.quotes { display: grid; grid-template-columns: 1fr; gap: 40px; margin-top: 48px; }
@media (min-width: 768px) { .quotes { grid-template-columns: repeat(3, 1fr); gap: 32px; } }
.quotes blockquote { margin: 0; padding-top: 32px; border-top: 1px solid var(--ink-line); display: flex; flex-direction: column; justify-content: space-between; height: 100%; }
.quotes blockquote p { font-size: 22px; line-height: 1.4; color: var(--ink); margin: 0; }
.quotes blockquote footer { margin-top: 32px; font-size: 11px; letter-spacing: .24em; text-transform: uppercase; color: var(--ink-mute); }

/* Contact */
.contact { position: relative; overflow: hidden; }
.contact-title { font-size: clamp(2.5rem, 6vw, 5rem); line-height: .98; letter-spacing: -.03em; margin: 24px 0 0; }
.contact-lede { max-width: 28rem; font-size: 16px; line-height: 1.65; color: rgba(255,255,255,.65); margin: 32px 0 0; }
.contact-meta { margin: 48px 0 0; display: flex; flex-direction: column; gap: 24px; }
.contact-meta dt { font-size: 11px; letter-spacing: .28em; text-transform: uppercase; color: rgba(255,255,255,.5); }
.contact-meta dd { margin: 8px 0 0; font-size: 18px; color: var(--background); }
.form { display: flex; flex-direction: column; gap: 20px; padding: 32px; border: 1px solid rgba(245,239,230,.15); background: rgba(245,239,230,.03); border-radius: 3px; backdrop-filter: blur(8px); }
@media (min-width: 768px) { .form { padding: 40px; } }
.form label { display: block; font-size: 11px; letter-spacing: .24em; text-transform: uppercase; color: rgba(245,239,230,.6); }
.form input, .form textarea { display: block; width: 100%; margin-top: 8px; padding: 8px 0; background: transparent; border: none; border-bottom: 1px solid rgba(245,239,230,.3); color: var(--background); font-family: var(--serif); font-size: 18px; outline: none; transition: border-color .2s; }
.form input:focus, .form textarea:focus { border-color: var(--primary); }
.form input::placeholder { color: rgba(245,239,230,.3); }
.form textarea { resize: vertical; }
.form button { align-self: flex-start; margin-top: 8px; }
.form button:hover { background: var(--background); color: var(--ink); }

/* Footer */
.site-footer { border-top: 1px solid var(--ink-line); background: var(--background); padding: 48px 0; }
.footer-row { display: flex; flex-direction: column; align-items: flex-start; justify-content: space-between; gap: 24px; }
@media (min-width: 768px) { .footer-row { flex-direction: row; align-items: center; } }
.footer-row .brand img { width: 32px; height: 32px; }
.footer-row .display { font-size: 14px; margin: 0; }
.footer-row .caps { color: var(--ink-mute); }

/* Animations */
@keyframes rise { from { opacity: 0; transform: translateY(28px); } to { opacity: 1; transform: translateY(0); } }
.rise { animation: rise 1.1s cubic-bezier(.22,1,.36,1) both; }
@keyframes slow-zoom { from { transform: scale(1.08); } to { transform: scale(1); } }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
