/* Christian (Tiki in Waikiki) — Blackwork tribal palette */
:root{
  --c-black:#000;--c-bg-2:#0a0a0a;--c-card:#0f0d0a;--c-border:#1f1a14;
  --c-tapa:#5e3a1d;--c-tapa-hi:#7a4d28;--c-tapa-deep:#3a2410;
  --c-coconut:#f0e8d4;--c-coconut-soft:#d4cab2;
  --c-green:#4a7c3f;--c-green-hi:#6ba858;
  --c-text:#bfb8a4;--c-dim:#7d7666;
  --r-sm:0;--r-md:0;--r-lg:0;--r-pill:0;
  --trans:.2s ease;
  --font-h:'Bebas Neue','Impact',sans-serif;
  --font-b:'Inter',-apple-system,sans-serif;
  --font-acc:'Cormorant Garamond',Georgia,serif;
}
*,*::before,*::after{box-sizing:border-box}
[hidden]{display:none!important}
html{scroll-behavior:smooth;overflow-x:hidden}
body{margin:0;font-family:var(--font-b);color:var(--c-text);background:var(--c-black);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:var(--c-green-hi);text-decoration:none}a:hover{color:var(--c-coconut)}
img,svg{max-width:100%}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
.skip-link{position:absolute;left:-9999px;background:var(--c-coconut);color:var(--c-black);padding:10px 16px;font-weight:800}.skip-link:focus{left:0;top:0;z-index:999}

/* Tapa-cloth pattern background — angular geometric */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.04;
  background-image:
    repeating-linear-gradient(45deg,var(--c-tapa) 0,var(--c-tapa) 1px,transparent 1px,transparent 14px),
    repeating-linear-gradient(-45deg,var(--c-tapa) 0,var(--c-tapa) 1px,transparent 1px,transparent 14px);
}
.site-header,main,.site-footer{position:relative;z-index:1}

/* Header — minimal monolithic */
.site-header{background:var(--c-black);border-bottom:1px solid var(--c-border);padding:16px 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-mark{font-size:1.6rem;color:var(--c-tapa-hi);line-height:1}
.brand-mark-lg{font-size:2.4rem}
.brand-text strong{display:block;font-family:var(--font-h);font-size:1.3rem;color:var(--c-coconut);letter-spacing:.16em;line-height:1}
.brand-text small{display:block;font-family:var(--font-b);font-size:.7rem;color:var(--c-dim);letter-spacing:.18em;text-transform:uppercase;margin-top:4px}
.nav{display:flex;gap:28px}
.nav a{color:var(--c-coconut-soft);font-family:var(--font-h);font-size:1rem;letter-spacing:.14em;text-transform:uppercase;padding:6px 0;border-bottom:1px solid transparent;transition:border-color var(--trans)}
.nav a:hover{border-bottom-color:var(--c-tapa-hi);color:var(--c-coconut)}
@media(max-width:780px){.nav{display:none}}

/* Buttons — rectangular, monolithic */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border-radius:0;font-family:var(--font-h);font-size:1rem;border:1px solid transparent;cursor:pointer;transition:all var(--trans);text-decoration:none!important;letter-spacing:.14em;text-transform:uppercase;line-height:1}
.btn-primary{background:var(--c-coconut);color:var(--c-black);border-color:var(--c-coconut)}
.btn-primary:hover{background:var(--c-tapa);color:var(--c-coconut);border-color:var(--c-tapa)}
.btn-outline{background:transparent;color:var(--c-coconut);border-color:var(--c-coconut-soft)}
.btn-outline:hover{background:var(--c-coconut);color:var(--c-black)}
.btn-sm{padding:10px 18px;font-size:.85rem}
.btn-lg{padding:18px 32px;font-size:1.1rem}
.btn-xl{padding:22px 40px;font-size:1.25rem}
.btn-block{display:flex;width:100%}

