/* Forrest Goodrich — Teal · Black · Crimson palette (2026-05-12 recolor) */
:root{
  /* Names kept stable for backward CSS compat; values now teal/black/crimson. */
  --c-navy:#06090b;--c-navy-2:#0d1518;--c-navy-3:#0a1316;       /* deep black w/ teal undertone */
  --c-red:#c8102e;--c-red-hi:#e21d3c;--c-red-deep:#8a0a20;      /* CRIMSON */
  --c-green:#00838f;--c-green-hi:#16c0cc;                       /* TEAL (was green) */
  --c-cream:#e6f2f3;--c-bone:#ffffff;--c-tan:#a8c4c6;           /* cool light + muted teal */
  --c-text:#dde6e7;--c-dim:#7d8c8e;
  --c-gold:#e21d3c;                                             /* gold→crimson accents */

  /* Semantic aliases — preferred new tokens */
  --c-black:#06090b; --c-black-2:#0d1518; --c-black-3:#0a1316;
  --c-teal:#00838f;  --c-teal-hi:#16c0cc; --c-teal-deep:#005a63;
  --c-crimson:#c8102e; --c-crimson-hi:#e21d3c; --c-crimson-deep:#8a0a20;

  --r-sm:4px;--r-md:6px;--r-lg:10px;--r-pill:999px;
  --trans:.2s ease;
  --font-h:'Anton','Bebas Neue','Impact',sans-serif;
  --font-b:'Inter',-apple-system,sans-serif;
  --font-slab:'Roboto Slab',Georgia,serif;
}
*,*::before,*::after{box-sizing:border-box}
[hidden]{display:none!important}
html{scroll-behavior:smooth;overflow-x:hidden}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;font-family:var(--font-b);color:var(--c-text);background:var(--c-navy);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:var(--c-red-hi);text-decoration:none}a:hover{text-decoration:underline}
img,svg{max-width:100%}
.container{max-width:1180px;margin:0 auto;padding:0 22px}
.skip-link{position:absolute;left:-9999px;top:0;z-index:999;background:var(--c-red);color:var(--c-bone);padding:10px 16px;font-weight:800}.skip-link:focus{left:0}

/* Banner stripe — Americana flag-bunting at top */
.banner-stripe{display:flex;height:8px}
.banner-stripe span{flex:1;display:block}
.banner-stripe span:nth-child(1){background:var(--c-red)}
.banner-stripe span:nth-child(2){background:var(--c-cream)}
.banner-stripe span:nth-child(3){background:var(--c-green)}
.banner-stripe span:nth-child(4){background:var(--c-cream)}
.banner-stripe span:nth-child(5){background:var(--c-red)}

/* Header */
.site-header{background:var(--c-navy-2);border-bottom:3px solid var(--c-red);padding:14px 0;position:sticky;top:0;z-index:40}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:inline-flex;align-items:center;gap:14px;text-decoration:none}
.brand-monogram{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--c-red);color:var(--c-cream);font-family:var(--font-slab);font-weight:900;font-size:1.4rem;border:3px solid var(--c-cream);box-shadow:0 0 0 3px var(--c-red);letter-spacing:.04em}
.brand-text strong{display:block;font-family:var(--font-h);font-size:1.4rem;color:var(--c-cream);letter-spacing:.04em;line-height:1}
.brand-text small{display:block;font-family:var(--font-b);font-size:.7rem;color:var(--c-tan);text-transform:uppercase;letter-spacing:.18em;margin-top:4px}
.nav{display:flex;gap:24px}
.nav a{color:var(--c-cream);font-family:var(--font-h);font-size:1rem;letter-spacing:.08em;text-transform:uppercase;padding:6px 0;border-bottom:2px solid transparent;transition:border-color var(--trans)}
.nav a:hover{border-bottom-color:var(--c-red);text-decoration:none}
@media(max-width:780px){.nav{display:none}}

/* Buttons — flat blocks, no rounded pills */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border-radius:0;font-family:var(--font-h);font-weight:400;font-size:1rem;border:3px solid transparent;cursor:pointer;transition:all var(--trans);text-decoration:none!important;text-transform:uppercase;letter-spacing:.1em;line-height:1}
.btn-primary{background:var(--c-red);color:var(--c-cream);border-color:var(--c-cream);box-shadow:4px 4px 0 var(--c-navy-3)}
.btn-primary:hover{background:var(--c-red-hi);transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--c-navy-3)}
.btn-outline{background:transparent;color:var(--c-cream);border-color:var(--c-cream)}
.btn-outline:hover{background:var(--c-cream);color:var(--c-navy)}
.btn-sm{padding:10px 18px;font-size:.85rem}
.btn-lg{padding:16px 32px;font-size:1.05rem}
.btn-xl{padding:22px 40px;font-size:1.2rem}
.btn-block{display:flex;width:100%}

