@charset "UTF-8";
/* =============================================================
   みや恋・ゆる活 特設サイト  共通スタイル (base.css)
   宮崎市 みやざき出会い・結婚総合支援事業 / ゆる活から始める出会いの機会創出事業
   ============================================================= */

/* ---------- リセット ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{font:inherit;cursor:pointer;border:none;background:none}
table{border-collapse:collapse;width:100%}

/* ---------- デザイントークン（既定/共通） ---------- */
:root{
  --brand:#C72B79;
  --brand-dark:#9c1d5d;
  --brand-soft:#fbe6f0;
  --brand-soft2:#f6d3e4;
  --accent:#EE7D3A;
  --ink:#33272a;
  --ink-soft:#6c5b63;
  --line:#ecdfe6;
  --bg:#fffafc;
  --bg-card:#ffffff;
  --shadow:0 8px 30px rgba(120,30,80,.10);
  --shadow-sm:0 4px 14px rgba(120,30,80,.08);
  --radius:18px;
  --radius-lg:28px;
  --maxw:1120px;
  --font-body:"Noto Sans JP","Hiragino Kaku Gothic ProN","Hiragino Sans","Yu Gothic",Meiryo,sans-serif;
  --font-round:"M PLUS Rounded 1c","Noto Sans JP",sans-serif;
  --hero-tint:255,247,251;
}

/* テーマ：みや恋 */
.theme-miyakoi{
  --brand:#C72B79;--brand-dark:#9c1d5d;--brand-soft:#fbe6f0;--brand-soft2:#f6d3e4;
  --accent:#f4a8cb;--ink:#3a2530;--ink-soft:#7a5e6b;--line:#f0d8e4;--bg:#fff7fb;
  --hero-tint:255,247,251;
  --shadow:0 8px 30px rgba(160,30,100,.12);--shadow-sm:0 4px 14px rgba(160,30,100,.08);
}
/* テーマ：ゆる活 */
.theme-yurukatsu{
  --brand:#EE7D3A;--brand-dark:#cf5f1d;--brand-soft:#fdefe2;--brand-soft2:#fbe0c9;
  --accent:#f6b25e;--ink:#3a2e22;--ink-soft:#7a6651;--line:#f3e2d2;--bg:#fffaf4;
  --hero-tint:255,250,244;
  --shadow:0 8px 30px rgba(200,110,30,.14);--shadow-sm:0 4px 14px rgba(200,110,30,.10);
}
/* テーマ：ゲートウェイ（入口） */
.theme-gateway{
  --brand:#b94a7e;--brand-dark:#7d3357;--brand-soft:#fbeef4;--bg:#fdf7f4;
}