/* Hero — Heather/Benson pattern: real <img>, never cropped, fully visible */
.hero{position:relative;padding:0 0 56px;text-align:center;border-bottom:1px solid var(--c-border);background:#0a0608;overflow:hidden}
.hero-tiki .hero-art-wrap{display:block;width:100%;margin:0;padding:24px 16px 0;background:transparent;text-align:center}
.hero-tiki .hero-art-img{display:block;margin:0 auto;width:auto;max-width:min(100%,1400px);max-height:70vh;height:auto;object-fit:contain;border-radius:10px;box-shadow:0 28px 70px -28px rgba(0,0,0,.85),0 0 0 1px rgba(212,160,44,.08)}
.hero-tiki::after{content:'';position:absolute;left:0;right:0;top:calc(min(70vh,66.66vw) - 60px);height:140px;background:linear-gradient(180deg,rgba(212,160,44,.10),transparent 80%);pointer-events:none}
.hero-tiki > .hero-inner{position:relative;text-align:center;padding-top:32px;max-width:760px;margin:0 auto}
.hero-tapa{display:none}
/* sr-only utility for visually-hidden brand H1 (since brand is in image) */
.visually-hidden{position:absolute !important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media (max-width:720px){
  .hero-tiki .hero-art-wrap{padding:16px 10px 0}
  .hero-tiki .hero-art-img{max-height:50vh;border-radius:8px}
  .hero-tiki::after{top:calc(min(50vh,66vw) - 50px);height:100px}
}
.hero-inner{position:relative;z-index:2;max-width:920px}
.eyebrow{display:inline-block;font-family:var(--font-h);font-size:.78rem;color:var(--c-tapa-hi);letter-spacing:.32em;text-transform:uppercase;margin-bottom:24px;padding:8px 18px;border:1px solid var(--c-tapa);background:var(--c-tapa-deep)}
.hero-name{font-family:var(--font-h);font-size:clamp(4rem,12vw,9rem);line-height:.85;color:var(--c-coconut);margin:0;letter-spacing:.04em;text-shadow:none}
.hero-name-sub{display:block;color:var(--c-tapa-hi);font-size:.6em;margin-top:8px;letter-spacing:.12em}
.hero-divider{margin:24px 0;color:var(--c-tapa-hi);letter-spacing:1.2em;font-size:.9rem}
.hero-tag{font-family:var(--font-acc);font-style:italic;font-size:1.3rem;color:var(--c-coconut-soft);max-width:660px;margin:0 auto 28px;line-height:1.5}
.hero-tag strong{font-style:normal;font-family:var(--font-h);color:var(--c-coconut);letter-spacing:.06em}
.hero-trust{display:flex;flex-wrap:wrap;gap:14px 28px;justify-content:center;margin:0 0 36px;padding:0;list-style:none}
.hero-trust li{font-family:var(--font-h);color:var(--c-coconut);font-size:.92rem;letter-spacing:.18em}
.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-coconut);line-height:1.05;margin:0 0 .4em;letter-spacing:.06em}
h2{font-size:clamp(2.4rem,5vw,4rem);text-transform:uppercase}
h3{font-size:1.4rem;text-transform:uppercase;letter-spacing:.1em}
h4{font-size:.84rem;letter-spacing:.22em;text-transform:uppercase;color:var(--c-tapa-hi);font-weight:400}

/* Sections */
.section{padding:96px 0;border-top:1px solid var(--c-border)}
.section-alt{background:var(--c-bg-2)}
.section-head{text-align:center;margin-bottom:56px}
.section-head .eyebrow{margin-bottom:18px}
.section-head h2{margin-bottom:14px}
.section-head p{font-family:var(--font-acc);font-style:italic;font-size:1.2rem;color:var(--c-coconut-soft);max-width:620px;margin:0 auto;line-height:1.5}

/* 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-coconut)}

/* Tag list */
.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:.16em;color:var(--c-coconut);background:var(--c-tapa-deep);border:1px solid var(--c-tapa)}