/* Hero — banner-style, centered */
.hero{padding:80px 0 100px;background:
  linear-gradient(180deg,var(--c-navy-2),var(--c-navy)),
  repeating-linear-gradient(45deg,transparent,transparent 22px,rgba(244,234,216,.02) 22px,rgba(244,234,216,.02) 23px);
  text-align:center;border-bottom:6px double var(--c-red)}
.hero-inner{max-width:920px}
.eyebrow{display:inline-block;font-family:var(--font-slab);font-size:.78rem;font-weight:700;color:var(--c-gold);letter-spacing:.2em;text-transform:uppercase;margin-bottom:18px;padding:6px 18px;border:2px solid var(--c-gold);background:var(--c-navy-3)}
.hero-name{font-family:var(--font-h);font-size:clamp(3.4rem,9vw,6.8rem);line-height:.9;color:var(--c-cream);margin:0 0 12px;letter-spacing:.02em}
.hero-name-accent{color:var(--c-red);text-shadow:3px 3px 0 var(--c-cream),6px 6px 0 var(--c-navy-3)}
.hero-tag{font-family:var(--font-slab);font-size:1.2rem;font-weight:600;color:var(--c-tan);max-width:680px;margin:14px auto 28px;line-height:1.5}
.hero-tag strong{color:var(--c-cream);font-weight:700}
.hero-trust{display:flex;flex-wrap:wrap;gap:16px 32px;justify-content:center;margin:0 0 32px;padding:0;list-style:none}
.hero-trust li{font-family:var(--font-h);color:var(--c-gold);font-size:1rem;letter-spacing:.08em;text-transform:uppercase}
.hero-ctas{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}

/* Headings */
h1,h2,h3,h4{font-family:var(--font-h);font-weight:400;color:var(--c-cream);line-height:1.05;margin:0 0 .4em;letter-spacing:.02em}
h2{font-size:clamp(2.2rem,4.5vw,3.4rem);text-transform:uppercase}
h3{font-size:1.4rem;text-transform:uppercase;letter-spacing:.04em}
h4{font-size:.86rem;letter-spacing:.18em;text-transform:uppercase;color:var(--c-tan)}

/* Sections */
.section{padding:90px 0}
.section-alt{background:var(--c-navy-2)}
.section-head{text-align:center;margin-bottom:52px}
.section-head .eyebrow{margin-bottom:20px}
.section-head h2{margin-bottom:14px}
.section-head p{font-family:var(--font-slab);font-size:1.15rem;color:var(--c-tan);max-width:620px;margin:0 auto}
.eyebrow ▲,.eyebrow{}

/* About / two-col */
.two-col{display:grid;grid-template-columns:1.6fr 1fr;gap:48px;align-items:start}
@media(max-width:880px){.two-col{grid-template-columns:1fr;gap:32px}}
p{margin:0 0 1em;color:var(--c-text)}
p strong{color:var(--c-cream)}

/* Tag list — bordered chips */
.tag-list{display:flex;flex-wrap:wrap;gap:8px;list-style:none;padding:0;margin:18px 0 0}
.tag{display:inline-block;padding:7px 14px;font-family:var(--font-h);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--c-cream);background:var(--c-navy-3);border:2px solid var(--c-red)}

/* Quick facts — flag-bunting card */
.quick-facts{background:var(--c-navy-3);border:3px solid var(--c-cream);padding:30px;position:relative}
.quick-facts::before{content:"";position:absolute;top:-3px;left:-3px;right:-3px;height:6px;background:var(--c-red)}
.quick-facts dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:12px 18px}
.quick-facts dt{font-family:var(--font-h);font-size:.78rem;color:var(--c-gold);letter-spacing:.16em;text-transform:uppercase;align-self:center}
.quick-facts dd{margin:0;color:var(--c-cream);font-size:.95rem;align-self:center}
.quick-facts dd a{color:var(--c-cream);border-bottom:2px solid var(--c-red)}

