/* Lukki Casino App Guide - Sweet Elegance */
/* Palette derived from Lukki favicon: royal blue + gold clover, plus deep blue-black */

:root {
  --c-canvas: #ffffff;
  --c-canvas-2: #f3f5fb;
  --c-ink: #0c1530;
  --c-ink-soft: #525c7a;
  --c-accent: #f5c842;          /* lukki gold */
  --c-accent-deep: #d9a91b;
  --c-brand: #1f54a8;           /* lukki royal blue */
  --c-brand-deep: #0e3070;
  --c-rule: #d8dee8;
  --c-good: #1a8a55;
  --c-bad: #c74148;
  --shadow-low: 0 2px 10px rgba(12, 21, 48, 0.06);
  --shadow-mid: 0 8px 24px rgba(12, 21, 48, 0.12);
  --shadow-glow: 0 6px 30px rgba(31, 84, 168, 0.22);
  --round: 10px;
  --round-lg: 18px;
  --round-pill: 999px;
  --gutter: 1240px;
  --type-base: "Inter", "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--type-base);
  font-size: 16px;
  line-height: 1.65;
  color: var(--c-ink);
  background: var(--c-canvas);
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--c-brand); text-decoration: none; }
a:hover { text-decoration: underline; }

.wrap { max-width: var(--gutter); margin: 0 auto; padding: 0 22px; }
.wrap-narrow { max-width: 880px; }

.block-h { font-size: clamp(1.7rem, 3vw, 2.3rem); margin: 0 0 12px; color: var(--c-ink); line-height: 1.22; letter-spacing: -0.01em; }
.block-sub { color: var(--c-ink-soft); margin: 0 0 32px; max-width: 740px; }

