/* ALOHA Resorts — Component styles */

/* ============ Card grid ============ */
.cardgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.cardgrid--3{grid-template-columns:repeat(3,1fr)}
.cardgrid--4{grid-template-columns:repeat(4,1fr)}
.cardgrid--2{grid-template-columns:repeat(2,1fr)}
@media (max-width: 980px){.cardgrid--3,.cardgrid--4{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 640px){.cardgrid,.cardgrid--3,.cardgrid--4,.cardgrid--2{grid-template-columns:1fr}}

.card{
  position:relative;overflow:hidden;background:var(--c-cream-2);
  border-radius:var(--radius);
  transition:var(--t);
  box-shadow:var(--shadow-sm);
  border:1px solid var(--c-line);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--c-gold)}
.card .card-media{position:relative;overflow:hidden}
.card .card-media image-slot,.card .card-media img{width:100%;aspect-ratio:4/5;object-fit:cover;display:block;transition:transform var(--t-slow)}
.card:hover .card-media image-slot,.card:hover .card-media img{transform:scale(1.05)}
.card-tag{
  position:absolute;top:14px;left:14px;z-index:2;
  background:var(--c-cream);color:var(--c-ink);
  padding:6px 12px;font-size:10px;letter-spacing:.24em;text-transform:uppercase;
}
.card-body{padding:24px 20px 28px}
.card-eyebrow{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--c-gold);margin-bottom:10px;display:block}
.card h3{font-size:var(--fs-h3);margin-bottom:8px}
.card p{font-size:14px;color:var(--c-muted);margin-bottom:18px}
.card .card-foot{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--c-line);padding-top:14px}
.card .card-foot .price{font-family:var(--f-display);font-size:18px;color:var(--c-ink)}
.card .card-foot .price em{font-style:normal;color:var(--c-muted);font-size:11px;letter-spacing:.18em;text-transform:uppercase;display:block;font-family:var(--f-body)}
.card .card-link{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--c-ink);border-bottom:1px solid var(--c-gold);padding-bottom:3px;transition:var(--t-fast)}
.card .card-link:hover{color:var(--c-gold)}

/* ============ Pillar (4 hub showcase) ============ */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--c-line)}
.pillar{position:relative;display:flex;flex-direction:column;border-right:1px solid var(--c-line);min-height:520px;overflow:hidden;background:var(--c-cream)}
.pillar:last-child{border-right:0}
.pillar-media{position:relative;flex:1;overflow:hidden}
.pillar-media image-slot,.pillar-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform var(--t-slow)}
.pillar:hover .pillar-media image-slot,.pillar:hover .pillar-media img{transform:scale(1.06)}
.pillar-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 20%,rgba(5,28,16,.55) 60%,rgba(4,22,12,.82));transition:var(--t)}
.pillar-body{position:absolute;left:0;right:0;bottom:0;padding:32px 26px 30px;color:var(--c-cream);z-index:2}
.pillar-body .p-num{font-family:var(--f-display);font-size:14px;letter-spacing:.4em;color:var(--c-gold);margin-bottom:14px}
.pillar-body h3{color:var(--c-cream);font-size:30px;margin-bottom:12px}
.pillar-body p{font-size:13px;color:rgba(250,248,243,.80);margin-bottom:18px;max-width:30ch}
.pillar-body .arr{display:inline-flex;align-items:center;gap:10px;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--c-gold);padding-bottom:3px;border-bottom:1px solid var(--c-gold);transition:var(--t-fast)}
.pillar:hover .pillar-body .arr{padding-right:8px}
@media (max-width: 980px){.pillars{grid-template-columns:repeat(2,1fr)}.pillar{min-height:420px;border-bottom:1px solid var(--c-line)}}
@media (max-width: 560px){.pillars{grid-template-columns:1fr}}