/* Style cards — flash sheet panels */
.styles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:26px}
.style-card{padding:32px 26px;border:3px solid var(--c-cream);box-shadow:6px 6px 0 var(--c-red);transition:all var(--trans)}
.style-card:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--c-red)}
.style-card h3{margin-bottom:12px;color:var(--c-cream)}
.style-card p{color:rgba(244,234,216,.92);font-size:.96rem;margin:0}
.style-card-red{background:var(--c-red);color:var(--c-cream)}
.style-card-red p{color:var(--c-cream)}
.style-card-cream{background:var(--c-cream);color:var(--c-navy);box-shadow:6px 6px 0 var(--c-green)}
.style-card-cream h3{color:var(--c-navy)}.style-card-cream p{color:var(--c-navy)}
.style-card-green{background:var(--c-green);color:var(--c-cream);box-shadow:6px 6px 0 var(--c-cream)}
.style-card-green p{color:var(--c-cream)}
.style-card-navy{background:var(--c-navy-2);color:var(--c-cream);box-shadow:6px 6px 0 var(--c-gold)}

/* FAQ */
.faq-grid{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.faq-grid details{background:var(--c-navy-3);border:2px solid var(--c-cream);overflow:hidden}
.faq-grid details[open]{border-color:var(--c-red)}
.faq-grid summary{cursor:pointer;padding:18px 22px;font-family:var(--font-h);font-size:1.05rem;color:var(--c-cream);letter-spacing:.06em;text-transform:uppercase;list-style:none;position:relative;padding-right:50px}
.faq-grid summary::-webkit-details-marker{display:none}
.faq-grid summary::after{content:"+";position:absolute;right:22px;top:50%;transform:translateY(-50%);color:var(--c-red);font-size:1.5rem;font-weight:900}
.faq-grid details[open] summary::after{content:"−"}
.faq-grid details p{padding:0 22px 22px;color:var(--c-tan);margin:0;font-size:.96rem}

/* Section CTA wrapper */
.section-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}

/* CTA section */
.cta-section{padding:96px 0;text-align:center;background:var(--c-red);color:var(--c-cream);border-top:6px double var(--c-cream);border-bottom:6px double var(--c-cream)}
.cta-section h2{color:var(--c-cream);font-size:clamp(2.4rem,5vw,3.8rem);margin-bottom:18px}
.cta-section p{color:var(--c-cream);font-family:var(--font-slab);font-size:1.2rem;max-width:580px;margin:0 auto 32px}
.cta-section .btn-primary{background:var(--c-cream);color:var(--c-red);border-color:var(--c-navy)}
.cta-section .btn-outline{color:var(--c-cream);border-color:var(--c-cream)}
.cta-section .btn-outline:hover{background:var(--c-cream);color:var(--c-red)}

/* Footer */
.site-footer{background:var(--c-navy-3);border-top:6px solid var(--c-red);padding:64px 0 26px;color:var(--c-tan)}
.footer-grid{display:grid;grid-template-columns:1.3fr 2fr;gap:52px;margin-bottom:36px}
.footer-brand{display:flex;align-items:center;gap:16px}
.brand-monogram-lg{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--c-red);color:var(--c-cream);font-family:var(--font-slab);font-weight:900;font-size:1.6rem;border:3px solid var(--c-cream)}
.footer-brand strong{display:block;font-family:var(--font-h);color:var(--c-cream);font-size:1.3rem;letter-spacing:.04em}
.footer-brand small{display:block;font-family:var(--font-b);color:var(--c-tan);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;margin-top:4px}
.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.footer-links h4{font-family:var(--font-h);color:var(--c-gold);margin:0 0 14px}
.footer-links ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.footer-links a,.footer-links li{color:var(--c-tan);font-size:.92rem}
.footer-links a:hover{color:var(--c-cream)}
.footer-bottom{border-top:2px solid var(--c-navy);padding-top:22px;font-size:.78rem;color:var(--c-dim);text-align:center;font-family:var(--font-slab)}
@media(max-width:780px){.footer-grid{grid-template-columns:1fr}.footer-links{grid-template-columns:1fr 1fr}}

/* Sticky CTA */
.sticky-cta{position:fixed;right:18px;bottom:18px;z-index:50;background:var(--c-red);color:var(--c-cream);padding:14px 22px;font-family:var(--font-h);font-size:.9rem;letter-spacing:.08em;text-transform:uppercase;text-decoration:none!important;border:3px solid var(--c-cream);box-shadow:4px 4px 0 var(--c-navy-3);transition:all var(--trans)}
.sticky-cta:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--c-navy-3)}

