/* =========================================================
   Silver Bridge Zone — layout.css
   ========================================================= */

/* ---------- featured destinations (magazine grid) ---------- */
.feature-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:1.3rem; }
.dest-card { position:relative; border-radius:var(--radius-lg); overflow:hidden; min-height:300px; display:flex; align-items:flex-end; color:#fff; box-shadow:var(--shadow-sm); transition:transform .5s var(--ease), box-shadow .5s var(--ease); }
.dest-card .scene { transition:transform .8s var(--ease); }
.dest-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); }
.dest-card:hover .scene { transform:scale(1.06); }
.dest-card .dc-body { position:relative; z-index:2; padding:1.6rem; width:100%; }
.dest-card .coord { color:rgba(255,255,255,.82); margin-bottom:.6rem; }
.dest-card h3 { color:#fff; font-size:1.7rem; line-height:1.05; }
.dest-card p { color:rgba(255,255,255,.84); font-size:.92rem; margin-top:.4rem; max-width:34ch; }
.dest-card .go { display:inline-flex; align-items:center; gap:.4rem; margin-top:1rem; font-weight:600; font-size:.86rem; letter-spacing:.04em; }
.dest-card .go svg{ width:15px;height:15px; transition:transform .3s var(--ease); }
.dest-card:hover .go svg{ transform:translateX(5px); }
.dest-card.lg { grid-column:span 4; min-height:440px; }
.dest-card.sm { grid-column:span 2; }
.dest-card.md { grid-column:span 3; }
.dest-card-center { grid-column:3 / span 2; }
.feature-grid-alt .dest-card.lg { min-height:480px; }
.feature-grid-alt .dest-card:nth-child(2) { margin-top:2.5rem; }
.feature-grid-alt .dest-card:nth-child(5) { margin-top:-1.5rem; }

/* ---------- itinerary cards (interactive route) ---------- */
.itin-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.itin { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; display:flex; flex-direction:column; transition:transform .4s var(--ease), box-shadow .4s var(--ease); }
.itin:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); }
.itin .itin-top { position:relative; height:170px; color:#fff; display:flex; align-items:flex-end; }
.itin .itin-top .meta { position:relative; z-index:2; padding:1.2rem 1.4rem; display:flex; gap:1rem; width:100%; }
.itin .pill { background:rgba(255,255,255,.18); backdrop-filter:blur(4px); border:1px solid rgba(255,255,255,.25); border-radius:var(--radius-pill); padding:.25rem .7rem; font-size:.74rem; font-weight:600; letter-spacing:.04em; }
.itin .itin-body { padding:1.5rem 1.5rem 1.7rem; display:flex; flex-direction:column; flex:1; }
.itin .itin-region { font-size:.74rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--ocean); }
.itin h3 { font-size:1.55rem; margin-top:.45rem; line-height:1.1; }
.itin p { color:var(--muted); font-size:.96rem; margin-top:.55rem; flex:1; }
.itin .itin-stats { display:flex; gap:1.3rem; margin-top:1.1rem; padding-top:1.1rem; border-top:1px solid var(--line-soft); }
.itin .itin-stats .st { display:flex; flex-direction:column; }
.itin .itin-stats .st .v { font-family:var(--display); font-weight:600; font-size:1.3rem; color:var(--ink); line-height:1; }
.itin .itin-stats .st .k { font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted-2); margin-top:.3rem; }
.itin .itin-toggle { margin-top:1.2rem; display:inline-flex; align-items:center; gap:.5rem; font-weight:600; font-size:.9rem; color:var(--ocean-deep); align-self:flex-start; }
.itin .itin-toggle svg{ width:16px;height:16px; transition:transform .35s var(--ease); }
.itin.open .itin-toggle svg{ transform:rotate(180deg); }
.itin .route { overflow:hidden; max-height:0; transition:max-height .45s var(--ease); }
.itin .route-inner { padding-top:1.2rem; }
.route-stop { position:relative; padding-left:1.8rem; padding-bottom:1.1rem; }
.route-stop::before { content:""; position:absolute; left:5px; top:6px; bottom:-6px; width:2px; background:var(--line); }
.route-stop:last-child::before{ display:none; }
.route-stop::after { content:""; position:absolute; left:0; top:5px; width:12px;height:12px; border-radius:50%; background:var(--surface); border:2px solid var(--ocean); }
.route-stop.sun::after{ border-color:var(--sun); } .route-stop.forest::after{ border-color:var(--forest); }
.route-stop .day { font-size:.72rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--ocean); }
.route-stop h4 { font-family:var(--body); font-weight:700; font-size:.98rem; margin-top:.15rem; }
.route-stop p { font-size:.9rem; color:var(--muted); margin-top:.2rem; }