/* ============ Feature row (alternating editorial) ============ */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-bottom:var(--sec-v)}
.feature:last-child{margin-bottom:0}
.feature.reverse .feature-media{order:2}
.feature-media{position:relative;aspect-ratio:4/5;overflow:hidden}
.feature-media image-slot,.feature-media img{width:100%;height:100%;object-fit:cover;display:block}
.feature-media::before{
  content:"";position:absolute;left:20px;top:20px;width:40px;height:40px;
  border-top:2px solid var(--c-gold);border-left:2px solid var(--c-gold);
  z-index:2;
}
.feature-media::after{
  content:"";position:absolute;right:20px;bottom:20px;width:40px;height:40px;
  border-bottom:2px solid var(--c-gold);border-right:2px solid var(--c-gold);
  z-index:2;
}
.feature-body h2{font-size:var(--fs-h2);margin-bottom:24px}
.feature-body p{font-size:17px;color:var(--c-muted);line-height:1.6;margin-bottom:18px}
.feature-body ul.spec{margin-top:32px;border-top:1px solid var(--c-line);padding-top:24px}
.feature-body ul.spec li{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--c-line);font-size:14px}
.feature-body ul.spec li b{font-weight:500;font-family:var(--f-display);font-size:18px;color:var(--c-ink)}
.feature-body .btn{margin-top:32px}
@media (max-width: 900px){.feature{grid-template-columns:1fr;gap:32px}.feature.reverse .feature-media{order:0}}

/* ============ Quote / review ============ */
.quote{padding:var(--sec-v) var(--pad-x);background:var(--c-cream-2);text-align:center}
.quote q{
  display:block;font-family:var(--f-display);font-size:clamp(28px,3.4vw,46px);
  line-height:1.25;color:var(--c-ink);max-width:30ch;margin:0 auto;quotes:none;text-wrap:balance;
}
.quote q::before,.quote q::after{content:""}
.quote .stars{color:var(--c-gold);letter-spacing:.4em;margin-bottom:24px;font-size:14px}
.quote .attr{margin-top:32px;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--c-muted)}
.quote .attr b{color:var(--c-ink);font-weight:500}

/* Review carousel */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review{
  background:var(--c-cream);padding:40px;
  border:1px solid var(--c-line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  transition:var(--t);
  border-top:3px solid transparent;
}
.review:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--c-line);border-top-color:var(--c-gold)}
.review .stars{color:var(--c-gold);letter-spacing:.3em;font-size:14px;margin-bottom:18px}
.review q{font-family:var(--f-display);font-size:22px;line-height:1.4;color:var(--c-ink);display:block;quotes:none}
.review q::before,.review q::after{content:""}
.review .attr{margin-top:22px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--c-muted)}
.review .attr b{color:var(--c-ink);display:block;margin-bottom:2px}
@media (max-width: 900px){.reviews{grid-template-columns:1fr}}

/* ============ Stats strip ============ */
.statstrip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--c-line);border-block:1px solid var(--c-line)}
.statstrip > div{background:var(--c-cream);padding:48px 24px;text-align:center}
.statstrip b{display:block;font-family:var(--f-display);font-size:clamp(36px,4vw,64px);color:var(--c-ink);font-weight:400;margin-bottom:8px}
.statstrip span{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--c-muted)}
.section--ink .statstrip{background:var(--c-line-dark);border-color:var(--c-line-dark)}
.section--ink .statstrip > div{background:var(--c-ink)}
.section--ink .statstrip b{color:var(--c-gold)}
.section--ink .statstrip span{color:rgba(250,248,243,.72)}
@media (max-width: 760px){.statstrip{grid-template-columns:repeat(2,1fr)}.statstrip > div{padding:32px 16px}}

/* ============ Timeline / process ============ */
.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;counter-reset:tl}
.timeline > div{position:relative;padding-top:48px;counter-increment:tl}
.timeline > div::before{
  content:counter(tl,decimal-leading-zero);
  position:absolute;top:0;left:0;font-family:var(--f-display);font-size:13px;color:var(--c-gold);letter-spacing:.36em;font-weight:400;
}
.timeline > div::after{content:"";position:absolute;top:24px;left:36px;right:-24px;height:1px;background:var(--c-line)}
.timeline > div:last-child::after{display:none}
.timeline h4{font-family:var(--f-display);font-size:22px;margin-bottom:10px}
.timeline p{font-size:14px;color:var(--c-muted);margin:0}
@media (max-width: 760px){.timeline{grid-template-columns:1fr;gap:24px}.timeline > div::after{display:none}}