/* Booking widget */
.booking-widget{position:fixed;left:18px;bottom:18px;z-index:50}
.booking-bubble{background:var(--c-red);color:var(--c-cream);width:56px;height:56px;border:3px solid var(--c-cream);box-shadow:4px 4px 0 var(--c-navy-3);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:0}
.booking-widget.is-open .booking-bubble .bk-open{display:none}
.booking-bubble .bk-close{display:none}
.booking-widget.is-open .booking-bubble .bk-close{display:block}
.booking-panel{position:absolute;left:0;bottom:72px;width:340px;max-width:calc(100vw - 36px);max-height:78vh;overflow-y:auto;background:var(--c-navy-3);border:3px solid var(--c-cream);padding:22px;box-shadow:6px 6px 0 var(--c-red)}
.booking-head{margin-bottom:14px;padding-bottom:14px;border-bottom:2px solid var(--c-red)}
.booking-head strong{display:block;font-family:var(--font-h);font-size:1.2rem;color:var(--c-cream);letter-spacing:.04em}
.booking-head small{display:block;color:var(--c-gold);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;margin-top:4px}
.booking-form label{display:block;margin-bottom:10px}
.booking-form span{display:block;font-family:var(--font-h);font-size:.78rem;color:var(--c-gold);text-transform:uppercase;letter-spacing:.14em;margin-bottom:5px}
.booking-form input,.booking-form select{width:100%;padding:10px 12px;background:var(--c-navy);border:2px solid var(--c-cream);color:var(--c-cream);font-family:var(--font-b);font-size:.92rem}
.booking-form input:focus,.booking-form select:focus{outline:none;border-color:var(--c-red)}
.booking-note{font-family:var(--font-slab);color:var(--c-dim);font-size:.82rem;margin-top:10px;text-align:center}

/* Gallery placeholder */
.gallery-empty{text-align:center;padding:60px 20px;color:var(--c-dim);font-family:var(--font-slab);font-style:italic}
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}

/* === Affiliated Artists (v2) === */
.affiliated-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 16px; margin-top: 28px; max-width: 1100px; margin-left: auto; margin-right: auto; }
.affiliated-card { display: flex; flex-direction: column; text-decoration: none; color: inherit; background: rgba(0,0,0,0.18); border: 1px solid rgba(255,255,255,0.08); border-radius: 12px; overflow: hidden; transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease; position: relative; }
.affiliated-card:hover { transform: translateY(-4px); border-color: rgba(255,255,255,0.25); box-shadow: 0 8px 24px rgba(0,0,0,0.25); }
.affiliated-card.featured::before { content: "Featured"; position: absolute; top: 8px; right: 8px; background: rgba(255,255,255,0.95); color: #050e1a; padding: 3px 8px; border-radius: 4px; font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.5px; z-index: 1; }
.affiliated-card picture { display: block; aspect-ratio: 1/1; overflow: hidden; background: rgba(255,255,255,0.04); }
.affiliated-card img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.4s ease; }
.affiliated-card:hover img { transform: scale(1.04); }
.affiliated-body { padding: 12px 14px 14px; display: flex; flex-direction: column; gap: 2px; flex: 1; }
.affiliated-body h3 { margin: 0; font-size: 14px; font-weight: 700; line-height: 1.25; }
.aff-specialty { margin: 0; font-size: 11px; opacity: 0.78; line-height: 1.3; }
.aff-shop { margin: 0; font-size: 10px; opacity: 0.55; text-transform: uppercase; letter-spacing: 0.5px; margin-top: 2px; }
@media (max-width: 600px) { .affiliated-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; } .affiliated-body { padding: 10px 12px 12px; } }

/* MARKER:IMG-SIZE-FIX */
/* === Image sizing — preserve natural aspect ratio, never stretch === */
.gallery-item img, .gallery-item picture { display: block; width: 100%; height: auto; aspect-ratio: auto; object-fit: contain; }
figure.gallery-item picture { line-height: 0; }

/* === MARKER:IMG-INFO === Tim-pattern visible captions + style pills === */
.gallery-item { position: relative; background: var(--c-card, rgba(0,0,0,.3)); border: 1px solid var(--c-border, rgba(255,255,255,.08)); border-radius: 10px; overflow: hidden; transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease; }
.gallery-item:hover { transform: translateY(-3px); border-color: rgba(255,255,255,.25); box-shadow: 0 12px 32px rgba(0,0,0,.45); }
.gallery-item .img-caption { padding: 10px 14px; color: rgba(255,255,255,.78); font-size: .8rem; line-height: 1.45; border-top: 1px solid rgba(255,255,255,.08); font-weight: 500; }
.gallery-item .img-keywords { padding: 4px 12px 10px; display: flex; flex-wrap: wrap; gap: 4px; }
.gallery-item .img-keyword { display: inline-block; padding: 2px 8px; background: rgba(255,255,255,.06); border-radius: 999px; font-size: .68rem; color: rgba(255,255,255,.7); font-weight: 600; letter-spacing: .02em; }