/* Quick facts */
.quick-facts{background:var(--c-bg-2);border:1px solid var(--c-tapa);padding:30px;position:relative}
.quick-facts::before,.quick-facts::after{content:"";position:absolute;width:18px;height:18px;border:2px solid var(--c-tapa-hi)}
.quick-facts::before{top:-2px;left:-2px;border-right:none;border-bottom:none}
.quick-facts::after{bottom:-2px;right:-2px;border-left:none;border-top:none}
.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-tapa-hi);letter-spacing:.18em;align-self:center}
.quick-facts dd{margin:0;color:var(--c-coconut);font-size:.95rem;align-self:center}
.quick-facts dd a{color:var(--c-coconut);border-bottom:1px solid var(--c-tapa-hi)}

/* Style cards — heavy black blocks */
.styles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:0}
.style-card{padding:40px 28px;border:1px solid var(--c-border);border-right:none;background:var(--c-black);transition:all var(--trans);position:relative;min-height:240px;display:flex;flex-direction:column}
.style-card:last-child{border-right:1px solid var(--c-border)}
.style-card:hover{background:var(--c-tapa-deep);border-color:var(--c-tapa-hi)}
.style-card .style-mark{font-size:2rem;color:var(--c-tapa-hi);margin-bottom:18px;line-height:1}
.style-card h3{margin-bottom:12px;color:var(--c-coconut)}
.style-card p{color:var(--c-coconut-soft);font-size:.96rem;margin:0;flex:1}
@media(max-width:780px){.style-card{border-right:1px solid var(--c-border);border-bottom:none}.style-card:last-child{border-bottom:1px solid var(--c-border)}}

/* FAQ */
.faq-grid{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:0}
.faq-grid details{background:var(--c-bg-2);border-bottom:1px solid var(--c-border);overflow:hidden}
.faq-grid details:first-child{border-top:1px solid var(--c-border)}
.faq-grid summary{cursor:pointer;padding:22px 22px;font-family:var(--font-h);font-size:1.08rem;color:var(--c-coconut);letter-spacing:.08em;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-tapa-hi);font-size:.85rem;transition:transform var(--trans)}
.faq-grid details[open] summary::after{transform:translateY(-50%) rotate(180deg)}
.faq-grid details p{padding:0 22px 22px;color:var(--c-coconut-soft);margin:0;font-size:.96rem;line-height:1.7;font-family:var(--font-acc);font-style:italic}

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

/* CTA section */
.cta-section{padding:100px 0;text-align:center;background:linear-gradient(180deg,var(--c-tapa-deep),var(--c-black));border-top:1px solid var(--c-tapa);border-bottom:1px solid var(--c-tapa)}
.cta-section h2{font-size:clamp(2.4rem,5vw,4rem);margin-bottom:18px;color:var(--c-coconut)}
.cta-section p{font-family:var(--font-acc);font-style:italic;font-size:1.2rem;color:var(--c-coconut-soft);max-width:580px;margin:0 auto 32px}

/* Footer */
.site-footer{background:var(--c-black);border-top:1px solid var(--c-tapa);padding:64px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.3fr 2fr;gap:52px;margin-bottom:36px}
.footer-brand{display:flex;align-items:center;gap:18px}
.footer-brand strong{display:block;font-family:var(--font-h);color:var(--c-coconut);font-size:1.3rem;letter-spacing:.14em}
.footer-brand small{display:block;color:var(--c-dim);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;margin-top:6px}
.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.footer-links h4{font-family:var(--font-h);color:var(--c-tapa-hi);margin:0 0 16px}
.footer-links ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.footer-links a,.footer-links li{color:var(--c-coconut-soft);font-size:.92rem;font-family:var(--font-b)}
.footer-links a:hover{color:var(--c-coconut)}
.footer-bottom{border-top:1px solid var(--c-border);padding-top:22px;font-size:.78rem;color:var(--c-dim);text-align:center;font-family:var(--font-acc);font-style:italic}
@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-coconut);color:var(--c-black);padding:14px 22px;font-family:var(--font-h);font-size:.9rem;letter-spacing:.14em;text-decoration:none!important;border:1px solid var(--c-tapa);transition:all var(--trans)}
.sticky-cta:hover{background:var(--c-tapa);color:var(--c-coconut)}

