/* ============================================================
   CLASSIC POKER CHIPS — design system v2 "Pressed & Gilded"
   Espresso noir · deep felt green · aged gold · cream paper
   ============================================================ */
:root{
  --noir:    #16120E;            /* warm espresso near-black */
  --noir-2:  #1E1913;            /* raised dark panel */
  --felt:    #0F3527;            /* deep casino felt green */
  --felt-2:  #0B2A1F;
  --paper:   #F7F2E6;            /* warm cream */
  --cream:   #EFE7D4;            /* deeper cream band */
  --ink:     #221C14;
  --ink-soft: rgba(34,28,20,.66);
  --gold:    #C2A158;            /* aged gold */
  --gold-2:  #DCBE7C;            /* bright champagne */
  --gold-dim: rgba(194,161,88,.38);
  --hair:    rgba(194,161,88,.28);          /* gold hairline on dark */
  --hair-lt: rgba(34,28,20,.16);            /* hairline on light */
  --cream-on-dark: rgba(247,242,230,.82);
  --display: "Fraunces", Georgia, serif;
  --body: "Libre Franklin", "Franklin Gothic Medium", Arial, sans-serif;
  --shadow: 0 18px 50px rgba(22,18,14,.16), 0 2px 8px rgba(22,18,14,.08);
  --shadow-dark: 0 24px 60px rgba(0,0,0,.5);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--paper);line-height:1.7;font-size:16.5px;font-weight:400}
/* handmade grain over everything, very subtle */
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:2000;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E")}
img,svg{display:block;max-width:100%}
img{height:auto}
a{color:inherit}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.wrap-narrow{max-width:880px;margin:0 auto;padding:0 28px}

/* ---------- announcement ---------- */
.announce{background:var(--felt-2);color:rgba(247,242,230,.85);font-size:.82rem;letter-spacing:.02em;text-align:center;padding:11px 18px;border-bottom:1px solid var(--hair)}
.announce strong{color:var(--gold-2);font-weight:600;letter-spacing:.06em;text-transform:uppercase;font-size:.76rem}
.announce a{color:var(--gold-2)}

/* ---------- header ---------- */
header.site{background:linear-gradient(180deg,#1A1510,var(--noir));border-bottom:1px solid var(--hair);position:sticky;top:0;z-index:50}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:16px 0}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none}
.brand-mark{width:46px;height:46px;flex:none;filter:drop-shadow(0 3px 8px rgba(0,0,0,.5))}
.brand-text{line-height:1.18;color:var(--paper)}
.brand-name{font-family:var(--display);font-weight:600;font-size:1.22rem;letter-spacing:.02em}
.brand-est{font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);font-weight:600}
nav.main ul{display:flex;gap:26px;list-style:none;align-items:center}
nav.main a{text-decoration:none;font-size:.76rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-on-dark);padding:8px 0;border-bottom:1px solid transparent;transition:color .2s,border-color .2s;white-space:nowrap}
nav.main a:hover,nav.main a:focus-visible{color:var(--gold-2);border-bottom-color:var(--gold-dim)}
nav.main a[aria-current="page"]{color:var(--gold-2);border-bottom-color:var(--gold)}
.nav-cta{border:1px solid var(--gold);color:var(--gold-2)!important;padding:11px 20px!important;border-bottom:1px solid var(--gold)!important;transition:background .2s,color .2s!important}
.nav-cta:hover{background:var(--gold);color:var(--noir)!important}
.menu-btn{display:none;background:none;border:1px solid var(--hair);border-radius:0;color:var(--gold-2);padding:9px 14px;font:inherit;font-size:.76rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;cursor:pointer}