/* ============ FAQ ============ */
.faq-list{max-width:880px;margin:0 auto;border-top:1px solid var(--c-line)}
.faq-item{border-bottom:1px solid var(--c-line)}
.faq-item summary{
  list-style:none;cursor:pointer;padding:26px 0;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  font-family:var(--f-display);font-size:clamp(19px,2vw,26px);color:var(--c-ink);
  line-height:1.2;
  transition:color var(--t-fast);
}
details[open] > .faq-item summary,
.faq-item[open] > summary{color:var(--c-brand)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--c-gold)}
.faq-item .plus{
  flex-shrink:0;width:32px;height:32px;border:1px solid var(--c-line);
  display:grid;place-items:center;font-size:18px;font-family:var(--f-body);color:var(--c-gold);
  transition:var(--t);
}
.faq-item[open] .plus{background:var(--c-gold);color:var(--c-ink);transform:rotate(45deg)}
.faq-item .ans{padding:0 0 28px;color:var(--c-muted);font-size:16px;max-width:62ch;line-height:1.7}

/* ============ Enquiry block ============ */
.enquiry{position:relative;background:var(--c-ink);color:var(--c-cream);overflow:hidden}
.enquiry::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 20%,rgba(200,150,60,.15),transparent 50%),
             radial-gradient(circle at 10% 90%,rgba(200,150,60,.09),transparent 40%);
  pointer-events:none;
}
.enquiry-grid{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;padding:var(--sec-v) var(--pad-x);max-width:var(--max);margin:0 auto}
.enquiry h2{color:var(--c-cream);font-size:var(--fs-h2);margin-bottom:24px}
.enquiry .lede{color:rgba(250,248,243,.84)}
.enquiry .contact-list{margin-top:40px;display:flex;flex-direction:column;gap:18px;border-top:1px solid var(--c-line-dark);padding-top:24px}
.enquiry .contact-list a{display:flex;align-items:baseline;gap:14px;color:var(--c-cream);transition:var(--t-fast)}
.enquiry .contact-list a:hover{color:var(--c-gold)}
.enquiry .contact-list .lbl{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--c-gold);width:80px;flex-shrink:0}
.enquiry .contact-list .val{font-family:var(--f-display);font-size:20px}

.form{display:grid;gap:18px}
.field{display:flex;flex-direction:column;gap:8px;position:relative}
.field label{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--c-gold)}
.field input,.field select,.field textarea{
  background:transparent;border:0;border-bottom:1px solid var(--c-line-dark);
  padding:13px 0;color:var(--c-cream);font-size:16px;transition:border-color var(--t-fast),box-shadow var(--t-fast);
  font-family:var(--f-body);
  border-radius:0;
}
.field input::placeholder,.field textarea::placeholder{color:rgba(250,248,243,.35)}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-bottom-color:var(--c-gold);
  box-shadow:0 2px 0 -1px rgba(200,150,60,.35);
}
.field select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%23C8963C' d='M5 6 0 0h10z'/></svg>");background-repeat:no-repeat;background-position:right 4px center;background-size:10px}
.field select option{background:var(--c-ink);color:var(--c-cream)}
.field textarea{resize:vertical;min-height:80px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form .btn{margin-top:14px;justify-self:start}
.form .small{font-size:11px;color:rgba(250,248,243,.52);letter-spacing:.02em}
@media (max-width: 900px){.enquiry-grid{grid-template-columns:1fr;gap:40px}.field-row{grid-template-columns:1fr}}

/* ============ YMAL — You may also like ============ */
.ymal{background:var(--c-cream-2);padding:var(--sec-v) var(--pad-x)}
.ymal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:var(--max);margin:0 auto}
.ymal-card{position:relative;overflow:hidden;background:var(--c-ink);color:var(--c-cream);min-height:280px;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;text-decoration:none}
.ymal-card image-slot,.ymal-card img.ymal-bg{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover;display:block}
.ymal-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,61,37,.32),rgba(6,38,22,.88));z-index:1;transition:var(--t)}
.ymal-card:hover::after{background:linear-gradient(180deg,rgba(10,61,37,.22),rgba(6,38,22,.96))}
.ymal-card .content{position:relative;z-index:2}
.ymal-card .ey{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--c-gold);margin-bottom:8px;display:block}
.ymal-card h4{font-family:var(--f-display);font-size:24px;color:var(--c-cream);margin-bottom:6px}
.ymal-card p{font-size:13px;color:rgba(250,248,243,.72);margin:0}
@media (max-width: 900px){.ymal-grid{grid-template-columns:1fr 1fr}}
@media (max-width: 560px){.ymal-grid{grid-template-columns:1fr}}