/* Booking widget */
.booking-widget{position:fixed;left:18px;bottom:18px;z-index:50}
.booking-bubble{background:var(--c-coconut);color:var(--c-black);width:56px;height:56px;border:1px solid var(--c-tapa);cursor:pointer;display:flex;align-items:center;justify-content:center}
.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-bg-2);border:1px solid var(--c-tapa);padding:22px}
.booking-head{margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--c-tapa)}
.booking-head strong{display:block;font-family:var(--font-h);font-size:1.1rem;color:var(--c-coconut);letter-spacing:.16em}
.booking-head small{display:block;color:var(--c-tapa-hi);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-tapa-hi);letter-spacing:.18em;margin-bottom:5px}
.booking-form input,.booking-form select{width:100%;padding:10px 12px;background:var(--c-black);border:1px solid var(--c-border);color:var(--c-coconut);font-family:var(--font-b);font-size:.92rem;border-radius:0}
.booking-form input:focus,.booking-form select:focus{outline:none;border-color:var(--c-tapa-hi)}
.booking-form input[type="submit"]{background:var(--c-coconut);color:var(--c-black);border:1px solid var(--c-coconut);font-weight:700;cursor:pointer;padding:14px;font-family:var(--font-h);letter-spacing:.14em}
.booking-note{font-family:var(--font-acc);font-style:italic;color:var(--c-dim);font-size:.82rem;margin-top:10px;text-align:center}

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

/* === 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:UNIVERSAL-MOBILE-FIX — 2026-05-13
   Network-wide mobile safety. Stops header-CTA overflow, makes hero
   text wrap, stacks CTA pairs on narrow viewports.
   ═══════════════════════════════════════════════════════════════════ */

/* Global overflow safety */
html, body { overflow-x: hidden !important; max-width: 100vw; }
img, picture, video, svg, iframe { max-width: 100%; }

@media (max-width: 720px) {
  /* Header CTA hides on phones — sticky bottom bar / hamburger handles bookings */
  .header-cta, .header-actions .btn, .header-cta-wrap, .header-actions .header-cta,
  .site-header .btn, .site-header a.btn,
  a.btn.header-cta, a.btn-gold.btn-sm.header-cta { display: none !important; }

  /* Ensure brand text in header doesn't get pushed off */
  .site-header .container, .header-row, .header-inner { flex-wrap: wrap; gap: 8px; }
  .brand, .brand-text { min-width: 0; }
  .brand-text strong, .brand-text small { overflow: hidden; text-overflow: ellipsis; }

  /* Eyebrow + headlines wrap properly */
  .eyebrow { white-space: normal !important; word-wrap: break-word; overflow-wrap: anywhere; }
  h1, h2, h3, .hero-name, .hero-wordmark, .hero-title, .hero-tag {
    overflow-wrap: anywhere; word-break: normal; max-width: 100%;
  }
  .hero, .hero-inner, .hero-content, .hero-bg, .article-hero,
  .container, .container-narrow { max-width: 100% !important; box-sizing: border-box; }
  .container, .container-narrow { padding-left: 16px; padding-right: 16px; }

  /* Hero CTA pair stacks vertically on narrow viewports */
  .hero-ctas, .hero-meta, .hero-cta { flex-direction: column !important; align-items: stretch !important; }
  .hero-ctas .btn, .hero-meta .btn, .hero-cta .btn { width: 100% !important; min-width: 0 !important; }

  /* Trust pills wrap nicely */
  .hero-trust { flex-wrap: wrap !important; justify-content: center !important; gap: 8px 12px !important; }
  .hero-trust li { white-space: nowrap; }

  /* Card grids never wider than viewport */
  .cards-grid, .grid, .styles-grid, .gallery, .network-grid, .scout-grid {
    max-width: 100% !important; box-sizing: border-box;
  }

  /* Intake form fits */
  .intake-form { width: 100% !important; max-width: 100% !important; box-sizing: border-box; }
  .intake-form select, .intake-form input, .intake-form button { min-width: 0; max-width: 100%; box-sizing: border-box; }

  /* WORD-BREAK-PASS-2 */
  /* Tighter word-break for unbreakable strings (URLs, "Photoreal", etc.) */
  .hero-tag, .hero-name, .hero-name-accent, .hero-wordmark,
  .article-hero h1, .feature h1, h1, h2, p {
    hyphens: auto;
    -webkit-hyphens: auto;
    overflow-wrap: anywhere !important;
  }
  /* Last-resort safety: prevent any element from forcing horizontal scroll */
  body * { max-width: 100vw; }

}
/* ═══════════════════════════════════════════════════════════════════ */