/* ---------- filter bar (itinerary filtering) ---------- */
.filter-bar { display:flex; flex-wrap:wrap; gap:.5rem; align-items:center; margin-bottom:2rem; }
.filter-bar .fl { font-size:.74rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-right:.6rem; }
.chip { font-size:.88rem; font-weight:500; padding:.5rem 1rem; border-radius:var(--radius-pill); border:1.5px solid var(--line); background:var(--surface); color:var(--ink-soft); transition:.2s; }
.chip:hover { border-color:var(--ocean); color:var(--ocean-deep); }
.chip.active { background:var(--ocean); border-color:var(--ocean); color:#fff; }
.filter-empty { display:none; text-align:center; padding:3rem 1rem; color:var(--muted); background:var(--surface); border:1px dashed var(--sand-deep); border-radius:var(--radius-lg); }
.filter-empty.show { display:block; }

/* ---------- why grid ---------- */
.why-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; }
.why { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:1.8rem; transition:transform .4s var(--ease), box-shadow .4s var(--ease); }
.why:hover { transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--sand-deep); }
.why .wi { width:52px;height:52px;border-radius:14px; background:var(--ocean-tint); color:var(--ocean-deep); display:grid;place-items:center; margin-bottom:1.1rem; }
.why:nth-child(2) .wi{ background:var(--forest-tint); color:var(--forest-deep); }
.why:nth-child(3) .wi{ background:var(--sun-soft); color:#9a5e22; }
.why:nth-child(4) .wi{ background:var(--ocean-tint); color:var(--ocean-deep); }
.why .wi svg{ width:25px;height:25px; }
.why h3 { font-size:1.32rem; } .why p{ color:var(--muted); font-size:.96rem; margin-top:.5rem; }

/* ---------- seasonal spotlight (cinematic split) ---------- */
.spotlight { position:relative; border-radius:var(--radius-xl); overflow:hidden; color:#fff; min-height:480px; display:flex; align-items:center; box-shadow:var(--shadow-lg); }
.spotlight-wide { min-height:520px; }
.spotlight-wide .spot-body { max-width:680px; margin-left:auto; margin-right:clamp(1rem,8vw,5rem); }
.spotlight-wide .scrim-l { background:linear-gradient(105deg, rgba(13,32,46,.05) 0%, rgba(13,32,46,.35) 40%, rgba(13,32,46,.78) 100%); }
.spotlight .spot-body { position:relative; z-index:2; padding:clamp(2rem,5vw,4rem); max-width:620px; }
.spotlight h2 { color:#fff; font-size:clamp(2.2rem,4.5vw,3.4rem); margin-top:1rem; }
.spotlight p { color:rgba(255,255,255,.9); font-size:1.12rem; margin-top:1rem; }
.spot-list { display:flex; flex-wrap:wrap; gap:.7rem; margin-top:1.6rem; }
.spot-list span { background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.25); border-radius:var(--radius-pill); padding:.4rem .9rem; font-size:.86rem; font-weight:500; }

/* ---------- hidden gems (offset editorial list) ---------- */
.gems { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.gems-stagger .gem:nth-child(2) { transform:translateY(1.8rem); }
.gems-stagger .gem:nth-child(2):hover { transform:translateY(calc(1.8rem - 5px)); }
.gems-stagger .gem:nth-child(3) { transform:translateY(.9rem); }
.gems-stagger .gem:nth-child(3):hover { transform:translateY(calc(.9rem - 5px)); }
.gem { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; display:flex; flex-direction:column; transition:transform .4s var(--ease), box-shadow .4s var(--ease); }
.gem:hover { transform:translateY(-5px); box-shadow:var(--shadow); }
.gem .gem-top { height:200px; position:relative; color:#fff; display:flex; align-items:flex-end; }
.gem .gem-top .tag { position:relative; z-index:2; margin:1.1rem; background:rgba(20,40,55,.55); backdrop-filter:blur(4px); border:1px solid rgba(255,255,255,.2); border-radius:var(--radius-pill); padding:.3rem .8rem; font-size:.74rem; font-weight:600; letter-spacing:.08em; }
.gem .gem-body { padding:1.5rem; flex:1; display:flex; flex-direction:column; }
.gem .coord { margin-bottom:.5rem; }
.gem h3 { font-size:1.4rem; } .gem p{ color:var(--muted); font-size:.95rem; margin-top:.5rem; flex:1; }
.gem .gem-foot { margin-top:1rem; font-weight:600; font-size:.86rem; color:var(--ocean-deep); display:inline-flex; align-items:center; gap:.4rem; }
.gem .gem-foot svg{ width:14px;height:14px; }

/* ---------- travel tips block ---------- */
.tips-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1.3rem; }
.tip { display:grid; grid-template-columns:auto 1fr; gap:1.3rem; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:1.7rem; align-items:start; }
.tip .ti { width:48px;height:48px;border-radius:12px; background:var(--forest-tint); color:var(--forest-deep); display:grid;place-items:center; flex:none; }
.tip .ti svg{ width:23px;height:23px; }
.tip h3 { font-size:1.28rem; } .tip p{ color:var(--muted); font-size:.96rem; margin-top:.4rem; }

/* ---------- testimonials ---------- */
.tmls { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.tml { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:1.9rem; display:flex; flex-direction:column; position:relative; }
.tml .mark { font-family:var(--display); font-size:3.5rem; line-height:.6; color:var(--sand-deep); height:1.6rem; }
.tml blockquote { font-family:var(--display); font-style:italic; font-size:1.28rem; line-height:1.4; color:var(--ink); flex:1; margin-top:.5rem; }
.tml .who { display:flex; align-items:center; gap:.8rem; margin-top:1.5rem; }
.tml .who i { width:42px;height:42px;border-radius:50%; flex:none; display:grid;place-items:center; color:#fff; font-family:var(--display); font-weight:700; font-size:1.1rem; }
.tml .who .nm { font-weight:600; font-size:.94rem; } .tml .who .loc{ color:var(--muted-2); font-size:.82rem; }

/* ---------- FAQ ---------- */
.faq { max-width:860px; margin-inline:auto; }
.faq-item { border-bottom:1px solid var(--line); }
.faq-q { width:100%; display:flex; align-items:center; justify-content:space-between; gap:1rem; text-align:left; padding:1.5rem 0; font-family:var(--display); font-weight:600; font-size:1.4rem; color:var(--ink); }
.faq-q .ic { width:30px;height:30px;border-radius:50%; flex:none; border:1.5px solid var(--sand-deep); color:var(--ocean); display:grid;place-items:center; position:relative; transition:.35s var(--ease); }
.faq-q .ic::before,.faq-q .ic::after { content:""; position:absolute; background:currentColor; border-radius:2px; }
.faq-q .ic::before{ width:12px;height:2px; } .faq-q .ic::after{ width:2px;height:12px; transition:transform .35s var(--ease); }
.faq-item.open .faq-q .ic { background:var(--ocean); border-color:var(--ocean); color:#fff; }
.faq-item.open .faq-q .ic::after { transform:scaleY(0); }
.faq-a { overflow:hidden; max-height:0; transition:max-height .45s var(--ease); }
.faq-a-inner { padding:0 0 1.5rem; color:var(--muted); font-size:1.06rem; max-width:74ch; }

/* ---------- destination page sections ---------- */
.dest-quickfacts { display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; margin-top:-3.5rem; position:relative; z-index:5; }
.qf { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:1.4rem 1.5rem; box-shadow:var(--shadow); }
.qf .k { font-size:.72rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--muted-2); }
.qf .v { font-family:var(--display); font-size:1.5rem; font-weight:600; color:var(--ink); margin-top:.3rem; line-height:1.1; }
.qf .s { font-size:.86rem; color:var(--muted); margin-top:.2rem; }

.season-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
.season { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:1.4rem; border-top:3px solid var(--line); }
.season.best { border-top-color:var(--forest); }
.season.good { border-top-color:var(--ocean); }
.season.mixed { border-top-color:var(--sun); }
.season h4 { font-family:var(--body); font-weight:700; font-size:1.05rem; display:flex; align-items:center; justify-content:space-between; }
.season .badge { font-size:.68rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:.18rem .5rem; border-radius:var(--radius-pill); }
.season.best .badge{ background:var(--forest-tint); color:var(--forest-deep); }
.season.good .badge{ background:var(--ocean-tint); color:var(--ocean-deep); }
.season.mixed .badge{ background:var(--sun-soft); color:#9a5e22; }
.season p { color:var(--muted); font-size:.9rem; margin-top:.6rem; }

.mustsee { display:grid; grid-template-columns:repeat(2,1fr); gap:1.3rem; }
.ms { display:grid; grid-template-columns:130px 1fr; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; transition:transform .4s var(--ease), box-shadow .4s var(--ease); }
.ms:hover { transform:translateY(-4px); box-shadow:var(--shadow); }
.ms .ms-img { position:relative; }
.ms .ms-body { padding:1.4rem 1.5rem; }
.ms .ms-num { font-family:var(--display); font-size:.9rem; font-weight:700; color:var(--ocean); }
.ms h3 { font-size:1.3rem; margin-top:.2rem; } .ms p{ color:var(--muted); font-size:.92rem; margin-top:.4rem; }

/* meters (difficulty / accessibility / budget) */
.meters { display:grid; gap:1.3rem; }
.meter .ml { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:.5rem; }
.meter .ml .name { font-weight:600; } .meter .ml .val{ font-size:.88rem; color:var(--muted); }
.meter .track { height:9px; background:var(--line); border-radius:5px; overflow:hidden; }
.meter .fill { height:100%; border-radius:5px; background:linear-gradient(90deg,var(--forest),var(--ocean)); }

.budget-tiers { display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.tier { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:1.7rem; }
.tier.feature { border-color:var(--ocean); box-shadow:0 0 0 1px var(--ocean); }
.tier .tier-k { font-size:.74rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--ocean); }
.tier .tier-v { font-family:var(--display); font-size:2rem; font-weight:600; color:var(--ink); margin:.3rem 0; }
.tier .tier-v span{ font-size:.9rem; color:var(--muted); font-family:var(--body); }
.tier ul { margin-top:1rem; display:grid; gap:.55rem; }
.tier ul li { position:relative; padding-left:1.5rem; font-size:.92rem; color:var(--ink-soft); }
.tier ul li::before { content:""; position:absolute; left:0; top:.5em; width:8px;height:8px;border-radius:50%; background:var(--forest); }

/* related destinations */
.related { display:grid; grid-template-columns:repeat(3,1fr); gap:1.3rem; }
.rel-card { position:relative; border-radius:var(--radius-lg); overflow:hidden; min-height:200px; display:flex; align-items:flex-end; color:#fff; transition:transform .4s var(--ease), box-shadow .4s var(--ease); }
.rel-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.rel-card .rc-body { position:relative; z-index:2; padding:1.4rem; }
.rel-card h4 { color:#fff; font-size:1.3rem; } .rel-card .coord{ color:rgba(255,255,255,.8); margin-top:.3rem; }

/* ---------- blog ---------- */
.blog-feature { display:grid; grid-template-columns:1.15fr 1fr; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-xl); overflow:hidden; }
.blog-feature .bf-img { position:relative; min-height:360px; }
.blog-feature .bf-body { padding:clamp(1.8rem,4vw,3.2rem); display:flex; flex-direction:column; justify-content:center; }
.blog-feature h2 { font-size:clamp(1.9rem,3.2vw,2.7rem); margin-top:.6rem; }
.blog-feature p { color:var(--muted); margin-top:1rem; font-size:1.05rem; }
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.post { display:flex; flex-direction:column; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; transition:transform .4s var(--ease), box-shadow .4s var(--ease); }
.post:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.post .post-img { height:200px; position:relative; }
.post .post-body { padding:1.5rem; display:flex; flex-direction:column; flex:1; }
.post .cat { font-size:.72rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--ocean); }
.post h3 { font-size:1.4rem; margin-top:.5rem; line-height:1.12; }
.post p { color:var(--muted); font-size:.94rem; margin-top:.5rem; flex:1; }
.post .meta { margin-top:1.1rem; font-size:.82rem; color:var(--muted-2); display:flex; gap:.6rem; align-items:center; }
.post .meta .dot{ width:3px;height:3px;border-radius:50%; background:var(--muted-2); }

/* ---------- forms ---------- */
.form-card { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-xl); padding:clamp(1.7rem,4vw,2.8rem); box-shadow:var(--shadow); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; }
.field-group { margin-bottom:1.15rem; display:flex; flex-direction:column; }
.field-group label { font-weight:600; font-size:.9rem; margin-bottom:.45rem; } .field-group label .req{ color:var(--danger); }
.field-group input,.field-group select,.field-group textarea { font:inherit; font-size:1rem; padding:.85rem 1rem; border:1.5px solid var(--line); border-radius:10px; background:var(--paper); color:var(--ink); transition:border-color .2s, box-shadow .2s, background .2s; width:100%; }
.field-group textarea { resize:vertical; min-height:150px; }
.field-group select { appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2366726f' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 1rem center; padding-right:2.6rem; }
.field-group input:focus,.field-group select:focus,.field-group textarea:focus { outline:none; border-color:var(--ocean); background:#fff; box-shadow:0 0 0 4px rgba(29,78,111,.1); }
.field-group .err-msg { color:var(--danger); font-size:.82rem; margin-top:.4rem; display:none; }
.field-group.invalid input,.field-group.invalid select,.field-group.invalid textarea { border-color:var(--danger); }
.field-group.invalid .err-msg { display:block; }
.form-success { display:none; align-items:center; gap:1rem; background:var(--forest-tint); border:1px solid rgba(53,97,69,.3); border-radius:var(--radius); padding:1.2rem 1.4rem; margin-bottom:1.5rem; }
.form-success.show { display:flex; animation:pop .4s var(--ease); }
.form-success .ic { width:44px;height:44px;border-radius:50%; background:var(--forest); color:#fff; display:grid;place-items:center; flex:none; }
.form-success strong{ display:block; color:var(--forest-deep); } .form-success span{ font-size:.92rem; color:var(--ink-soft); }
@keyframes pop{ from{opacity:0;transform:scale(.96) translateY(6px);} to{opacity:1;transform:none;} }
.contact-grid { display:grid; grid-template-columns:1fr 1.1fr; gap:var(--s-6); align-items:start; }
.contact-info { display:grid; gap:1.2rem; }
.contact-line { display:flex; gap:1rem; align-items:flex-start; }
.contact-line .ci { width:48px;height:48px;border-radius:12px; background:var(--ocean-tint); color:var(--ocean-deep); display:grid;place-items:center; flex:none; }
.contact-line .ci svg{ width:22px;height:22px; }
.contact-line h4{ font-size:1.08rem; } .contact-line p,.contact-line a{ color:var(--muted); font-size:.95rem; margin-top:.15rem; }
.contact-line a:hover{ color:var(--ocean-deep); }

/* sidebar cards */
.side-card { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:1.7rem; }
.side-card.feature { position:relative; color:#fff; border:none; overflow:hidden; }
.side-card.feature > .scene{ z-index:0; } .side-card.feature > .scrim{ z-index:1; }
.side-card.feature > *:not(.scene):not(.scrim){ position:relative; z-index:2; }
.side-card.feature .scrim, .cta-band .scrim { background:linear-gradient(180deg, rgba(13,28,38,.62) 0%, rgba(13,28,38,.5) 40%, rgba(13,28,38,.72) 100%); }
.side-card h3 { font-size:1.3rem; } .side-card.feature h3{ color:#fff; }
.side-card p { color:var(--muted); font-size:.94rem; margin-top:.5rem; } .side-card.feature p{ color:rgba(255,255,255,.85); }
.side-links { margin-top:.5rem; }
.side-links a { display:flex; align-items:center; justify-content:space-between; padding:.7rem 0; border-bottom:1px solid var(--line-soft); font-weight:500; font-size:.96rem; transition:color .2s, padding .2s; }
.side-links a:last-child{ border-bottom:none; }
.side-links a:hover { color:var(--ocean-deep); padding-left:.3rem; }
.side-links a svg{ width:15px;height:15px; opacity:.5; }

/* generic CTA band */
.cta-band { position:relative; border-radius:var(--radius-xl); overflow:hidden; color:#fff; padding:clamp(2.4rem,5vw,4rem); text-align:center; box-shadow:var(--shadow-lg); }
.cta-band .cta-body { position:relative; z-index:2; }
.cta-band h2 { color:#fff; font-size:clamp(2rem,4vw,3rem); max-width:20ch; margin-inline:auto; }
.cta-band p { color:rgba(255,255,255,.88); max-width:46ch; margin:1rem auto 0; }
.cta-band .btn-row { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-top:2rem; }

/* feature split (destination editorial blocks) */
.feat-wrap { display:grid; gap:var(--s-7); }
.feat-split { display:grid; grid-template-columns:1fr 1fr; gap:var(--s-6); align-items:center; }
.feat-split .feat-media { position:relative; min-height:340px; border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow); }
.feat-split .feat-body h2 { font-size:clamp(1.8rem,3.6vw,2.6rem); margin-top:.8rem; }
.feat-split .feat-body p { color:var(--muted); margin-top:1rem; font-size:1.06rem; }
.feat-split .feat-body .ticks { margin-top:1.3rem; display:grid; gap:.7rem; }

/* tag row */
.tagrow { display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1.2rem; align-items:center; }
.tagrow .lbl { font-size:.74rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--muted-2); }
.tagrow a { font-size:.88rem; font-weight:500; color:var(--ocean-deep); padding:.35rem .85rem; background:var(--ocean-tint); border-radius:var(--radius-pill); transition:.2s; }
.tagrow a:hover { background:var(--ocean); color:#fff; }