/* ============ Logos strip ============ */
.logos{display:flex;flex-wrap:wrap;justify-content:center;gap:48px;align-items:center}
.logos > div{font-family:var(--f-display);font-size:22px;letter-spacing:.18em;text-transform:uppercase;color:var(--c-muted);opacity:.6;transition:var(--t-fast)}
.logos > div:hover{opacity:1;color:var(--c-ink)}

/* ============ Owner message ============ */
.owner{display:grid;grid-template-columns:.6fr 1fr;gap:64px;align-items:center;max-width:1080px;margin:0 auto}
.owner-photo{aspect-ratio:4/5;background:var(--c-cream-2);position:relative;overflow:hidden}
.owner-photo image-slot,.owner-photo img{width:100%;height:100%;object-fit:cover;display:block}
.owner-body q{font-family:var(--f-display);font-size:clamp(22px,2.3vw,32px);line-height:1.35;color:var(--c-ink);display:block;margin-bottom:32px;quotes:none;font-style:italic}
.owner-body q::before,.owner-body q::after{content:""}
.owner-body .sign{font-family:var(--f-display);font-size:24px;color:var(--c-ink)}
.owner-body .role{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--c-muted);margin-top:4px}
@media (max-width: 760px){.owner{grid-template-columns:1fr;gap:32px}}

/* ============ Marquee ============ */
.marquee{overflow:hidden;border-block:1px solid var(--c-line);background:var(--c-cream-2)}
.marquee-track{display:flex;gap:64px;padding:24px 0;animation:marquee 40s linear infinite;white-space:nowrap}
.marquee span{font-family:var(--f-display);font-size:clamp(20px,2vw,32px);color:var(--c-ink);font-style:italic;display:inline-flex;align-items:center;gap:64px}
.marquee span::after{content:"✦";color:var(--c-gold);font-style:normal;margin-left:64px}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============ Press strip ============ */
.press{display:flex;justify-content:center;gap:48px;flex-wrap:wrap;align-items:center;padding:32px 0;border-block:1px solid var(--c-line);background:var(--c-cream)}
.press > .item{font-family:var(--f-display);font-size:18px;color:var(--c-muted);letter-spacing:.06em;font-style:italic}
.press > .item b{font-style:normal;color:var(--c-ink);font-weight:400;margin-right:8px}

/* ============ Capacity / spec table ============ */
.spec-table{width:100%;border-collapse:collapse;border-top:1px solid var(--c-line)}
.spec-table th,.spec-table td{padding:18px 12px;text-align:left;border-bottom:1px solid var(--c-line);font-size:14px}
.spec-table th{font-family:var(--f-body);font-weight:500;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--c-muted)}
.spec-table td:first-child{font-family:var(--f-display);font-size:18px;color:var(--c-ink)}
.spec-table tr:hover td{background:var(--c-cream-2)}
@media (max-width: 720px){.spec-table th:nth-child(3),.spec-table td:nth-child(3){display:none}}
.section--ink .spec-table{border-top-color:rgba(255,255,255,.12)}
.section--ink .spec-table th,.section--ink .spec-table td{border-bottom-color:rgba(255,255,255,.08);color:rgba(250,248,243,.65)}
.section--ink .spec-table th{color:rgba(250,248,243,.4)}
.section--ink .spec-table td:first-child{color:var(--c-cream)}
.section--ink .spec-table tr:hover td{background:rgba(255,255,255,.04)}

/* ============ Highlight number ============ */
.hl-num{display:flex;gap:24px;align-items:baseline;margin-bottom:24px}
.hl-num b{font-family:var(--f-display);font-size:clamp(56px,6vw,96px);color:var(--c-gold);font-weight:400;line-height:.9}
.hl-num span{font-size:14px;color:var(--c-muted);max-width:18ch;line-height:1.4}