/* ═══════════════════════════════════════════════════════════════════
   MARKER:BOLDER — 2026-05-12 Forrest recolor pass
   Teal / Black / Crimson + heavier weights throughout.
   ═══════════════════════════════════════════════════════════════════ */

/* Banner stripe — crimson / teal / black / teal / crimson */
.banner-stripe span:nth-child(1) { background: var(--c-crimson); }
.banner-stripe span:nth-child(2) { background: var(--c-teal); }
.banner-stripe span:nth-child(3) { background: var(--c-black-3); }
.banner-stripe span:nth-child(4) { background: var(--c-teal); }
.banner-stripe span:nth-child(5) { background: var(--c-crimson); }
.banner-stripe { height: 10px; }

/* Bolder body + nav */
body { font-weight: 500; letter-spacing: .005em; }
.nav a { font-weight: 700; }
.nav a:hover { border-bottom-color: var(--c-teal-hi); }

/* Bolder buttons + heavier borders */
.btn { font-weight: 800; border-width: 4px; letter-spacing: .12em; }
.btn-primary { background: var(--c-crimson); border-color: var(--c-bone); color: var(--c-bone); }
.btn-primary:hover { background: var(--c-crimson-hi); }
.btn-outline { color: var(--c-bone); border-color: var(--c-teal-hi); }
.btn-outline:hover { background: var(--c-teal); color: var(--c-bone); }

/* Headlines crank to max display-weight feel */
h1, h2, h3, h4 {
  font-weight: 900;
  letter-spacing: .025em;
  text-shadow: 0 2px 0 rgba(0,0,0,.35);
}
.hero-name { letter-spacing: .03em; text-shadow: 0 4px 0 var(--c-crimson-deep), 0 6px 18px rgba(0,0,0,.45); }
.hero-tag { font-weight: 700; color: var(--c-teal-hi); }
.hero-tag strong { color: var(--c-bone); font-weight: 900; }
.hero-trust li { color: var(--c-crimson-hi); font-weight: 800; }

/* Eyebrows + tags + monograms */
.eyebrow { color: var(--c-teal-hi); border-color: var(--c-teal-hi); font-weight: 900; background: rgba(0,131,143,0.10); }
.tag { background: rgba(200,16,46,0.10); border-color: var(--c-crimson); color: var(--c-bone); font-weight: 800; }
.brand-monogram, .brand-monogram-lg {
  background: var(--c-crimson);
  border-color: var(--c-bone);
  box-shadow: 0 0 0 3px var(--c-crimson), 0 0 0 6px var(--c-teal);
  font-weight: 900;
}

/* Header accent line — switch to teal */
.site-header { border-bottom-color: var(--c-teal); border-bottom-width: 4px; }

/* FAQ + style cards keep contrast */
.faq-grid summary::after { color: var(--c-teal-hi); font-weight: 900; }
.style-card h3 { color: var(--c-bone); font-weight: 900; }
.style-card-cream { background: var(--c-bone); }
.style-card-cream h3, .style-card-cream p { color: var(--c-black); }
.style-card-cream h3 { font-weight: 900; }

/* Footer brand + dim tones */
.footer-brand strong { font-weight: 900; }

/* Link color (was crimson) — keep crimson on dark, but underline thicker on hover */
a { font-weight: 600; }
a:hover { text-decoration-thickness: 2px; }

/* Forms — bolder labels and stronger borders */
label, .form-label { font-weight: 700; letter-spacing: .03em; }
input, textarea, select { border-width: 2px; font-weight: 500; }
input:focus, textarea:focus, select:focus { border-color: var(--c-teal-hi); outline: 2px solid var(--c-teal); outline-offset: 1px; }

/* Section dividers more pronounced */
section { border-top: 1px solid rgba(255,255,255,.05); }

/* Gallery-item caption styled to match new palette */
.gallery-item { border-color: rgba(22, 192, 204, 0.18); }
.gallery-item:hover { border-color: var(--c-teal-hi); box-shadow: 0 12px 32px rgba(200,16,46,.20); }
.gallery-item .img-caption { color: var(--c-bone); font-weight: 600; border-top-color: rgba(22,192,204,.20); background: linear-gradient(180deg, transparent, rgba(200,16,46,.08)); }
.gallery-item .img-keyword { background: rgba(22,192,204,.12); color: var(--c-teal-hi); font-weight: 800; border: 1px solid rgba(22,192,204,.25); }
/* ═══════════════════════════════════════════════════════════════════ */