/* ---------- type & links ---------- */
.eyebrow{font-size:.7rem;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.eyebrow::after{content:"";display:block;width:44px;height:1px;background:var(--gold-dim);margin-top:14px}
.center .eyebrow::after{margin-left:auto;margin-right:auto}
.text-link{font-weight:600;font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;color:var(--ink);border-bottom:1px solid var(--gold);padding-bottom:5px;transition:color .2s,border-color .2s;display:inline-block}
.text-link:hover{color:#8a6e33}
.on-dark .text-link{color:var(--gold-2);border-bottom-color:var(--gold-dim)}
.on-dark .text-link:hover{color:#fff}
.btn{display:inline-block;text-decoration:none;font-weight:600;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;padding:17px 34px;border-radius:0;transition:background .25s,color .25s,border-color .25s,transform .25s;cursor:pointer;border:1px solid transparent;font-family:var(--body)}
.btn-primary{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:var(--noir);border-color:rgba(0,0,0,.15);box-shadow:inset 0 1px 0 rgba(255,255,255,.4),0 10px 26px rgba(22,18,14,.28)}
.btn-primary:hover{background:linear-gradient(180deg,#E7CD92,var(--gold-2));transform:translateY(-1px)}
.btn-quiet{border-color:var(--ink);color:var(--ink);background:transparent}
.btn-quiet:hover{background:var(--ink);color:var(--paper)}
.on-dark .btn-quiet{border-color:var(--gold-dim);color:var(--cream-on-dark)}
.on-dark .btn-quiet:hover{background:transparent;border-color:var(--gold-2);color:var(--gold-2)}
.btn-row{display:flex;gap:16px;flex-wrap:wrap}

/* ---------- cinematic home hero ---------- */
.cinema{position:relative;min-height:min(88vh,820px);display:flex;align-items:center;background-size:cover;background-position:center 38%;border-bottom:1px solid var(--hair)}
.cinema::before{content:"";position:absolute;inset:0;background:linear-gradient(98deg,rgba(16,12,9,.93) 0%,rgba(16,12,9,.72) 38%,rgba(16,12,9,.28) 72%,rgba(16,12,9,.45) 100%)}
.cinema::after{content:"";position:absolute;inset:0;box-shadow:inset 0 -120px 160px -60px rgba(10,8,6,.8),inset 0 90px 120px -60px rgba(10,8,6,.7);pointer-events:none}
.cinema .wrap{position:relative;z-index:1;padding-top:90px;padding-bottom:110px}
.cinema h1{font-family:var(--display);font-weight:500;font-size:clamp(2.6rem,5.4vw,4.4rem);line-height:1.06;letter-spacing:-.005em;color:var(--paper);max-width:15ch;margin-bottom:26px;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.cinema h1 em{font-style:italic;color:var(--gold-2)}
.cinema .lede{font-size:1.08rem;line-height:1.8;color:var(--cream-on-dark);max-width:46ch;margin-bottom:40px}
.hero-note{margin-top:30px;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(247,242,230,.5)}

/* ---------- interior page hero (dark) ---------- */
.page-hero{background:radial-gradient(120% 160% at 18% 0%,#241D15 0%,var(--noir) 55%);color:var(--paper);padding:88px 0 76px;border-bottom:1px solid var(--hair);position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-140px;top:-140px;width:520px;height:520px;border-radius:50%;border:1px solid var(--hair);pointer-events:none}
.page-hero::before{content:"";position:absolute;right:-80px;top:-80px;width:400px;height:400px;border-radius:50%;border:1px solid rgba(194,161,88,.14);pointer-events:none}
.page-hero h1{font-family:var(--display);font-weight:500;font-size:clamp(2.2rem,4.4vw,3.5rem);line-height:1.08;margin-bottom:22px;max-width:22ch}
.page-hero h1 em{font-style:italic;color:var(--gold-2)}
.page-hero .lede{font-size:1.04rem;line-height:1.8;color:var(--cream-on-dark);max-width:66ch}
.page-hero .lede a{color:var(--gold-2)}
.page-hero .btn-row{margin-top:36px}

/* ---------- in-page subnav ---------- */
.subnav{position:sticky;top:79px;z-index:40;background:var(--noir-2);border-bottom:1px solid var(--hair)}
.subnav ul{display:flex;gap:2px;list-style:none;overflow-x:auto;padding:0 28px;max-width:1200px;margin:0 auto;scrollbar-width:none}
.subnav ul::-webkit-scrollbar{display:none}
.subnav a{display:block;text-decoration:none;font-size:.7rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--cream-on-dark);padding:15px 16px;border-bottom:2px solid transparent;white-space:nowrap;transition:color .2s,border-color .2s}
.subnav a:hover{color:var(--gold-2);border-bottom-color:var(--gold)}

/* ---------- sections ---------- */
section{padding:96px 0;position:relative}
section.tight{padding:68px 0}
.sec-head{max-width:700px;margin-bottom:54px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-family:var(--display);font-weight:500;font-size:clamp(1.9rem,3.4vw,2.7rem);line-height:1.14;margin:14px 0 18px;letter-spacing:-.005em}
.sec-head h2 em{font-style:italic;color:#8a6e33}
.sec-head p{color:var(--ink-soft);font-size:1rem}
.sec-head p a{color:#8a6e33}
.band{background:var(--cream);border-top:1px solid var(--hair-lt);border-bottom:1px solid var(--hair-lt)}
.band-dark{background:radial-gradient(140% 140% at 50% -20%,#221B14 0%,var(--noir) 60%);color:var(--paper);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.band-dark .sec-head h2{color:var(--paper)}
.band-dark .sec-head h2 em{color:var(--gold-2)}
.band-dark .sec-head p{color:var(--cream-on-dark)}
.band-felt{background:radial-gradient(130% 150% at 50% -10%,#154433 0%,var(--felt-2) 65%);color:var(--paper);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.band-felt .sec-head h2{color:var(--paper)}
.band-felt .sec-head p{color:rgba(247,242,230,.78)}
h3.sub{font-family:var(--display);font-weight:600;font-size:1.4rem;margin:44px 0 16px}
h3.sub:first-child{margin-top:0}
p+p{margin-top:15px}
.prose{max-width:76ch;color:var(--ink-soft)}
.prose strong{color:var(--ink);font-weight:600}
.prose a{color:#8a6e33}
.on-dark .prose,.band-dark .prose,.band-felt .prose{color:var(--cream-on-dark)}
.band-dark .prose strong,.band-felt .prose strong{color:var(--paper)}
.band-dark .prose a,.band-felt .prose a{color:var(--gold-2)}

/* ---------- cards ---------- */
.cards{display:grid;grid-template-columns:1fr 1fr;gap:34px}
.cards.three{grid-template-columns:repeat(3,1fr)}
.card{border:1px solid var(--hair-lt);border-top:2px solid var(--gold);background:#FFFDF7;overflow:hidden;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s;box-shadow:0 4px 14px rgba(22,18,14,.05)}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.band-dark .card,.band-felt .card{background:var(--noir-2);border-color:var(--hair);color:var(--paper);box-shadow:0 10px 30px rgba(0,0,0,.35)}
.card .ph{aspect-ratio:16/10;overflow:hidden;background:var(--noir-2)}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.card:hover .ph img{transform:scale(1.045)}
.card-body{padding:30px 32px 34px;display:flex;flex-direction:column;flex:1}
.card-body h3{font-family:var(--display);font-size:1.4rem;font-weight:600;margin-bottom:10px}
.card-body p{color:var(--ink-soft);margin-bottom:20px;flex:1;font-size:.94rem}
.band-dark .card-body p,.band-felt .card-body p{color:var(--cream-on-dark)}
.card-body p a{color:#8a6e33}
.card-body .price{font-family:var(--display);font-weight:600;color:#8a6e33;margin-bottom:14px;font-size:1.05rem}
.band-dark .card-body .price{color:var(--gold-2)}

/* ---------- gallery ---------- */
.gallery-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:repeat(2,280px);gap:20px}
.g-item{overflow:hidden;position:relative;border:1px solid var(--hair-lt)}
.band-dark .g-item{border-color:var(--hair)}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.g-item:hover img{transform:scale(1.05)}
.g-tall{grid-row:span 2}
.g-wide{grid-column:span 2}
.g-cap{position:absolute;left:0;right:0;bottom:0;padding:34px 18px 14px;background:linear-gradient(transparent,rgba(12,9,7,.78));color:rgba(247,242,230,.95);font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase}

/* ---------- steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-left:1px solid var(--hair-lt)}
.steps.three{grid-template-columns:repeat(3,1fr)}
.step{padding:8px 30px 8px 26px;border-right:1px solid var(--hair-lt)}
.band-dark .steps,.band-felt .steps{border-color:var(--hair)}
.band-dark .step,.band-felt .step{border-color:var(--hair)}
.step-num{font-family:var(--display);font-style:italic;font-size:1rem;color:var(--gold);margin-bottom:10px}
.step h3{font-family:var(--display);font-size:1.15rem;font-weight:600;margin-bottom:8px}
.step p{font-size:.9rem;color:var(--ink-soft)}
.band-dark .step p,.band-felt .step p{color:var(--cream-on-dark)}
.step p a{color:#8a6e33}
.band-dark .step p a,.band-felt .step p a{color:var(--gold-2)}

/* ---------- timeline (full-width, two-column) ---------- */
.timeline{display:grid;grid-template-columns:1fr 1fr;column-gap:64px;row-gap:0;max-width:1080px}
.tl{display:grid;grid-template-columns:96px 1fr;gap:22px;align-items:baseline;padding:20px 0;border-bottom:1px solid var(--hair-lt)}
.band-dark .tl,.band-felt .tl{border-color:var(--hair)}
.tl-year{font-family:var(--display);font-weight:600;font-style:italic;font-size:1.3rem;color:var(--gold)}
.tl p{font-size:.93rem;color:var(--ink-soft)}
.band-dark .tl p,.band-felt .tl p{color:var(--cream-on-dark)}

/* ---------- wide framed photo ---------- */
.frame-photo{position:relative;margin-top:56px}
.frame-photo img{width:100%;max-height:520px;object-fit:cover;border:1px solid var(--hair-lt)}
.band-dark .frame-photo img{border-color:var(--hair)}
.frame-photo::after{content:"";position:absolute;inset:14px;border:1px solid var(--gold-dim);pointer-events:none}
.frame-photo figcaption{margin-top:14px;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);text-align:center}
.band-dark .frame-photo figcaption{color:rgba(247,242,230,.55)}

/* ---------- tables ---------- */
.table-scroll{overflow-x:auto;border:1px solid var(--hair-lt);border-top:2px solid var(--gold);background:#FFFDF7;box-shadow:0 4px 14px rgba(22,18,14,.05)}
table.data{width:100%;border-collapse:collapse;font-size:.9rem;min-width:660px}
table.data caption{text-align:left;font-family:var(--display);font-weight:600;font-size:1.05rem;padding:18px 20px 8px}
table.data th{background:var(--cream);text-align:left;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;padding:13px 18px;border-bottom:1px solid var(--gold-dim);white-space:nowrap;font-weight:600}
table.data td{padding:13px 18px;border-bottom:1px solid var(--hair-lt);vertical-align:top}
table.data tr:last-child td{border-bottom:none}
table.data td.num,table.data th.num{text-align:right;font-variant-numeric:tabular-nums}
table.data .muted{color:var(--ink-soft);font-size:.85rem}
.table-note{font-size:.84rem;color:var(--ink-soft);margin-top:14px}
.table-note a{color:#8a6e33}

/* ---------- swatches ---------- */
.swatches{display:grid;grid-template-columns:repeat(auto-fill,minmax(122px,1fr));gap:26px 18px}
.swatch{text-align:center}
.swatch .disc{width:88px;height:88px;border-radius:50%;margin:0 auto 12px;border:1px solid rgba(22,18,14,.3);box-shadow:inset 0 -8px 14px rgba(0,0,0,.18),inset 0 6px 10px rgba(255,255,255,.12),0 8px 16px rgba(22,18,14,.18);position:relative}
.swatch .disc::after{content:"";position:absolute;inset:17px;border-radius:50%;border:1px solid rgba(0,0,0,.18)}
.swatch .name{font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.swatch .tag{font-size:.7rem;color:var(--ink-soft)}

/* ---------- chip showcase ---------- */
.chip-row{display:grid;grid-template-columns:repeat(5,1fr);gap:28px}
.chip-card{text-align:center}
.chip-card svg{width:100%;max-width:136px;margin:0 auto 14px;filter:drop-shadow(0 14px 22px rgba(0,0,0,.45));transition:transform .35s}
.chip-card:hover svg{transform:rotate(8deg) scale(1.06)}
.chip-card .label{font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase}
.chip-card .sub{font-size:.74rem;color:var(--ink-soft);margin-top:2px}
.band-dark .chip-card .sub,.band-felt .chip-card .sub{color:rgba(247,242,230,.55)}

/* ---------- accordion ---------- */
details.faq{border:1px solid var(--hair-lt);background:#FFFDF7;margin-bottom:-1px}
details.faq summary{cursor:pointer;font-family:var(--display);font-weight:600;font-size:1.02rem;padding:19px 24px;list-style:none;display:flex;justify-content:space-between;gap:16px;align-items:center}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary::after{content:"+";font-family:var(--display);font-size:1.4rem;color:var(--gold);flex:none;font-weight:400}
details.faq[open]{border-left:2px solid var(--gold)}
details.faq[open] summary::after{content:"\2013"}
details.faq .a{padding:0 24px 20px;color:var(--ink-soft);font-size:.94rem;max-width:80ch}

/* ---------- callouts ---------- */
.callout{border:1px solid var(--hair-lt);border-left:2px solid var(--gold);background:#FFFDF7;padding:22px 26px;font-size:.93rem;color:var(--ink-soft);margin:30px 0;box-shadow:0 4px 14px rgba(22,18,14,.04)}
.callout strong{color:var(--ink)}
.callout a{color:#8a6e33}
.band-dark .callout,.band-felt .callout{background:var(--noir-2);border-color:var(--hair);border-left-color:var(--gold);color:var(--cream-on-dark)}
.band-dark .callout strong,.band-felt .callout strong{color:var(--paper)}

/* ---------- quotes ---------- */
.quote{max-width:820px;margin:0 auto;text-align:center}
.quote blockquote{font-family:var(--display);font-style:italic;font-weight:400;font-size:clamp(1.4rem,2.8vw,1.95rem);line-height:1.46;margin-bottom:22px}
.quote blockquote::before{content:"\201C";display:block;font-size:3.4rem;line-height:.6;color:var(--gold);margin-bottom:18px}
.quote cite{font-style:normal;font-size:.7rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--gold)}
.quote cite a{color:inherit}
.quote-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:30px}
.quote-card{background:#FFFDF7;border:1px solid var(--hair-lt);border-top:2px solid var(--gold);padding:32px;box-shadow:0 4px 14px rgba(22,18,14,.05)}
.quote-card blockquote{font-family:var(--display);font-style:italic;font-size:1.08rem;line-height:1.55;margin-bottom:16px}
.quote-card cite{font-style:normal;font-size:.66rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:#8a6e33}

/* ---------- split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split .ph{position:relative}
.split .ph img{border:1px solid var(--hair-lt);box-shadow:var(--shadow)}
.band-dark .split .ph img,.band-felt .split .ph img{border-color:var(--hair);box-shadow:var(--shadow-dark)}
.split .ph::after{content:"";position:absolute;inset:12px;border:1px solid var(--gold-dim);pointer-events:none}
.split h2{font-family:var(--display);font-weight:500;font-size:clamp(1.8rem,3.2vw,2.5rem);line-height:1.14;margin:12px 0 18px}
.split h2 em{font-style:italic;color:#8a6e33}
.band-dark .split h2 em,.band-felt .split h2 em{color:var(--gold-2)}

/* ---------- form ---------- */
form.contact{display:grid;gap:22px;max-width:660px}
form.contact label{font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;display:block;margin-bottom:8px;color:var(--ink)}
form.contact input,form.contact textarea,form.contact select{width:100%;font:inherit;font-size:.95rem;padding:14px 16px;border:1px solid var(--hair-lt);border-radius:0;background:#FFFDF7;color:var(--ink)}
form.contact input:focus,form.contact textarea:focus,form.contact select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}

/* ---------- footer ---------- */
footer.site{background:linear-gradient(180deg,var(--noir) 0%,#0F0C09 100%);color:rgba(247,242,230,.62);padding:76px 0 40px;font-size:.9rem;border-top:1px solid var(--hair)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:44px;margin-bottom:54px}
footer.site h4{color:var(--gold);font-family:var(--body);font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;margin-bottom:18px;font-weight:600}
footer.site ul{list-style:none}
footer.site li{margin-bottom:11px}
footer.site a{text-decoration:none;transition:color .2s}
footer.site a:hover{color:var(--gold-2)}
.foot-brand p{max-width:36ch;margin-top:16px;font-size:.86rem;line-height:1.75}
.foot-base{border-top:1px solid var(--hair);padding-top:26px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(247,242,230,.35)}

/* ---------- responsive ---------- */
@media (max-width:960px){
  .split{grid-template-columns:1fr;gap:44px}
  .steps,.steps.three{grid-template-columns:1fr 1fr;border-left:none}
  .step{border-left:1px solid var(--hair-lt);margin-bottom:28px}
  .band-dark .step,.band-felt .step{border-left-color:var(--hair)}
  .cards,.cards.three{grid-template-columns:1fr 1fr}
  .chip-row{grid-template-columns:repeat(3,1fr)}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:repeat(2,230px)}
  .quote-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .timeline{grid-template-columns:1fr;max-width:760px}
  nav.main ul{display:none}
  nav.main ul.open{display:flex;position:absolute;top:100%;left:0;right:0;background:var(--noir);flex-direction:column;gap:0;padding:10px 28px 24px;border-bottom:1px solid var(--hair)}
  nav.main ul.open li{padding:11px 0}
  .menu-btn{display:block}
  .subnav{top:79px}
  .cinema{min-height:72vh}
}
@media (max-width:600px){
  body{font-size:16px}
  section{padding:68px 0}
  .cards,.cards.three,.steps,.steps.three{grid-template-columns:1fr}
  .chip-row{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:1fr;grid-template-rows:auto}
  .g-tall,.g-wide{grid-row:auto;grid-column:auto}
  .g-item{height:250px}
  .g-item.g-tall{height:400px}
  .tl{grid-template-columns:1fr;gap:6px}
  .foot-grid{grid-template-columns:1fr}
  .cinema .wrap{padding-top:70px;padding-bottom:80px}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;animation:none!important}
  html{scroll-behavior:auto}
}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

/* inline SVG illustrations in photo slots */
.frame-photo svg{width:100%;height:auto;display:block;border:1px solid var(--hair-lt)}
.band .frame-photo svg{border-color:var(--hair-lt)}
.card .ph svg{width:100%;height:100%}