/* ============ Gallery grid (asymmetric) ============ */
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;grid-auto-rows:200px}
.gal image-slot,.gal img{width:100%;height:100%;object-fit:cover;display:block}
.gal > .g1{grid-column:span 2;grid-row:span 2}
.gal > .g2{grid-column:span 1;grid-row:span 1}
.gal > .g3{grid-column:span 1;grid-row:span 2}
.gal > .g4{grid-column:span 2;grid-row:span 1}
@media (max-width: 760px){.gal{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}.gal > .g1{grid-column:span 2}.gal > .g3{grid-row:span 1}}

/* ============ Responsive: trust + location section ============ */
@media (max-width: 860px){
  .trust-loc-grid{grid-template-columns:1fr!important}
}

/* ============ Responsive: homepage gallery strip ============ */
@media (max-width: 760px){
  .home-gallery-grid{grid-template-columns:repeat(2,1fr)!important;grid-template-rows:auto!important}
  .home-gallery-grid > div:first-child{grid-column:1/3!important;grid-row:auto!important;aspect-ratio:16/9}
}
@media (max-width: 480px){
  .home-gallery-grid > div:nth-child(n+4){display:none}
}

/* ============ Activity tiles — Day Outing hub ============ */
.activity-tiles{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.activity-tile{
  background:var(--c-cream);border:1px solid var(--c-line);
  border-radius:var(--radius);padding:20px 14px;text-align:center;
  transition:var(--t);
}
.activity-tile:hover{border-color:var(--c-gold);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.activity-tile .at-icon{font-size:28px;margin-bottom:10px;display:block}
.activity-tile .at-label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--c-muted);font-weight:500;line-height:1.3}
.section--ink .activity-tile{background:var(--c-ink-2);border-color:var(--c-line-dark)}
.section--ink .activity-tile:hover{border-color:var(--c-gold)}
.section--ink .activity-tile .at-label{color:rgba(250,248,243,.75)}
@media (max-width:980px){.activity-tiles{grid-template-columns:repeat(3,1fr)}}
@media (max-width:560px){.activity-tiles{grid-template-columns:repeat(2,1fr)}}

/* ============ Room type cards — Stay hub ============ */
.room-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.room-card{border:1px solid var(--c-line);border-radius:var(--radius-lg);overflow:hidden;background:var(--c-cream);transition:var(--t)}
.room-card:hover{box-shadow:var(--shadow-md);border-color:var(--c-gold);transform:translateY(-3px)}
.room-card-media{aspect-ratio:4/3;overflow:hidden}
.room-card-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform var(--t-slow)}
.room-card:hover .room-card-media img{transform:scale(1.05)}
.room-card-body{padding:24px}
.room-card-body .rc-label{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--c-gold);margin-bottom:8px;display:block}
.room-card-body h3{font-family:var(--f-display);font-size:clamp(22px,1.8vw,28px);color:var(--c-ink);margin-bottom:8px}
.room-card-body p{font-size:14px;color:var(--c-muted);margin:0;line-height:1.6}
.room-card-body .rc-detail{margin-top:14px;padding-top:14px;border-top:1px solid var(--c-line);font-size:12px;color:var(--c-muted);letter-spacing:.06em}
@media (max-width:760px){.room-cards{grid-template-columns:1fr}}

/* ============ Venue capacity cards — Weddings hub ============ */
.venue-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--c-line);border-radius:var(--radius-lg);overflow:hidden}
.venue-card{padding:36px 28px;border-right:1px solid var(--c-line);position:relative}
.venue-card:last-child{border-right:0}
.venue-card::before{content:"";position:absolute;top:0;left:28px;width:40px;height:3px;background:var(--c-gold)}
.venue-card .vc-cap{font-family:var(--f-display);font-size:clamp(44px,4.5vw,68px);color:var(--c-gold);font-weight:400;line-height:1;margin-bottom:4px}
.venue-card .vc-unit{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--c-muted);margin-bottom:18px;display:block}
.venue-card h4{font-family:var(--f-display);font-size:clamp(18px,1.6vw,22px);color:var(--c-ink);margin-bottom:10px}
.venue-card p{font-size:13px;color:var(--c-muted);line-height:1.6;margin:0}
.section--ink .venue-card{border-color:var(--c-line-dark)}
.section--ink .venue-card .vc-unit{color:rgba(250,248,243,.55)}
.section--ink .venue-card h4{color:var(--c-cream)}
.section--ink .venue-card p{color:rgba(250,248,243,.68)}
@media (max-width:760px){.venue-cards{grid-template-columns:1fr}.venue-card{border-right:0;border-bottom:1px solid var(--c-line)}.venue-card:last-child{border-bottom:0}}