.vh { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

.skip-anchor { position: absolute; top: -50px; left: 10px; background: var(--c-ink); color: var(--c-accent); padding: 10px 16px; border-radius: 6px; font-weight: 700; z-index: 200; transition: top .18s; }
.skip-anchor:focus { top: 10px; outline: 3px solid var(--c-accent); }

:focus-visible { outline: 3px solid var(--c-accent); outline-offset: 3px; border-radius: 4px; }

/* CTAs (Lukki style: pill-shaped) */
.cta { display: inline-block; padding: 12px 22px; font-weight: 700; font-size: 0.95rem; cursor: pointer; border: 2px solid transparent; transition: transform .15s, background .15s, border-color .15s, color .15s; line-height: 1.1; text-align: center; text-decoration: none; }
.cta-pill { background: linear-gradient(135deg, var(--c-accent) 0%, var(--c-accent-deep) 100%); color: var(--c-ink); border-radius: var(--round-pill); border-color: var(--c-accent-deep); box-shadow: var(--shadow-glow); }
.cta-pill:hover { transform: translateY(-1px); text-decoration: none; }
.cta-pill--ghost { background: transparent; color: var(--c-brand); border-color: var(--c-brand); box-shadow: none; }
.cta-pill--ghost:hover { background: var(--c-brand); color: #fff; }
.cta-outline { background: transparent; color: var(--c-ink); border-color: var(--c-ink); border-radius: var(--round-pill); padding: 10px 20px; }
.cta-outline:hover { background: var(--c-ink); color: #fff; }
.cta-text { background: transparent; color: var(--c-brand); border: 0; padding: 12px 0; }
.cta-large { padding: 14px 30px; font-size: 1.05rem; }

/* TOPBAR */
.topbar {
  background: var(--c-canvas); border-bottom: 1px solid var(--c-rule);
  position: sticky; top: 0; z-index: 100;
}
.topbar-grid { display: flex; align-items: center; gap: 24px; padding: 14px 22px; }
.brand-mark { flex-shrink: 0; display: inline-flex; align-items: center; }
.brand-mark img { height: 42px; width: auto; }
.main-menu { flex: 1; }
.main-menu ul { display: flex; gap: 22px; list-style: none; margin: 0; padding: 0; justify-content: center; flex-wrap: wrap; }
.main-menu a { color: var(--c-ink); font-weight: 600; font-size: 0.93rem; }
.main-menu a:hover { color: var(--c-brand); text-decoration: none; }
.topbar-cta { display: flex; gap: 8px; flex-shrink: 0; }
.burger { display: none; background: none; border: 0; padding: 8px; cursor: pointer; }
.burger span { display: block; width: 26px; height: 3px; background: var(--c-ink); margin: 5px 0; transition: .2s; }

/* HERO / LEAD STAGE */
.lead-stage {
  background: radial-gradient(circle at 80% 0%, rgba(245,200,66,0.12) 0%, transparent 50%),
              linear-gradient(160deg, #0c1530 0%, #0e3070 50%, #1f54a8 100%);
  color: #fff; padding: 70px 0 80px;
}
.lead-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 50px; align-items: center; }
.lead-tag { display: inline-block; background: var(--c-accent); color: var(--c-ink); padding: 5px 12px; border-radius: var(--round-pill); font-weight: 700; font-size: 0.78rem; letter-spacing: .04em; text-transform: uppercase; margin-bottom: 18px; }
.lead-stage h1 { font-size: clamp(1.9rem, 4.2vw, 2.9rem); line-height: 1.18; margin: 0 0 18px; letter-spacing: -0.015em; }
.lead-summary { font-size: 1.02rem; color: rgba(255,255,255,0.86); margin: 0 0 22px; max-width: 580px; }
.lead-points { list-style: none; padding: 0; margin: 0 0 26px; display: grid; grid-template-columns: 1fr 1fr; gap: 10px 18px; }
.lead-points li { padding-left: 26px; position: relative; font-size: 0.94rem; color: rgba(255,255,255,0.92); }
.lead-points li::before { content: "•"; position: absolute; left: 4px; color: var(--c-accent); font-weight: 800; font-size: 1.6rem; line-height: 0.8; top: 5px; }
.lead-actions { display: flex; gap: 16px; align-items: center; flex-wrap: wrap; margin-bottom: 20px; }
.lead-actions .cta-text { color: var(--c-accent); }
.lead-fineprint { font-size: 0.78rem; color: rgba(255,255,255,0.55); margin: 0; max-width: 580px; line-height: 1.6; }

.lead-feature { display: flex; flex-direction: column; gap: 22px; align-items: center; }
.qr-stack { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; width: 100%; max-width: 460px; }
.qr-card { background: rgba(255,255,255,0.07); border: 1px solid rgba(245,200,66,0.3); border-radius: var(--round-lg); padding: 22px 18px; text-align: center; backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }
.qr-os { color: var(--c-accent); font-weight: 700; letter-spacing: .04em; text-transform: uppercase; font-size: 0.82rem; margin-bottom: 10px; }
.qr-glyph { color: var(--c-accent); margin: 8px 0 12px; }
.qr-card p { color: rgba(255,255,255,0.78); font-size: 0.84rem; margin: 0; }
.lead-rating { background: rgba(0,0,0,0.4); border: 1px solid rgba(245,200,66,0.4); padding: 12px 18px; border-radius: var(--round-pill); display: flex; gap: 12px; align-items: center; }
.lead-rating-value { font-size: 1.6rem; font-weight: 800; color: var(--c-accent); line-height: 1; }
.lead-rating-stars { letter-spacing: 2px; color: var(--c-accent); }
.lead-rating-text { font-size: 0.82rem; color: rgba(255,255,255,0.74); }

/* HIGHLIGHTS / FEATURE TILES */
.highlight-row { padding: 70px 0; }
.tile-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.feature-tile { background: var(--c-canvas-2); border-radius: var(--round-lg); padding: 28px 22px; border: 1px solid var(--c-rule); transition: transform .2s, box-shadow .2s, border-color .2s; }
.feature-tile:hover { transform: translateY(-3px); box-shadow: var(--shadow-mid); border-color: var(--c-brand); }
.tile-icon { width: 56px; height: 56px; border-radius: var(--round); background: linear-gradient(135deg, var(--c-brand) 0%, var(--c-brand-deep) 100%); color: var(--c-accent); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.feature-tile h3 { margin: 0 0 8px; font-size: 1.15rem; color: var(--c-ink); }
.feature-tile p { margin: 0; color: var(--c-ink-soft); font-size: 0.93rem; }

/* HOWTO BLOCKS */
.howto-block { padding: 70px 0; background: var(--c-canvas); }
.howto-block--alt { background: var(--c-canvas-2); }
.step-list { counter-reset: step; list-style: none; padding: 0; margin: 0 0 24px; max-width: 800px; }
.step-list li { counter-increment: step; position: relative; padding: 18px 22px 18px 70px; margin-bottom: 12px; background: #fff; border-radius: var(--round); border: 1px solid var(--c-rule); }
.howto-block--alt .step-list li { background: #fff; }
.step-list li::before { content: counter(step); position: absolute; left: 18px; top: 50%; transform: translateY(-50%); width: 36px; height: 36px; border-radius: 50%; background: linear-gradient(135deg, var(--c-accent) 0%, var(--c-accent-deep) 100%); color: var(--c-ink); display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 1.05rem; }
.step-list li strong { color: var(--c-ink); }
.callout { background: rgba(31,84,168,0.06); border-left: 4px solid var(--c-brand); padding: 14px 18px; border-radius: var(--round); color: var(--c-ink); font-size: 0.94rem; max-width: 800px; }

/* SPECS / TABLES */
.specs-block, .compat-block, .snapshot-block { padding: 70px 0; }
.compat-block { background: var(--c-canvas-2); }
.snapshot-block { background: var(--c-canvas); }
.grid-table { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.info-grid { width: 100%; border-collapse: collapse; background: #fff; border-radius: var(--round); overflow: hidden; box-shadow: var(--shadow-low); }
.info-grid th, .info-grid td { padding: 14px 16px; text-align: left; border-bottom: 1px solid var(--c-rule); }
.info-grid thead { background: linear-gradient(135deg, var(--c-brand) 0%, var(--c-brand-deep) 100%); color: #fff; }
.info-grid thead th { font-weight: 700; }
.info-grid tbody tr:hover { background: var(--c-canvas-2); }
.info-grid tbody tr:last-child td, .info-grid tbody tr:last-child th { border-bottom: 0; }
.info-grid--two th { background: var(--c-canvas-2); width: 32%; color: var(--c-ink); font-weight: 700; }

/* BONUSES */
.bonus-row { padding: 70px 0; background: var(--c-canvas-2); }
.bonus-rack { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.bonus-tile { background: #fff; border: 1px solid var(--c-rule); border-radius: var(--round-lg); padding: 24px; display: flex; flex-direction: column; }
.bonus-tile--star { border: 2px solid var(--c-accent); background: linear-gradient(180deg, #fff9e8 0%, #fff 70%); }
.bonus-stripe { display: inline-block; background: var(--c-ink); color: #fff; padding: 4px 12px; border-radius: var(--round-pill); font-size: 0.72rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; margin-bottom: 12px; align-self: flex-start; }
.bonus-tile--star .bonus-stripe { background: var(--c-accent); color: var(--c-ink); }
.bonus-tile h3 { margin: 0 0 6px; font-size: 1.25rem; color: var(--c-ink); }
.bonus-figure { color: var(--c-brand); font-weight: 700; font-size: 1.05rem; margin: 0 0 14px; }
.bonus-line { list-style: none; padding: 0; margin: 0 0 18px; font-size: 0.9rem; color: var(--c-ink-soft); flex: 1; }
.bonus-line li { padding: 5px 0; border-bottom: 1px dashed var(--c-rule); }
.bonus-line li:last-child { border-bottom: 0; }

/* LONG READ (SEO TEXT) */
.long-read { padding: 70px 0; }
.long-read h2 { font-size: clamp(1.7rem, 3vw, 2.1rem); color: var(--c-ink); margin: 36px 0 14px; line-height: 1.25; letter-spacing: -0.01em; }
.long-read h2:first-child { margin-top: 0; }
.long-read h3 { font-size: 1.4rem; color: var(--c-ink); margin: 28px 0 10px; }
.long-read h4 { font-size: 1.12rem; color: var(--c-ink); margin: 22px 0 8px; }
.long-read p { margin: 0 0 16px; }
.long-read ul, .long-read ol { padding-left: 24px; margin: 0 0 18px; }
.long-read li { margin-bottom: 6px; }

/* OPINION RAIL (REVIEWS) */
.opinion-block { padding: 70px 0; background: var(--c-canvas-2); }
.agg-strip { display: grid; grid-template-columns: 220px 1fr; gap: 30px; align-items: center; background: #fff; border-radius: var(--round-lg); padding: 26px; margin-bottom: 30px; box-shadow: var(--shadow-low); }
.agg-figure { text-align: center; padding: 18px; background: linear-gradient(135deg, var(--c-canvas-2) 0%, #fff 100%); border-radius: var(--round); border: 1px solid var(--c-rule); }
.agg-major { display: block; font-size: 3.2rem; font-weight: 800; color: var(--c-brand); line-height: 1; }
.agg-stars { color: var(--c-accent); letter-spacing: 3px; font-size: 1.3rem; }
.agg-bars { list-style: none; padding: 0; margin: 0; }
.agg-bars li { display: grid; grid-template-columns: 30px 1fr 30px; gap: 10px; align-items: center; padding: 4px 0; font-size: 0.9rem; color: var(--c-ink-soft); }
.agg-bar { background: var(--c-canvas-2); border-radius: 4px; height: 10px; overflow: hidden; }
.agg-bar > span { display: block; height: 100%; background: linear-gradient(90deg, var(--c-accent) 0%, var(--c-accent-deep) 100%); border-radius: 4px; }

.opinion-rail { position: relative; }
.rail-track { display: flex; gap: 16px; overflow-x: auto; scroll-behavior: smooth; padding: 6px 2px 18px; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; scrollbar-width: thin; }
.rail-track::-webkit-scrollbar { height: 6px; }
.rail-track::-webkit-scrollbar-thumb { background: var(--c-rule); border-radius: 4px; }
.opinion-card { flex: 0 0 320px; scroll-snap-align: start; background: #fff; border-radius: var(--round); padding: 22px; box-shadow: var(--shadow-low); display: flex; flex-direction: column; border-top: 4px solid var(--c-brand); }
.opinion-stars { color: var(--c-accent); letter-spacing: 2px; font-size: 1rem; margin-bottom: 10px; }
.opinion-quote { flex: 1; margin: 0 0 14px; color: var(--c-ink); font-size: 0.95rem; line-height: 1.55; font-style: italic; }
.opinion-card footer { border-top: 1px solid var(--c-rule); padding-top: 10px; }
.opinion-card footer strong { display: block; color: var(--c-ink); }
.opinion-card footer span { color: var(--c-ink-soft); font-size: 0.82rem; }
.rail-arrow { position: absolute; top: 50%; transform: translateY(-50%); width: 44px; height: 44px; border-radius: 50%; background: linear-gradient(135deg, var(--c-brand) 0%, var(--c-brand-deep) 100%); color: var(--c-accent); border: 0; font-size: 1.6rem; cursor: pointer; box-shadow: var(--shadow-mid); display: flex; align-items: center; justify-content: center; line-height: 1; z-index: 2; }
.rail-arrow:hover { background: var(--c-accent); color: var(--c-ink); }
.rail-prev { left: -10px; }
.rail-next { right: -10px; }

/* SIGNUP FORM */
.signup-section { padding: 70px 0; background: linear-gradient(135deg, var(--c-ink) 0%, var(--c-brand-deep) 100%); color: #fff; text-align: center; }
.signup-section .block-h { color: #fff; }
.signup-section .block-sub { color: rgba(255,255,255,0.78); margin-left: auto; margin-right: auto; }
.signup-form { display: flex; flex-direction: column; gap: 14px; max-width: 480px; margin: 0 auto; align-items: stretch; text-align: left; }
.signup-form input[type="email"] { padding: 14px 16px; border: 0; border-radius: var(--round-pill); font-size: 1rem; font-family: inherit; }
.age-confirm { color: rgba(255,255,255,0.85); font-size: 0.9rem; display: flex; gap: 8px; align-items: center; }
.signup-form .cta { width: 100%; }
.form-alert { color: #ffd0d3; background: rgba(199,65,72,0.22); padding: 8px 14px; border-radius: var(--round); margin: 0; font-size: 0.9rem; }
.signup-fineprint { color: rgba(255,255,255,0.6); margin-top: 16px; max-width: 480px; margin-left: auto; margin-right: auto; text-align: center; font-size: 0.82rem; }

/* PROS / CONS */
.balance-block { padding: 70px 0; }
.balance-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.balance-positive, .balance-negative { background: #fff; padding: 28px; border-radius: var(--round-lg); border: 1px solid var(--c-rule); }
.balance-positive { border-top: 4px solid var(--c-good); }
.balance-negative { border-top: 4px solid var(--c-bad); }
.balance-positive h3 { color: var(--c-good); margin: 0 0 14px; }
.balance-negative h3 { color: var(--c-bad); margin: 0 0 14px; }
.balance-positive ul, .balance-negative ul { padding-left: 22px; margin: 0; }
.balance-positive li, .balance-negative li { padding: 6px 0; }

/* AUTHOR */
.byline-block { padding: 70px 0; background: var(--c-canvas-2); }
.byline-card { display: grid; grid-template-columns: 160px 1fr; gap: 30px; background: #fff; padding: 32px; border-radius: var(--round-lg); align-items: start; border: 1px solid var(--c-rule); box-shadow: var(--shadow-low); }
.byline-card img { border-radius: var(--round-lg); width: 160px; height: 160px; object-fit: cover; }
.byline-info h3 { margin: 0 0 4px; font-size: 1.35rem; color: var(--c-ink); }
.byline-role { color: var(--c-brand); font-weight: 700; margin: 0 0 14px; }
.byline-extra { color: var(--c-ink-soft); font-size: 0.88rem; margin-top: 12px; }

/* FAQ */
.answers-block { padding: 70px 0; }
.answers-list { display: flex; flex-direction: column; gap: 10px; }
.answer-item { background: #fff; border: 1px solid var(--c-rule); border-radius: var(--round); overflow: hidden; }
.answer-item summary { padding: 18px 22px; cursor: pointer; font-weight: 600; color: var(--c-ink); list-style: none; position: relative; padding-right: 50px; }
.answer-item summary::-webkit-details-marker { display: none; }
.answer-item summary::after { content: "+"; position: absolute; right: 22px; top: 50%; transform: translateY(-50%); font-size: 1.5rem; font-weight: 400; color: var(--c-brand); transition: .2s; }
.answer-item[open] summary::after { content: "−"; color: var(--c-accent-deep); }
.answer-item summary:focus-visible { outline-offset: -3px; }
.answer-body { padding: 0 22px 20px; color: var(--c-ink-soft); }
.answer-body p { margin: 0; }

/* CTA BANNER */
.banner-cta { padding: 56px 0; background: linear-gradient(135deg, var(--c-accent) 0%, var(--c-accent-deep) 100%); text-align: center; }
.banner-cta h2 { font-size: clamp(1.5rem, 3vw, 2.1rem); color: var(--c-ink); margin: 0 0 8px; }
.banner-cta p { color: var(--c-ink); opacity: 0.85; margin: 0 0 24px; }
.banner-cta .cta-pill { background: var(--c-ink); color: var(--c-accent); border-color: var(--c-ink); }
.banner-cta .cta-pill:hover { background: var(--c-brand-deep); border-color: var(--c-brand-deep); }

/* MICRO LEGAL */
.micro-legal { padding: 26px 0; background: var(--c-canvas); border-top: 1px solid var(--c-rule); }
.micro-legal p { color: var(--c-ink-soft); font-size: 0.78rem; line-height: 1.65; margin: 0; }

/* FOOTER */
.page-foot { background: var(--c-ink); color: rgba(255,255,255,0.74); padding: 50px 0 0; }
.foot-grid { display: grid; grid-template-columns: 1.2fr 1fr 1.8fr; gap: 30px; }
.foot-identity img { background: #fff; padding: 8px 12px; border-radius: 6px; }
.foot-identity p { font-size: 0.9rem; margin: 14px 0 0; }
.foot-menu h4, .foot-icons h4 { color: #fff; font-size: 0.88rem; text-transform: uppercase; letter-spacing: .06em; margin: 0 0 14px; }
.foot-menu ul { list-style: none; padding: 0; margin: 0; }
.foot-menu li { margin-bottom: 8px; }
.foot-menu a { color: rgba(255,255,255,0.74); font-size: 0.92rem; }
.foot-menu a:hover { color: var(--c-accent); text-decoration: none; }
.bank-row { list-style: none; padding: 0; margin: 0 0 18px; display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.bank-row li { background: #fff; padding: 6px 10px; border-radius: 4px; min-height: 38px; display: inline-flex; align-items: center; }
.bank-row img { display: block; max-height: 22px; width: auto; height: auto; }
.bank-row img.bank-row-dark { filter: invert(1); }
.foot-rule { padding: 22px; border-top: 1px solid rgba(255,255,255,0.08); margin-top: 40px; text-align: center; font-size: 0.82rem; color: rgba(255,255,255,0.6); }

/* DOCK CTA (sticky) */
.dock-cta { position: fixed; bottom: 16px; left: 50%; transform: translateX(-50%); background: linear-gradient(135deg, var(--c-brand) 0%, var(--c-brand-deep) 100%); color: #fff; padding: 12px 20px; padding-right: 44px; border-radius: var(--round-pill); box-shadow: var(--shadow-mid); z-index: 90; max-width: 92%; border: 2px solid var(--c-accent); transition: opacity .25s, transform .25s; }
.dock-cta.is-hidden { opacity: 0; pointer-events: none; transform: translateX(-50%) translateY(40px); }
.dock-inner { display: flex; gap: 16px; align-items: center; }
.dock-text strong { display: block; color: var(--c-accent); font-size: 1.02rem; }
.dock-text span { font-size: 0.78rem; color: rgba(255,255,255,0.78); }
.dock-close { position: absolute; top: 6px; right: 8px; background: transparent; border: 0; color: rgba(255,255,255,0.78); font-size: 1.5rem; cursor: pointer; line-height: 1; padding: 4px 8px; }
.dock-close:hover { color: var(--c-accent); }

/* RESPONSIVE */
@media (max-width: 1023px) {
  .foot-grid { grid-template-columns: 1fr 1fr; }
  .tile-grid { grid-template-columns: 1fr 1fr; }
  .bonus-rack { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 767px) {
  .burger { display: block; margin-left: auto; order: 3; }
  .topbar-grid { flex-wrap: wrap; }
  .main-menu { order: 4; flex-basis: 100%; max-height: 0; overflow: hidden; transition: max-height .3s; }
  .main-menu.is-open { max-height: 600px; padding: 14px 0; }
  .main-menu ul { flex-direction: column; gap: 12px; align-items: stretch; }
  .main-menu a { padding: 8px 0; display: block; }
  .topbar-cta { order: 2; margin-left: auto; }
  .topbar-cta .cta { padding: 8px 14px; font-size: 0.85rem; }
  .lead-stage { padding: 50px 0; }
  .lead-grid { grid-template-columns: 1fr; gap: 30px; }
  .lead-points { grid-template-columns: 1fr; }
  .qr-stack { grid-template-columns: 1fr 1fr; }
  .tile-grid { grid-template-columns: 1fr; }
  .bonus-rack { grid-template-columns: 1fr; }
  .agg-strip { grid-template-columns: 1fr; gap: 16px; padding: 18px; }
  .balance-grid { grid-template-columns: 1fr; }
  .byline-card { grid-template-columns: 1fr; text-align: center; }
  .byline-card img { margin: 0 auto; }
  .foot-grid { grid-template-columns: 1fr; }
  .rail-arrow { width: 36px; height: 36px; font-size: 1.3rem; }
  .rail-prev { left: 0; }
  .rail-next { right: 0; }
  .opinion-card { flex: 0 0 270px; }
  .dock-cta { left: 8px; right: 8px; transform: none; max-width: none; }
  .dock-cta.is-hidden { transform: translateY(60px); }
  .step-list li { padding-left: 60px; }
  .step-list li::before { left: 14px; width: 32px; height: 32px; font-size: 0.95rem; }
}

@media (max-width: 480px) {
  .wrap { padding: 0 14px; }
  .long-read h2 { margin-top: 28px; }
  .info-grid th, .info-grid td { padding: 10px 12px; font-size: 0.88rem; }
}

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}