/* === Scroll logo brand mark — networked (2026-05-20, retro-fit 2026-05-23 for tiki logo) === */
.brand-mark-img {
  width: 56px; height: 56px;
  border-radius: 8px;
  background: transparent;
  padding: 0;
  object-fit: contain;
  box-shadow: 0 2px 14px rgba(0,0,0,0.6);
  flex-shrink: 0;
}
@media (max-width:720px){
  .brand-mark-img { width: 48px; height: 48px; }
}


/* ═══ Tiki brand-text: prevent header byline from orphaning the Ohana link ═══ */
.brand-text small { max-width: 22ch; white-space: normal; }
.brand-text small a { color: var(--c-dim); border-bottom: none; text-decoration: none; pointer-events: auto; }
.brand-text small a:hover { color: var(--c-tapa-hi); }

/* ═══ Tiki brand: force entire small phrase to wrap cleanly under TIKI logo ═══ */
.brand-text { max-width: 280px; display: block; }
.brand-text small { display: block !important; max-width: 100%; white-space: normal !important; line-height: 1.2; }
.brand-text small a { display: inline; color: var(--c-dim) !important; }


/* === Mobile booking widget fix (network-wide 2026-05-23) === */
@media (max-width: 720px) {
  #book { padding-bottom: 120px !important; }
  body { padding-bottom: 80px; }
}
.intake-form input,
.intake-form select { box-sizing: border-box !important; width: 100% !important; }
.intake-form input[type="checkbox"] { width: auto !important; }
.intake-form select,
.intake-form input { font-size: 14px; }


/* === Affiliated-card hero variant (network-wide 2026-05-23) === */
.affiliated-card-hero {
  display: flex !important;
  flex-direction: column !important;
  background: rgba(0,0,0,0.35) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  text-decoration: none !important;
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
  box-shadow: 0 6px 18px rgba(0,0,0,0.4);
}
.affiliated-card-hero:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 32px rgba(0,0,0,0.55);
  border-color: rgba(249,115,22,0.45) !important;
}
.affiliated-card-hero picture {
  display: block !important;
  width: 100% !important;
  aspect-ratio: 1200 / 630 !important;
  overflow: hidden;
  background: rgba(0,0,0,0.5);
}
.affiliated-card-hero picture img,
.affiliated-card-hero img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  aspect-ratio: 1200 / 630 !important;
  object-fit: cover !important;
  object-position: center !important;
  border-radius: 0 !important;
  transition: transform 0.4s ease;
}
.affiliated-card-hero:hover img { transform: scale(1.03); }
.affiliated-card-hero .affiliated-body {
  padding: 14px 16px 16px !important;
  text-align: left !important;
  background: transparent !important;
  border-top: 1px solid rgba(255,255,255,0.07) !important;
}
.affiliated-card-hero .affiliated-body h3 {
  margin: 0 0 4px !important;
  font-size: 1.05rem !important;
  line-height: 1.25 !important;
}
.affiliated-card-hero .aff-specialty {
  margin: 0 0 4px !important;
  font-size: 0.82rem !important;
  opacity: 0.85;
  line-height: 1.4;
}
.affiliated-card-hero .aff-shop {
  margin: 0 !important;
  font-size: 0.74rem !important;
  opacity: 0.6;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
/* Grid: 2 columns desktop, 1 column mobile (hero cards are wider) */
.affiliated-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr)) !important;
  gap: 24px !important;
}
@media (max-width: 720px) {
  .affiliated-grid { grid-template-columns: 1fr !important; gap: 18px !important; }
}
.affiliated-card-hero.featured {
  border-color: rgba(249,115,22,0.45) !important;
  box-shadow: 0 10px 32px rgba(0,0,0,0.55), 0 0 0 1px rgba(249,115,22,0.25);
}