/* ============ Trust badges — Corporate hub ============ */
.trust-badges{display:flex;flex-wrap:wrap;gap:10px}
.trust-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border:1px solid var(--c-line);border-radius:100px;
  font-size:12px;color:var(--c-muted);letter-spacing:.04em;
  transition:var(--t-fast);
}
.trust-badge:hover{border-color:var(--c-gold);color:var(--c-ink)}
.trust-badge::before{content:"✓";color:var(--c-gold);font-weight:700;font-size:13px;flex-shrink:0}
.section--ink .trust-badge{border-color:rgba(200,150,60,.2);color:rgba(250,248,243,.65)}
.section--ink .trust-badge:hover{border-color:var(--c-gold);color:var(--c-cream)}
.section--warm .trust-badge{border-color:rgba(200,150,60,.25);color:rgba(250,248,243,.68)}
.section--warm .trust-badge:hover{border-color:var(--c-gold);color:var(--c-cream)}
.section--warm .venue-card{border-color:rgba(200,150,60,.15)}
.section--warm .venue-card .vc-unit{color:rgba(250,248,243,.55)}
.section--warm .venue-card h4{color:var(--c-cream)}
.section--warm .venue-card p{color:rgba(250,248,243,.68)}
.section--warm .eyebrow{color:var(--c-gold);border-color:rgba(200,150,60,.35)}
.section--slate .trust-badge{border-color:rgba(200,150,60,.2);color:rgba(250,248,243,.65)}
.section--slate .trust-badge:hover{border-color:var(--c-gold);color:var(--c-cream)}
.section--slate .spec-table{border-top-color:rgba(255,255,255,.1)}
.section--slate .spec-table th,.section--slate .spec-table td{border-bottom-color:rgba(255,255,255,.07);color:rgba(250,248,243,.65)}
.section--slate .spec-table th{color:rgba(250,248,243,.38)}
.section--slate .spec-table td:first-child{color:var(--c-cream)}
.section--slate .spec-table tr:hover td{background:rgba(255,255,255,.04)}

/* ============ Day outing price callout ============ */
.outing-price{
  display:flex;align-items:center;gap:28px;flex-wrap:wrap;
  padding:40px 48px;
  background:var(--c-ink);color:var(--c-cream);
  border-radius:var(--radius-lg);
}
.outing-price .op-amount{font-family:var(--f-display);font-size:clamp(56px,5.5vw,80px);color:var(--c-gold);font-weight:400;line-height:1;flex-shrink:0}
.outing-price .op-meta{display:flex;flex-direction:column;gap:6px}
.outing-price .op-label{font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:rgba(250,248,243,.55)}
.outing-price .op-desc{font-size:clamp(16px,1.4vw,20px);color:var(--c-cream);line-height:1.4}
.outing-price .op-includes{margin-top:4px;font-size:13px;color:rgba(250,248,243,.65)}
@media (max-width:640px){.outing-price{padding:28px 24px;gap:18px}.outing-price .op-amount{font-size:clamp(44px,10vw,64px)}}

/* ============ Day step timeline ============ */
.day-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--c-line);position:relative}
.day-step{padding:28px 24px;border-right:1px solid var(--c-line);position:relative}
.day-step:last-child{border-right:0}
.day-step .ds-time{font-family:var(--f-display);font-size:28px;color:var(--c-gold);font-weight:400;margin-bottom:8px}
.day-step h4{font-size:14px;font-weight:600;color:var(--c-ink);margin-bottom:6px;letter-spacing:.04em}
.day-step p{font-size:13px;color:var(--c-muted);margin:0;line-height:1.5}
.section--cream2 .day-step{border-color:var(--c-line)}
@media (max-width:760px){.day-steps{grid-template-columns:repeat(2,1fr)}.day-step:nth-child(2){border-right:0}.day-step:nth-child(n+3){border-top:1px solid var(--c-line)}}
@media (max-width:480px){.day-steps{grid-template-columns:1fr}.day-step{border-right:0;border-bottom:1px solid var(--c-line)}.day-step:last-child{border-bottom:0}}
