/* Tips Tennis — "grass court" design system. Wimbledon green + purple + tennis-ball pop. Distinct. */
:root{
  --bg:#f4f7f0; --bg-2:#e7efdf; --surface:#ffffff; --surface-2:#f1f5ec;
  --ink:#16241a; --ink-2:#42513f; --muted:#869180;
  --green:#0a5c36; --green-d:#084a2b; --green-deep:#073d24; --green-wash:#e3f0e6;
  --purple:#4f2d7f; --purple-d:#3b1f63; --purple-wash:#ede7f6;
  --ball:#d6e84a; --ball-d:#b7c92f;
  --line:#dfe7d6; --line-2:#cdd9bf;
  --display:'Big Shoulders Display',system-ui,sans-serif;
  --sans:'Mulish',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --wrap:1140px; --radius:7px;
  --sh-1:0 1px 2px rgba(7,61,36,.06); --sh-2:0 18px 40px -22px rgba(7,61,36,.35);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:88px}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.66;font-weight:400;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--display);font-weight:800;line-height:1.0;letter-spacing:.005em;color:var(--ink);text-transform:uppercase}
a{color:var(--purple);text-decoration:none}a:hover{color:var(--purple-d)}
.prose a{text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--ball-d)}
img{max-width:100%;display:block}
.container{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 28px}
.skip{position:absolute;left:-999px}.skip:focus{left:8px;top:8px;background:var(--purple);color:#fff;padding:8px 14px;z-index:50;border-radius:6px}
.ic{width:1.05em;height:1.05em;vertical-align:-.16em;flex:none}
::selection{background:var(--ball)}

/* ── Header: sports-broadcast top bar (brand left · nav left of it · CTA right edge) ── */
.site-header{position:sticky;top:0;z-index:30;background:var(--green-deep);color:#eaf3ec;border-bottom:3px solid var(--ball)}
.site-header__bar{display:flex;align-items:center;gap:22px;width:100%;max-width:var(--wrap);margin:0 auto;padding:11px 28px}
.brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:#fff;flex:none}
.brand__mark{display:grid;place-items:center;width:34px;height:34px;border-radius:9px;background:var(--ball);color:var(--green-deep)}
.brand__mark .ic{width:19px;height:19px}
.brand__name{font-family:var(--display);font-weight:800;font-size:25px;text-transform:uppercase;letter-spacing:.01em;color:#fff}
.brand__live{font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.12em;color:var(--green-deep);background:var(--ball);padding:2px 7px;border-radius:4px;position:relative;padding-left:18px}
.brand__live::before{content:"";position:absolute;left:7px;top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:var(--green-deep);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.mainnav{display:flex;gap:4px;align-items:center}
.mainnav__link{font-family:var(--display);font-weight:600;font-size:15px;text-transform:uppercase;letter-spacing:.04em;text-decoration:none;color:#bcd3c2;padding:7px 12px;border-radius:6px}
.mainnav__link:hover{color:#fff;background:rgba(255,255,255,.08)}
.mainnav__link.is-active{color:var(--green-deep);background:var(--ball)}
.header-cta{margin-left:auto;flex:none;display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-weight:700;font-size:15px;text-transform:uppercase;letter-spacing:.04em;color:var(--green-deep);background:var(--ball);padding:9px 18px;border-radius:99px;text-decoration:none;border:2px solid var(--ball);transition:transform .12s,background .15s}
.header-cta:hover{transform:translateY(-1px);background:#fff;border-color:#fff;color:var(--green-deep)}
.header-cta .ic{width:16px;height:16px}
.navtoggle{display:none;margin-left:auto;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}.navtoggle span{width:25px;height:2.5px;background:#fff;border-radius:2px}
.mobilenav{display:none;flex-direction:column;padding:8px 28px 18px;background:var(--green-d)}
.mobilenav a{padding:12px 0;border-bottom:1px solid rgba(255,255,255,.12);text-decoration:none;color:#eaf3ec;font-family:var(--display);font-weight:600;font-size:18px;text-transform:uppercase}
.mobilenav__cta{display:inline-flex;align-items:center;gap:8px;margin-top:14px;border-bottom:0!important;color:var(--green-deep)!important;background:var(--ball);justify-content:center;border-radius:99px;padding:13px 18px!important;font-weight:700}
.site-header.is-open .mobilenav{display:flex}

/* ── Breadcrumb: ticker strip ── */
.crumbs{background:var(--green-wash);border-bottom:1px solid var(--line-2)}
.crumbs__inner{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 28px}
.crumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:9px;margin:0;padding:9px 0;font-family:var(--display);font-weight:700;font-size:12px;color:var(--ink-2);text-transform:uppercase;letter-spacing:.06em}
.crumbs li::after{content:"›";margin-left:9px;color:var(--line-2)}.crumbs li:last-child::after{content:""}
.crumbs a{color:var(--green);text-decoration:none}.crumbs a:hover{color:var(--purple)}.crumbs [aria-current]{color:var(--ink)}

/* ── Article: full-bleed head band + 2-column (content + sticky right quick-facts) ── */
.page{padding:0 0 72px}
.page__head{background:var(--surface);border-bottom:3px solid var(--ball);padding:38px 0 30px;margin-bottom:34px}
.page__head-inner{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 28px}
.page__eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--green);margin:0 0 12px}
.page__eyebrow .ic{color:var(--ball-d);width:16px;height:16px}
.page__head h1{font-size:clamp(36px,5.4vw,64px);margin:0 0 14px;line-height:.95;max-width:20ch}
.page__intro{font-size:19px;color:var(--ink-2);line-height:1.5;max-width:70ch}.page__intro p{margin:.4em 0}
.page__meta{margin:16px 0 0;font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.page__grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:46px;align-items:start;width:100%;max-width:var(--wrap);margin:0 auto;padding:0 28px}
.page__body{min-width:0;max-width:760px}
.block{margin:34px 0}

/* ── Article aside: sticky QUICK FACTS / tickets card ── */
.page__aside{position:sticky;top:88px}
.quickfacts{background:var(--green-deep);color:#eaf3ec;border-radius:10px;overflow:hidden;box-shadow:var(--sh-2);border:1px solid var(--green-deep)}
.quickfacts__kick{display:flex;align-items:center;gap:8px;margin:0;padding:16px 20px;font-family:var(--display);font-weight:800;font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:var(--green-deep);background:var(--ball)}
.quickfacts__kick .ic{width:17px;height:17px}
.quickfacts__list{margin:0;padding:6px 20px}
.quickfacts__row{display:flex;justify-content:space-between;align-items:baseline;gap:14px;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.quickfacts__row:last-child{border-bottom:0}
.quickfacts__row dt{font-family:var(--display);font-weight:600;font-size:12.5px;letter-spacing:.04em;text-transform:uppercase;color:#9fc0a8}
.quickfacts__row dd{margin:0;font-family:var(--display);font-weight:800;font-size:17px;color:#fff;text-align:right;text-transform:uppercase;line-height:1.1}
.quickfacts__cta{padding:16px 20px 20px;border-top:1px solid rgba(255,255,255,.14)}
.quickfacts__ctalabel{margin:0 0 9px;font-family:var(--display);font-weight:700;font-size:13px;letter-spacing:.05em;text-transform:uppercase;color:var(--ball)}
.btn--block{width:100%;justify-content:center}
.quickfacts .btn--primary{background:var(--ball);color:var(--green-deep)}.quickfacts .btn--primary:hover{background:#fff;color:var(--green-deep)}
.block h2{font-size:clamp(25px,3.4vw,36px);margin:0 0 14px;padding-left:16px;border-left:5px solid var(--ball)}
.block h3{font-size:21px;margin:0 0 10px}
.prose p{margin:0 0 16px;color:var(--ink-2)}.prose strong{color:var(--ink);font-weight:700}
.prose ul,.prose ol{padding-left:22px}.prose li{margin:7px 0;color:var(--ink-2)}
.rich-list{padding-left:0;list-style:none;display:grid;gap:8px}
.rich-list li{position:relative;padding:12px 14px 12px 44px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);color:var(--ink-2)}
.rich-list li::before{content:"";position:absolute;left:15px;top:50%;transform:translateY(-50%);width:16px;height:16px;border-radius:50%;background:var(--ball);box-shadow:inset 0 0 0 1.5px var(--ball-d)}

/* ── Verdict ── */
.verdict{display:flex;gap:22px;align-items:center;background:var(--green-deep);color:#eaf3ec;border-radius:var(--radius);padding:26px;margin:30px 0;box-shadow:var(--sh-2)}
.verdict__score{flex:none;width:96px;height:96px;border-radius:50%;display:grid;place-items:center;text-align:center;background:conic-gradient(var(--ball) var(--p),rgba(255,255,255,.14) 0);position:relative}
.verdict__score::after{content:"";position:absolute;inset:8px;border-radius:50%;background:var(--green-deep)}
.verdict__score-num{position:relative;z-index:1;font-family:var(--display);font-weight:800;font-size:36px;color:#fff}
.verdict__score-max{position:relative;z-index:1;display:block;font-family:var(--display);font-size:11px;text-transform:uppercase;color:#9fc0a8}
.verdict__label{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.05em;color:var(--ball)}
.verdict__body p{margin:0 0 12px;color:#cfe0d3}
.stars{display:inline-flex;gap:1px}.star{width:16px;height:16px;color:rgba(255,255,255,.25)}.star.on,.star.half{color:var(--ball)}.star .ic{width:16px;height:16px}

/* ── Pros/cons ── */
.proscons{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.proscons__col{border:1px solid var(--line-2);border-radius:var(--radius);padding:20px 22px;background:var(--surface)}
.proscons__col--pro{border-top:4px solid var(--green)}.proscons__col--con{border-top:4px solid var(--purple)}
.proscons__col h3{display:flex;align-items:center;gap:8px;font-family:var(--display);font-size:16px;text-transform:uppercase;letter-spacing:.03em;margin:0 0 12px}
.proscons__col--pro h3{color:var(--green)}.proscons__col--con h3{color:var(--purple)}
.proscons__col ul{margin:0;padding-left:18px}.proscons__col li{margin:8px 0;color:var(--ink-2);font-size:15.5px}

/* ── Table ── */
.table-wrap{overflow-x:auto;border:1px solid var(--line-2);border-radius:var(--radius)}
.cmp{width:100%;border-collapse:collapse;font-size:15px;background:var(--surface)}
.cmp th,.cmp td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--line)}
.cmp thead th{background:var(--purple);color:#fff;font-family:var(--display);font-size:14px;text-transform:uppercase;letter-spacing:.03em;font-weight:600}
.cmp .cmp__rowhead{font-weight:700;color:var(--ink);background:var(--surface-2)}
.cmp .hl{background:var(--green-wash)}.cmp td{color:var(--ink-2)}.cmp tbody tr:last-child td{border-bottom:0}
.table-note{font-size:13px;color:var(--muted);margin:9px 2px 0;font-style:italic}

/* ── Bars ── */
.bars{display:flex;flex-direction:column;gap:13px;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--radius);padding:22px}
.bar{display:grid;grid-template-columns:170px 1fr 46px;align-items:center;gap:14px}
.bar__label{font-size:14px;color:var(--ink-2)}
.bar__track{height:9px;background:var(--bg-2);border-radius:99px;overflow:hidden}
.bar__fill{height:100%;background:var(--green);border-radius:99px}
.bar__val{font-family:var(--display);font-size:14px;color:var(--green);text-align:right;font-weight:700}

/* ── Cards: sporty tiles (article grids) ── */
.block__sub{color:var(--ink-2);margin:-8px 0 18px}
.cards--grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.ucard{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line-2);border-radius:10px;padding:24px 22px 22px;text-decoration:none;color:var(--ink);box-shadow:var(--sh-1);transition:transform .15s,box-shadow .15s,border-color .15s;position:relative;overflow:hidden}
.ucard__stripe{position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--ball)}
a.ucard:hover{transform:translateY(-4px);box-shadow:var(--sh-2);border-color:var(--green)}
a.ucard:hover .ucard__stripe{background:var(--green)}
.ucard__top{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:22px;margin-bottom:10px}
.ucard__badge{font-family:var(--display);font-weight:700;font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--green-deep);background:var(--ball);padding:3px 10px;border-radius:5px}
.ucard__rating{display:flex;align-items:center;gap:7px}.ucard__rating b{font-family:var(--display);color:var(--green)}
.ucard__title{font-family:var(--display);font-size:23px;margin:2px 0 7px;text-transform:uppercase;line-height:.98}
.ucard__meta{font-family:var(--display);font-weight:600;font-size:12px;color:var(--muted);margin:0 0 8px;text-transform:uppercase;letter-spacing:.04em}
.ucard__text{font-size:15px;color:var(--ink-2);margin:0 0 14px;flex:1}
.ucard__more{font-family:var(--display);font-size:13.5px;text-transform:uppercase;letter-spacing:.03em;color:var(--green);display:inline-flex;align-items:center;gap:7px;font-weight:700}
.ucard__more .ic{transition:transform .2s}a.ucard:hover .ucard__more .ic{transform:translateX(4px)}

/* ── Callout ── */
.callout{border:1px solid var(--line-2);background:var(--surface);border-radius:var(--radius);padding:20px 22px;margin:26px 0;border-left:4px solid var(--green)}
.callout--tip{border-left-color:var(--green);background:var(--green-wash)}
.callout--warn{border-left-color:var(--ball-d);background:#f7f9e3}
.callout--info{border-left-color:var(--purple);background:var(--purple-wash)}
.callout h3{display:flex;align-items:center;gap:9px;font-family:var(--display);font-size:16px;text-transform:uppercase;letter-spacing:.03em;margin:0 0 8px}
.callout h3 .ic{color:var(--green)}.callout--info h3 .ic{color:var(--purple)}.callout--warn h3 .ic{color:var(--ball-d)}
.callout p{margin:0 0 8px;color:var(--ink-2)}.callout p:last-child{margin:0}

/* ── CTA ── */
.ctablock{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;background:var(--purple);color:#fff;border-radius:var(--radius);padding:30px 34px;margin:38px 0;position:relative;overflow:hidden}
.ctablock::after{content:"";position:absolute;right:-30px;bottom:-30px;width:150px;height:150px;border-radius:50%;background:var(--ball);opacity:.2}
.ctablock h3{color:#fff;margin:0 0 6px;font-size:28px;position:relative}
.ctablock .prose p{margin:0;color:rgba(255,255,255,.9);position:relative}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:700;font-size:16px;text-transform:uppercase;letter-spacing:.03em;text-decoration:none;padding:13px 26px;border-radius:6px;cursor:pointer;border:2px solid transparent;white-space:nowrap;transition:transform .12s,background .15s}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:var(--green);color:#fff}.btn--primary:hover{background:var(--green-d);color:#fff}
.ctablock .btn--primary{background:var(--ball);color:var(--purple-d)}.ctablock .btn--primary:hover{background:#fff}
.btn--lg{padding:15px 30px;font-size:17px}
.btn--ghost{background:transparent;border-color:var(--line-2);color:var(--ink)}.btn--ghost:hover{border-color:var(--green);color:var(--green)}

/* ── Steps ── */
.steps{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.step{display:flex;gap:16px;padding:16px 18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius)}
.step__n{flex:none;width:40px;height:40px;border-radius:50%;background:var(--green);color:var(--ball);display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:18px}
.step h4{margin:5px 0 4px;font-size:19px}.step p{margin:0;color:var(--ink-2);font-size:15.5px}

/* ── FAQ: bold accordion ── */
.faq__list{display:grid;gap:10px}
.faq__item{border:2px solid var(--line-2);border-radius:10px;background:var(--surface);overflow:hidden;transition:border-color .15s}
.faq__item[open]{border-color:var(--green)}
.faq__item summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:18px 22px;font-family:var(--display);font-weight:700;font-size:20px;text-transform:uppercase;line-height:1.05}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary .ic{flex:none;color:var(--green-deep);background:var(--ball);width:28px;height:28px;padding:5px;border-radius:50%;transition:transform .2s}.faq__item[open] summary .ic{transform:rotate(90deg)}
.faq__item .prose{padding:2px 22px 18px;color:var(--ink-2)}

/* ── Related ── */
.related__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:12px}
.related__item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--radius);text-decoration:none;color:var(--ink);font-size:15px;font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.01em}
.related__item:hover{border-color:var(--green);color:var(--green)}.related__item .ic{color:var(--ball-d)}

/* ── Home: SPLIT hero (headline left / scoreboard right) ── */
.hero{position:relative;overflow:hidden;background:var(--green-deep);color:#eaf3ec;border-bottom:5px solid var(--ball)}
.hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 2px,transparent 2px);background-size:100% 44px;opacity:.6}
.hero__grid{position:relative;z-index:1;display:grid;grid-template-columns:1.25fr .85fr;gap:46px;align-items:center;max-width:var(--wrap);margin:0 auto;padding:62px 28px 58px}
.hero__kicker{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:700;font-size:14px;letter-spacing:.1em;text-transform:uppercase;color:var(--green-deep);background:var(--ball);padding:6px 14px;border-radius:5px;margin:0 0 22px}
.hero__title{font-size:clamp(44px,6.6vw,92px);margin:0 0 18px;color:#fff;line-height:.9;letter-spacing:.005em}
.hero__lead{font-size:20px;color:#bcd3c2;max-width:52ch;margin:0 0 28px}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap}
.hero .btn--ghost{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.25);color:#eaf3ec}.hero .btn--ghost:hover{border-color:var(--ball);color:var(--ball)}

/* Scoreboard panel */
.scoreboard{background:#06301d;border:1px solid rgba(214,232,74,.35);border-radius:14px;padding:6px;box-shadow:0 24px 60px -30px rgba(0,0,0,.7)}
.scoreboard__top{display:flex;align-items:center;gap:9px;padding:13px 16px 11px}
.scoreboard__dot{width:9px;height:9px;border-radius:50%;background:var(--ball);box-shadow:0 0 0 4px rgba(214,232,74,.18);animation:pulse 1.6s infinite}
.scoreboard__head{font-family:var(--display);font-weight:700;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:#9fc0a8}
.scoreboard__grid{display:grid;grid-template-columns:1fr 1fr;gap:3px;background:rgba(214,232,74,.18);border-radius:8px;overflow:hidden}
.scoreboard__cell{background:#06301d;padding:20px 18px;text-align:center}
.scoreboard__num{display:block;font-family:var(--display);font-weight:800;font-size:48px;line-height:1;color:var(--ball)}
.scoreboard__lbl{display:block;margin-top:7px;font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:#9fc0a8}
.scoreboard__cta{display:flex;align-items:center;justify-content:center;gap:9px;margin:6px 4px 4px;padding:14px;font-family:var(--display);font-weight:700;font-size:15px;text-transform:uppercase;letter-spacing:.03em;color:var(--green-deep);background:var(--ball);border-radius:8px;text-decoration:none;transition:background .15s}
.scoreboard__cta:hover{background:#fff;color:var(--green-deep)}.scoreboard__cta .ic{width:17px;height:17px}

/* ── Home: HORIZONTAL SCROLL RAILS ── */
.rail{max-width:var(--wrap);margin:0 auto;padding:42px 0 8px}
.rail__head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;padding:0 28px;margin-bottom:18px}
.rail__kicker{margin:0 0 4px;font-family:var(--display);font-weight:700;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--purple)}
.rail__title{font-size:clamp(28px,4vw,44px);margin:0;padding-left:14px;border-left:6px solid var(--ball);line-height:.95}
.rail__all{flex:none;font-family:var(--display);font-weight:700;font-size:14px;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;color:var(--green);display:inline-flex;align-items:center;gap:6px}
.rail__all:hover{color:var(--purple)}
.rail__track{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:4px 28px 22px;scrollbar-width:thin;scrollbar-color:var(--line-2) transparent}
.rail__track::-webkit-scrollbar{height:8px}.rail__track::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:99px}.rail__track::-webkit-scrollbar-track{background:transparent}
.rail__cell{flex:0 0 290px;scroll-snap-align:start}
.railcard{display:flex;flex-direction:column;height:100%;background:var(--surface);border:1px solid var(--line-2);border-radius:12px;padding:22px;text-decoration:none;color:var(--ink);box-shadow:var(--sh-1);position:relative;overflow:hidden;transition:transform .15s,box-shadow .15s,border-color .15s}
.railcard::before{content:"";position:absolute;left:0;top:0;right:0;height:6px;background:var(--green)}
.railcard--accent::before{background:var(--ball)}
.railcard:hover{transform:translateY(-5px);box-shadow:var(--sh-2);border-color:var(--green)}
.railcard__tag{align-self:flex-start;margin:6px 0 14px;font-family:var(--display);font-weight:700;font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--green-deep);background:var(--green-wash);padding:4px 11px;border-radius:5px}
.railcard--accent .railcard__tag{background:var(--ball)}
.railcard__title{font-family:var(--display);font-weight:800;font-size:25px;text-transform:uppercase;line-height:.96;margin-bottom:9px}
.railcard__text{font-size:15px;color:var(--ink-2);margin-bottom:16px;flex:1}
.railcard__go{font-family:var(--display);font-weight:700;font-size:13.5px;letter-spacing:.03em;text-transform:uppercase;color:var(--green);display:inline-flex;align-items:center;gap:7px}
.railcard__go .ic{transition:transform .2s}.railcard:hover .railcard__go .ic{transform:translateX(4px)}

/* ── Home: end CTA band ── */
.endcta{background:var(--purple);color:#fff;margin-top:34px;position:relative;overflow:hidden}
.endcta::after{content:"";position:absolute;right:-40px;bottom:-40px;width:180px;height:180px;border-radius:50%;background:var(--ball);opacity:.18}
.endcta__inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;max-width:var(--wrap);margin:0 auto;padding:40px 28px}
.endcta__kick{display:inline-flex;align-items:center;gap:8px;margin:0 0 8px;font-family:var(--display);font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--ball)}
.endcta__title{color:#fff;font-size:clamp(30px,4vw,44px);margin:0 0 6px;line-height:.95}
.endcta__text{margin:0;color:rgba(255,255,255,.9);font-size:17px}
.endcta .btn--primary{background:var(--ball);color:var(--purple-d)}.endcta .btn--primary:hover{background:#fff;color:var(--purple-d)}
.home-sec .cards{max-width:var(--wrap);margin:0 auto;padding:0 28px}
.home .ctablock{max-width:var(--wrap);margin-inline:auto}

/* ── Footer: bold dark 3-column ── */
.site-footer{background:var(--green-deep);color:#9fc0a8;margin-top:0;padding:54px 0 30px;border-top:5px solid var(--ball)}
.site-footer__top{display:grid;grid-template-columns:1.4fr 2fr;gap:48px;max-width:var(--wrap);margin:0 auto;padding:0 28px}
.site-footer__lead .brand,.site-footer__lead .brand__name{color:#fff}.site-footer__lead .brand__mark{background:var(--ball);color:var(--green-deep)}
.site-footer__about{font-size:14px;color:#83a589;margin:16px 0 18px;max-width:40ch;line-height:1.6}
.footer-cta{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:700;font-size:14.5px;text-transform:uppercase;letter-spacing:.03em;color:var(--green-deep);background:var(--ball);padding:11px 18px;border-radius:99px;text-decoration:none;transition:background .15s}
.footer-cta:hover{background:#fff;color:var(--green-deep)}.footer-cta .ic{width:16px;height:16px}
.site-footer__cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:28px}
.site-footer__col h4{color:var(--ball);font-family:var(--display);font-weight:800;font-size:14px;letter-spacing:.06em;text-transform:uppercase;margin:0 0 14px;padding-bottom:9px;border-bottom:2px solid rgba(255,255,255,.14)}
.site-footer__col ul{list-style:none;margin:0;padding:0}.site-footer__col li{margin:9px 0}
.site-footer__col a{color:#9fc0a8;text-decoration:none;font-size:14.5px}.site-footer__col a:hover{color:#fff}
.site-footer__bottom{margin:40px auto 0;padding:18px 28px 0;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;max-width:var(--wrap)}
.site-footer__disc{font-size:12.5px;color:#6f8f76;max-width:64ch;margin:0;line-height:1.6}
.site-footer__copy{font-family:var(--display);font-weight:600;font-size:12.5px;color:#6f8f76;margin:0;text-transform:uppercase;letter-spacing:.03em}

/* ── CWV ── */
.site-footer{content-visibility:auto;contain-intrinsic-size:0 440px}
.block.related,.block.faq{content-visibility:auto;contain-intrinsic-size:0 360px}

/* ── Responsive ── */
@media(max-width:980px){
  .mainnav,.header-cta{display:none}
  .navtoggle{display:flex}
  .page__grid{grid-template-columns:1fr;gap:30px}
  .page__aside{position:static;width:100%;max-width:760px}
  .quickfacts{max-width:none}
}
@media(max-width:900px){
  .hero__grid{grid-template-columns:1fr;gap:34px;padding:48px 28px 44px}
  .hero__title{font-size:clamp(40px,11vw,68px)}
  .site-footer__top{grid-template-columns:1fr;gap:30px}
}
@media(max-width:760px){
  .proscons{grid-template-columns:1fr}
  .endcta__inner{flex-direction:column;align-items:flex-start}
}
@media(max-width:560px){.site-footer__cols{grid-template-columns:1fr 1fr}}
@media(max-width:520px){
  body{font-size:16px}
  .verdict{flex-direction:column;text-align:center}
  .bar{grid-template-columns:120px 1fr 44px}
  .ctablock{flex-direction:column;align-items:flex-start}
  .scoreboard__num{font-size:40px}
  .rail__cell{flex-basis:80vw;max-width:300px}
  .rail__head{flex-wrap:wrap}
  .page__head h1{font-size:clamp(32px,9vw,48px)}
}
@media(max-width:380px){.site-footer__cols{grid-template-columns:1fr}}

/* ===== Interactions : hovers + transitions (couche additionnelle commune) ===== */
a, .btn, button, summary,
[class*="card"], [class*="tile"], [class*="panel"], [class*="story"], [class*="sheet"], [class*="row"], [class*="tab"],
.ic, .navtoggle span {
  transition: color .18s ease, background-color .18s ease, border-color .18s ease,
              box-shadow .22s ease, transform .2s ease, opacity .18s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }
a[class*="card"]:hover, a[class*="tile"]:hover, a[class*="story"]:hover,
a[class*="sheet"]:hover, a[class*="panel"]:hover { transform: translateY(-3px); }
:focus-visible { outline: 2px solid currentColor; outline-offset: 3px; }
@media (prefers-reduced-motion: reduce) { * { transition: none !important; } }