/* ---------- ベース ---------- */
body{
  font-family:var(--font-body);color:var(--ink);background:var(--bg);
  line-height:1.8;font-size:16px;letter-spacing:.02em;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.container{width:92%;max-width:var(--maxw);margin-inline:auto}
.section{padding:72px 0}
.section--tight{padding:48px 0}
h1,h2,h3,h4{font-family:var(--font-round);line-height:1.4;color:var(--ink)}
.lead{color:var(--ink-soft);font-size:1.02rem}

/* セクション見出し */
.sec-head{text-align:center;margin-bottom:44px}
.sec-head .ja{font-size:clamp(1.5rem,4vw,2.1rem);font-weight:800;position:relative;display:inline-block}
.sec-head .en{display:block;color:var(--brand);font-weight:700;letter-spacing:.22em;font-size:.8rem;margin-bottom:8px;text-transform:uppercase}
.sec-head .ja::after{content:"";display:block;width:54px;height:4px;border-radius:4px;background:var(--brand);margin:14px auto 0}

/* ---------- ボタン ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  padding:14px 30px;border-radius:999px;font-family:var(--font-round);font-weight:700;
  background:var(--brand);color:#fff;box-shadow:var(--shadow-sm);
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;font-size:1rem;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow);background:var(--brand-dark)}
.btn--outline{background:#fff;color:var(--brand);border:2px solid var(--brand)}
.btn--outline:hover{background:var(--brand);color:#fff}
.btn--lg{padding:17px 40px;font-size:1.08rem}
.btn--ghost{background:rgba(255,255,255,.18);color:#fff;border:1.5px solid rgba(255,255,255,.6)}
.btn--ghost:hover{background:#fff;color:var(--brand)}
.btn[aria-disabled="true"]{opacity:.55;pointer-events:none;filter:grayscale(.2)}

/* ---------- ヘッダー ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:18px;height:74px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-round);font-weight:800}
.brand img{width:46px;height:46px;border-radius:12px;box-shadow:var(--shadow-sm)}
.brand .brand-name{font-size:1.2rem;line-height:1.1;color:var(--brand)}
.brand .brand-sub{display:block;font-size:.62rem;letter-spacing:.18em;color:var(--ink-soft);font-family:var(--font-body);font-weight:600}
/* ヘッダーのInstagram公式アイコン */
.brand-ig{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:11px;flex:0 0 auto;margin-left:-4px;color:#fff;background:radial-gradient(circle at 30% 110%,#fdf497 0%,#fdf497 5%,#fd5949 45%,#d6249f 60%,#285AEB 90%);box-shadow:var(--shadow-sm);transition:transform .15s ease,box-shadow .15s ease}
.brand-ig:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.brand-ig:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.brand-ig svg{width:21px;height:21px}
@media(max-width:420px){.brand-ig{width:34px;height:34px}.brand-ig svg{width:19px;height:19px}}

.main-nav{margin-left:auto}
.main-nav ul{display:flex;gap:6px;align-items:center}
.main-nav a{display:block;padding:9px 14px;border-radius:999px;font-weight:600;font-size:.95rem;color:var(--ink);transition:background .15s,color .15s}
.main-nav a:hover{background:var(--brand-soft);color:var(--brand)}
.main-nav a.is-active{background:var(--brand);color:#fff}

.switch-links{display:flex;gap:8px;align-items:center;margin-left:8px}
.switch-links a{font-family:var(--font-round);font-weight:700;font-size:.82rem;padding:8px 14px;border-radius:999px;border:1.5px solid var(--line);color:var(--ink-soft);white-space:nowrap;display:flex;align-items:center;gap:6px}
.switch-links a:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}
.switch-links a .dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.dot--miyakoi{background:#C72B79}
.dot--yurukatsu{background:#EE7D3A}

.nav-toggle{display:none;margin-left:auto;width:46px;height:46px;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:5px;border:1.5px solid var(--line)}
.nav-toggle span{width:22px;height:2px;background:var(--brand);border-radius:2px;transition:.25s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- ヒーロー ---------- */
.hero{position:relative;overflow:hidden;background:linear-gradient(160deg,var(--brand-soft),var(--bg) 70%)}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;padding:64px 0 72px}
.hero-copy h1{font-size:clamp(1.9rem,5vw,3rem);font-weight:800;letter-spacing:.01em}
.hero-copy .hero-tag{display:inline-block;background:#fff;color:var(--brand);font-weight:700;font-family:var(--font-round);padding:6px 16px;border-radius:999px;font-size:.85rem;box-shadow:var(--shadow-sm);margin-bottom:18px}
.hero-copy p{margin:18px 0 28px;color:var(--ink-soft);font-size:1.05rem}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-visual{position:relative;display:flex;justify-content:center}
.hero-visual .logo-badge{width:min(330px,80%);aspect-ratio:1;border-radius:36px;background:var(--brand);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);transform:rotate(-3deg)}
.hero-visual .logo-badge img{width:78%}

/* ---------- ヒーロー（背景写真スライドショー） ---------- */
.hero--photo{position:relative;display:flex;align-items:center;min-height:clamp(480px,72vh,640px);overflow:hidden;background:var(--brand-soft)}
.hero-slideshow{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center 28%;opacity:0;transition:opacity 1.4s ease-in-out;will-change:opacity}
.hero-slide.is-active{opacity:1}
/* 可読性のための淡いスクリム（左→右で薄くなる・テーマ色に追従） */
.hero--photo::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(var(--hero-tint),.86) 0%,rgba(var(--hero-tint),.58) 40%,rgba(var(--hero-tint),.14) 64%,rgba(var(--hero-tint),0) 100%)}
.hero-photo-inner{position:relative;z-index:2;width:92%;max-width:var(--maxw);margin-inline:auto;padding:48px 0 64px}
/* パネルの白背景は使わず、写真の上に直接コンテンツを配置 */
.hero-panel{max-width:560px;padding:0;text-shadow:0 1px 12px rgba(var(--hero-tint),.9),0 1px 3px rgba(var(--hero-tint),.8)}
.hero-logo{width:92px;height:92px;border-radius:22px;box-shadow:0 6px 20px rgba(0,0,0,.18);margin-bottom:16px}
.hero-panel .hero-tag{display:inline-block;background:var(--brand);color:#fff;font-weight:700;font-family:var(--font-round);padding:6px 16px;border-radius:999px;font-size:.82rem;box-shadow:var(--shadow-sm);margin-bottom:14px;text-shadow:none}
.hero-panel h1{font-size:clamp(1.9rem,4.6vw,2.9rem);font-weight:800;letter-spacing:.01em;color:var(--ink)}
.hero-panel p{margin:14px 0 26px;color:var(--ink-soft);font-size:1.02rem}
/* スライド切替インジケーター */
.hero-dots{position:absolute;z-index:2;left:50%;bottom:26px;transform:translateX(-50%);display:flex;gap:9px}
.hero-dots button{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.7);box-shadow:0 1px 4px rgba(0,0,0,.25);border:none;cursor:pointer;padding:0;transition:width .25s,background .25s}
.hero-dots button.is-active{width:26px;border-radius:6px;background:var(--brand)}

/* 波形装飾 */
.wave{display:block;width:100%;line-height:0;position:relative;z-index:2}
.wave svg{width:100%;height:auto;display:block}
/* 写真ヒーローでは波形装飾を表示しない（画像に重なる白線を除去） */
.hero--photo .wave{display:none}

/* ---------- グリッド/カード ---------- */
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

.card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .18s;height:100%}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .card-ico{width:56px;height:56px;border-radius:16px;background:var(--brand-soft);display:flex;align-items:center;justify-content:center;font-size:1.7rem;margin-bottom:14px}
.card h3{font-size:1.18rem;margin-bottom:8px}
.card p{color:var(--ink-soft);font-size:.96rem}

/* 特徴ステップ */
.steps{counter-reset:step;display:grid;gap:18px}
.step{display:flex;gap:18px;align-items:flex-start;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow-sm)}
.step::before{counter-increment:step;content:counter(step);flex:0 0 auto;width:44px;height:44px;border-radius:50%;background:var(--brand);color:#fff;font-family:var(--font-round);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.step h3{font-size:1.1rem;margin-bottom:4px}
.step p{color:var(--ink-soft);font-size:.95rem}

/* ---------- イベントカード ---------- */
.event-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .18s,box-shadow .18s}
.event-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.event-card .ec-media{position:relative;aspect-ratio:16/10;background:linear-gradient(135deg,var(--brand-soft),var(--brand-soft2));display:flex;align-items:center;justify-content:center;overflow:hidden}
.event-card .ec-media img{width:100%;height:100%;object-fit:cover}
.event-card .ec-media .ec-emoji{font-size:3.4rem}
.event-card .ec-date{position:absolute;top:12px;left:12px;background:#fff;color:var(--brand);font-family:var(--font-round);font-weight:800;border-radius:12px;padding:6px 12px;font-size:.9rem;box-shadow:var(--shadow-sm);line-height:1.2;text-align:center}
.event-card .ec-cat{position:absolute;top:12px;right:12px;background:var(--brand);color:#fff;font-weight:700;font-size:.72rem;padding:5px 11px;border-radius:999px}
.event-card .ec-body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:12px;flex:1}
.event-card h3{font-size:1.12rem;line-height:1.5}
.event-meta{display:grid;gap:7px;font-size:.9rem;color:var(--ink-soft)}
.event-meta div{display:flex;gap:8px}
.event-meta .mk{flex:0 0 4.5em;color:var(--brand);font-weight:700}
.event-card .ec-foot{margin-top:auto;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.fee-pill{display:inline-block;background:var(--brand-soft);color:var(--brand-dark);font-weight:700;border-radius:999px;padding:4px 12px;font-size:.85rem}
.fee-pill.is-free{background:#e7f6ea;color:#2e8b57}

/* タグ/バッジ */
.tag{display:inline-block;background:var(--brand-soft);color:var(--brand-dark);font-weight:700;border-radius:999px;padding:4px 13px;font-size:.82rem}
.badge-set{display:inline-flex;align-items:center;gap:6px;background:var(--brand);color:#fff;font-family:var(--font-round);font-weight:800;border-radius:10px;padding:4px 11px;font-size:.82rem}

/* ---------- 体験談 ---------- */
.voice-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);position:relative}
.voice-card::before{content:"\201C";position:absolute;top:6px;left:18px;font-size:4rem;color:var(--brand-soft2);font-family:Georgia,serif;line-height:1}
.voice-card .v-body{position:relative;color:var(--ink);font-size:1rem}
.voice-card .v-who{margin-top:16px;display:flex;align-items:center;gap:12px}
.voice-card .v-avatar{width:46px;height:46px;border-radius:50%;background:var(--brand-soft);display:flex;align-items:center;justify-content:center;font-size:1.4rem}
.voice-card .v-name{font-weight:700;font-size:.95rem}
.voice-card .v-meta{font-size:.82rem;color:var(--ink-soft)}
.voice-stars{color:#f5b301;letter-spacing:2px;margin-top:4px}

/* ---------- テーブル ---------- */
.table-wrap{overflow-x:auto;border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.data-table{background:#fff;min-width:640px}
.data-table th,.data-table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--line);font-size:.94rem;vertical-align:top}
.data-table thead th{background:var(--brand);color:#fff;font-family:var(--font-round);font-weight:700;white-space:nowrap}
.data-table tbody tr:nth-child(even){background:var(--brand-soft)}
.data-table tbody tr:hover{background:var(--brand-soft2)}

/* ---------- 帯CTA ---------- */
.cta-band{background:linear-gradient(135deg,var(--brand),var(--brand-dark));color:#fff;border-radius:var(--radius-lg);padding:48px;text-align:center;box-shadow:var(--shadow)}
.cta-band h2{color:#fff;font-size:clamp(1.4rem,4vw,2rem)}
.cta-band p{opacity:.92;margin:12px 0 26px}

/* ---------- お知らせ ---------- */
.notice-list{display:grid;gap:2px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.notice-list li{display:flex;gap:16px;align-items:center;padding:16px 22px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.notice-list li:last-child{border-bottom:none}
.notice-list time{color:var(--ink-soft);font-weight:700;font-size:.88rem;flex:0 0 6.5em}
.notice-list .n-tag{background:var(--brand-soft);color:var(--brand-dark);font-weight:700;font-size:.74rem;border-radius:999px;padding:3px 11px}

/* ---------- パンくず ---------- */
.crumbs{font-size:.84rem;color:var(--ink-soft);padding:16px 0}
.crumbs a:hover{color:var(--brand)}
.crumbs span{margin:0 .4em}

/* ページヘッダー（下層） */
.page-hero{background:linear-gradient(160deg,var(--brand-soft),var(--bg));padding:40px 0 48px;text-align:center}
.page-hero h1{font-size:clamp(1.6rem,4.5vw,2.4rem);font-weight:800}
.page-hero p{color:var(--ink-soft);margin-top:10px}

/* ---------- フッター ---------- */
.site-footer{background:var(--brand-dark);color:#fff;margin-top:0}
.site-footer a{color:#fff}
.footer-top{padding:56px 0 40px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
.footer-brand img{width:56px;height:56px;border-radius:14px;margin-bottom:14px;background:#fff;padding:4px}
.footer-brand .f-name{font-family:var(--font-round);font-weight:800;font-size:1.25rem}
.footer-brand p{opacity:.85;font-size:.9rem;margin-top:10px}
.footer-col h4{font-family:var(--font-round);font-size:1rem;margin-bottom:14px;opacity:.95}
.footer-col ul{display:grid;gap:9px}
.footer-col a{opacity:.85;font-size:.92rem}
.footer-col a:hover{opacity:1;text-decoration:underline}
.sns-row{display:flex;gap:12px;margin-top:6px}
.sns-row a{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;transition:.15s}
.sns-row a:hover{background:#fff;color:var(--brand)}
.sns-row a svg{width:22px;height:22px}
.sns-row a[aria-disabled="true"]{opacity:.45;cursor:not-allowed}
.contact-line{display:flex;gap:8px;align-items:center;font-size:.92rem;opacity:.9;margin-bottom:8px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.18);padding:20px 0;font-size:.82rem;opacity:.85;text-align:center}
.footer-bottom .biz{display:block;margin-top:6px;opacity:.8}

/* ---------- ユーティリティ ---------- */
.text-center{text-align:center}
.mt-0{margin-top:0}.mt-1{margin-top:12px}.mt-2{margin-top:24px}.mt-3{margin-top:36px}
.mb-2{margin-bottom:24px}
.prose p{margin-bottom:1.1em;color:var(--ink-soft)}
.prose h2{font-size:1.5rem;margin:1.6em 0 .6em}
.prose h3{font-size:1.2rem;margin:1.4em 0 .4em;color:var(--brand)}
.pill-row{display:flex;gap:10px;flex-wrap:wrap}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* 注記ボックス */
.note-box{background:var(--brand-soft);border:1px dashed var(--brand);border-radius:var(--radius);padding:18px 22px;font-size:.92rem;color:var(--brand-dark)}

/* ---------- レスポンシブ ---------- */
@media(max-width:980px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-cta{justify-content:center}
  .hero-visual{order:-1}
  .grid-4{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:820px){
  .nav-toggle{display:flex}
  .main-nav{position:fixed;inset:74px 0 auto 0;margin:0;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow);transform:translateY(-130%);transition:transform .3s ease;max-height:calc(100vh - 74px);overflow:auto}
  .main-nav.open{transform:none}
  .main-nav ul{flex-direction:column;align-items:stretch;gap:0;padding:10px 16px}
  .main-nav a{padding:14px 10px;border-radius:12px}
  .switch-links{flex-direction:column;align-items:stretch;margin:8px 0 6px;border-top:1px solid var(--line);padding-top:12px}
  .switch-links a{justify-content:center}
}
@media(max-width:680px){
  .section{padding:52px 0}
  .section--tight{padding:36px 0}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .cta-band{padding:34px 22px}
  .cta-band h2{font-size:1.3rem}
  .data-table th,.data-table td{padding:11px 12px}
  .header-inner{height:66px}
  .main-nav{inset-block-start:66px}
  /* ヒーロー：モバイルではロゴを控えめにし、余白を圧縮 */
  .hero-inner{padding:32px 0 40px;gap:22px}
  .hero-visual .logo-badge{width:min(200px,52%)}
  .hero-copy p{font-size:.98rem;margin:14px 0 22px}
  .hero-tag{font-size:.8rem}
  /* 写真ヒーロー（モバイル）：画像を縮小バンドで“全体”表示し、文章は画像の下に配置 */
  .hero--photo{display:block;min-height:0;height:auto;background:var(--bg)}
  .hero-slideshow{position:relative;aspect-ratio:16/10;background:var(--brand-soft)}
  .hero-slide{background-size:contain;background-repeat:no-repeat;background-position:center}
  .hero--photo::before{display:none}
  .hero-photo-inner{display:block;width:92%;margin-inline:auto;padding:22px 0 6px;min-height:0}
  .hero-panel{max-width:100%;padding:0;text-shadow:none}
  .hero-logo{width:66px;height:66px;border-radius:16px;margin-bottom:12px}
  .hero-panel h1{font-size:clamp(1.7rem,7vw,2.2rem)}
  .hero-panel p{font-size:.96rem;margin:12px 0 20px}
  .hero-dots{display:none}
  .sec-head{margin-bottom:30px}
  .page-hero{padding:28px 0 32px}
  .card{padding:22px}
  .voice-card{padding:24px}
  .prose h2{font-size:1.3rem}
  .crumbs{padding:12px 0}
}
/* 小型スマートフォン（〜420px）：タップしやすさと密度を最適化 */
@media(max-width:420px){
  body{font-size:15px}
  .container{width:90%}
  .brand img{width:40px;height:40px}
  .brand .brand-name{font-size:1.05rem}
  .brand .brand-sub{font-size:.58rem}
  .hero-cta{gap:10px;width:100%}
  .hero-cta .btn{width:100%}
  .btn{padding:13px 22px;font-size:.95rem}
  .event-card .ec-body{padding:18px 18px 22px;gap:10px}
  .event-card h3{font-size:1.05rem}
  .event-meta{font-size:.86rem}
  .event-card .ec-foot{gap:8px}
  .event-card .ec-foot .btn{flex:1}
  .cta-band{padding:28px 18px}
  .cta-band p{font-size:.92rem}
  .note-box{padding:15px 16px;font-size:.88rem}
  .footer-top{padding:44px 0 32px}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
}
