/* ============================================================
   上海每日活动 · Shanghai Daily Events
   方向：澄澈 Modern Clean —— 浅色通透 / 封面优先 / 单一强调色 / 系统字体零外部依赖
   ============================================================ */
:root{
  --bg:#F7F4EF;
  --bg-2:#FBF8F3;
  --surface:#FFFFFF;
  --ink:#23201C;
  --ink-soft:#6E665B;     /* 承载信息的次要文字 ~5.6:1 */
  --ink-faint:#857C70;    /* 仅装饰性微标签/图标 ~4.1:1 */
  --line:#ECE7DF;
  --line-2:#F2EDE5;
  --accent:#BC5436;
  --accent-press:#A4452B;
  --accent-tint:#F6E7DF;
  --free:#2F7A4C;
  --free-tint:#E7F0EA;
  --fav-idle:#B8AE9F;
  --ongoing:#6E665B;
  --ongoing-tint:#F0ECE4;

  --r-card:16px;
  --r-media:14px;
  --r-sm:10px;
  --r-pill:999px;
  --sh-rest:0 1px 2px rgba(35,32,28,.05);
  --sh-hover:0 2px 4px rgba(35,32,28,.05), 0 10px 22px rgba(35,32,28,.09);
  --sh-pop:0 8px 24px rgba(35,32,28,.12);
  --ease:cubic-bezier(.23,1,.32,1);

  --maxw:1200px;
  --pad:24px;

  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei","Hiragino Sans GB",ui-sans-serif,Roboto,sans-serif;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;}
::selection{background:var(--accent-tint);}

svg.ico,.search-ico,.meta-ico,.cat-ico,.btn-ico{
  fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;
}

:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px;}

.eyebrow{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);}

/* ============================================================ Header */
.site-header{position:relative;background:var(--bg-2);border-bottom:1px solid var(--line);overflow:hidden;}
.header-aura{position:absolute;top:-160px;right:8%;width:520px;height:360px;pointer-events:none;
  background:radial-gradient(closest-side,rgba(188,84,54,.10),rgba(188,84,54,0) 70%);}
.header-inner{position:relative;max-width:var(--maxw);margin:0 auto;padding:30px var(--pad) 26px;
  display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.brand-eyebrow{margin:0 0 6px;font-size:11px;font-weight:600;letter-spacing:.22em;color:var(--accent);text-transform:uppercase;}
.brand h1{margin:0;font-size:27px;font-weight:700;letter-spacing:-.01em;}
.tagline{margin:8px 0 0;color:var(--ink-soft);font-size:14px;}
.header-meta{font-size:12.5px;color:var(--ink-soft);text-align:right;line-height:1.7;}
.header-meta b{color:var(--ink);font-weight:600;}
.header-meta .hm-srcs{color:var(--ink-soft);}

/* ============================================================ Toolbar */
.toolbar{position:sticky;top:0;z-index:30;background:rgba(247,244,239,.82);border-bottom:1px solid var(--line);}
@supports (backdrop-filter:blur(8px)){.toolbar{backdrop-filter:saturate(160%) blur(10px);background:rgba(247,244,239,.72);}}
.toolbar-inner{max-width:var(--maxw);margin:0 auto;padding:14px var(--pad);}

.search-wrap{position:relative;margin-bottom:13px;}
.search-ico{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--ink-faint);pointer-events:none;}
#searchInput{width:100%;padding:11px 40px 11px 42px;font-size:15px;border:1px solid var(--line);border-radius:var(--r-sm);
  background:var(--surface);color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s;}
#searchInput::placeholder{color:var(--ink-faint);}
#searchInput::-webkit-search-cancel-button,#searchInput::-webkit-search-decoration{-webkit-appearance:none;appearance:none;}
#searchInput:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-tint);}
.search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:30px;height:30px;border:none;background:transparent;
  color:var(--ink-faint);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;}
.search-clear svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;}

/* date rail */
.date-rail{display:flex;gap:8px;overflow-x:auto;padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid var(--line);scrollbar-width:thin;}
.date-rail::-webkit-scrollbar{height:6px;}
.date-rail::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px;}
.day-chip{position:relative;flex:0 0 auto;min-width:60px;min-height:64px;padding:8px 12px 9px;border:1px solid var(--line);
  background:var(--surface);border-radius:12px;cursor:pointer;text-align:center;display:flex;flex-direction:column;
  justify-content:space-between;gap:2px;line-height:1.15;transition:border-color .15s,background .15s,transform .15s var(--ease);}
.day-chip[data-active="true"]{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 6px 16px rgba(188,84,54,.24);}
.day-chip .dc-wd{font-size:12px;color:var(--ink-soft);}
.day-chip .dc-en{font-size:9px;font-weight:600;letter-spacing:.1em;color:var(--ink-faint);}
.day-chip .dc-date{font-size:16px;font-weight:600;}
.day-chip .dc-count{font-size:10.5px;color:var(--ink-soft);}
.day-chip[data-active="true"] .dc-wd,.day-chip[data-active="true"] .dc-en,.day-chip[data-active="true"] .dc-count{color:rgba(255,255,255,.86);}
.day-chip.is-weekend .dc-wd{color:var(--accent);}
.day-chip[data-active="true"].is-weekend .dc-wd{color:#fff;}
.day-chip.is-empty{opacity:.5;}
.day-chip.is-today::after{content:"";position:absolute;left:50%;bottom:4px;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--accent);}
.day-chip[data-active="true"].is-today::after{background:#fff;}
.day-chip.all-chip{min-width:62px;}

/* filters */
.filters-line{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.chip-row{display:flex;gap:8px;flex-wrap:wrap;}
.chip{min-height:32px;padding:6px 13px;border:1px solid var(--line);background:var(--surface);border-radius:var(--r-pill);
  font-size:13px;color:var(--ink-soft);cursor:pointer;white-space:nowrap;transition:border-color .15s,color .15s,background .15s,transform .12s var(--ease);}
.chip[data-active="true"]{background:var(--accent);border-color:var(--accent);color:#fff;}
.chip .c{opacity:.6;margin-left:5px;font-size:11px;font-variant-numeric:tabular-nums;}
.chip[data-active="true"] .c{opacity:.85;}

.control-group{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.select-wrap{position:relative;}
.select-wrap::after{content:"";position:absolute;right:11px;top:50%;width:7px;height:7px;border-right:1.6px solid var(--ink-faint);border-bottom:1.6px solid var(--ink-faint);transform:translateY(-65%) rotate(45deg);pointer-events:none;}
.select{appearance:none;-webkit-appearance:none;min-height:34px;padding:8px 30px 8px 13px;border:1px solid var(--line);border-radius:var(--r-sm);
  background:var(--surface);color:var(--ink);font-size:13px;cursor:pointer;outline:none;}
.select:focus{border-color:var(--accent);}

.toggle{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-soft);cursor:pointer;user-select:none;min-height:34px;}
.toggle input{position:absolute;opacity:0;width:1px;height:1px;}
.switch{width:34px;height:20px;border-radius:var(--r-pill);background:var(--line);position:relative;transition:background .2s var(--ease);flex:0 0 auto;}
.knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.2);transition:transform .2s var(--ease);}
.toggle input:checked + .switch{background:var(--accent);}
.toggle input:checked + .switch .knob{transform:translateX(14px);}
.toggle input:focus-visible + .switch{outline:2px solid var(--accent);outline-offset:2px;}

.tab-btn{display:inline-flex;align-items:center;gap:6px;min-height:34px;padding:7px 13px;border:1px solid var(--line);border-radius:var(--r-sm);
  background:var(--surface);color:var(--ink);font-size:13px;cursor:pointer;
  transition:border-color .15s,background .15s,color .15s,transform .12s var(--ease);}
.tab-btn .ico{width:15px;height:15px;color:var(--ink-soft);}
.tab-btn[data-active="true"]{background:var(--accent);border-color:var(--accent);color:#fff;}
.tab-btn[data-active="true"] .ico{color:#fff;fill:#fff;}
.fav-count{min-width:18px;padding:0 5px;height:18px;border-radius:9px;background:var(--accent-tint);color:var(--accent);
  font-size:11px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;font-variant-numeric:tabular-nums;}
.tab-btn[data-active="true"] .fav-count{background:rgba(255,255,255,.24);color:#fff;}

.filter-summary{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:13px;padding-top:13px;border-top:1px dashed var(--line);}
.fs-label{font-size:12px;color:var(--ink-soft);}
.fs-chip{display:inline-flex;align-items:center;gap:5px;max-width:100%;min-width:0;padding:4px 6px 4px 11px;background:var(--accent-tint);color:var(--accent);border-radius:var(--r-pill);font-size:12px;}
.fs-chip .fs-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.fs-chip button{flex:0 0 auto;border:none;background:transparent;color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;border-radius:50%;}
.fs-chip button svg{width:13px;height:13px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;}
.fs-clear{margin-left:2px;border:none;background:transparent;color:var(--ink-soft);font-size:12px;cursor:pointer;text-decoration:underline;text-underline-offset:3px;}

/* ============================================================ Zones */
.container{max-width:var(--maxw);margin:0 auto;padding:24px var(--pad) 72px;}
.result-bar{color:var(--ink-soft);font-size:13px;margin-bottom:18px;font-variant-numeric:tabular-nums;}
.result-bar b{color:var(--ink);font-weight:600;}
.zones{display:block;}
.zones.intro{animation:introIn .45s var(--ease) both;}
@keyframes introIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
.zone{margin-bottom:40px;}
.zone:last-child{margin-bottom:0;}
.zone-head{display:flex;align-items:flex-end;gap:12px;margin-bottom:18px;}
.zone-head .zh-text{display:flex;flex-direction:column;gap:3px;}
.zone-head .zh-en{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);}
.zone-head h2{margin:0;font-size:20px;font-weight:700;letter-spacing:-.01em;}
.zone-head .zh-sub{font-size:13px;color:var(--ink-soft);margin-left:2px;padding-bottom:2px;}
.zone-head.ongoing .zh-en{color:var(--ongoing);}

.date-group{margin-bottom:30px;}
.date-head{display:flex;align-items:center;gap:14px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--line);}
.date-head .dh-num{font-size:30px;font-weight:800;line-height:1;letter-spacing:-.02em;color:var(--ink);min-width:38px;text-align:center;font-variant-numeric:tabular-nums;}
.date-head .dh-info{display:flex;flex-direction:column;gap:2px;}
.date-head .dh-en{font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);}
.date-head .dh-main{font-size:16px;font-weight:600;}
.date-head .dh-main .rel{color:var(--accent);}
.date-head .dh-count{margin-left:auto;font-size:12.5px;color:var(--ink-soft);font-variant-numeric:tabular-nums;}

/* ============================================================ Cards */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:22px;}
.hero-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:22px;}

.card{position:relative;display:flex;flex-direction:column;background:var(--surface);border-radius:var(--r-card);overflow:hidden;
  box-shadow:var(--sh-rest);transition:transform .22s var(--ease),box-shadow .22s var(--ease);}

.card-link{color:inherit;text-decoration:none;outline:none;}
.card-link::after{content:"";position:absolute;inset:0;z-index:1;border-radius:var(--r-card);}
.card-link:focus-visible::after{outline:2px solid var(--accent);outline-offset:-2px;}

.card-cover{position:relative;width:100%;overflow:hidden;height:0;padding-top:75%;
  background:linear-gradient(140deg,var(--bg-2),#EFE7DA);}
.cover-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;background:transparent;transition:transform .3s var(--ease);}
.cover-fallback{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  color:#8a6a52;padding:12px;text-align:center;}
.cover-fallback .cat-ico{width:34px;height:34px;opacity:.9;}
.cover-fallback .fb-initial{font-size:19px;font-weight:700;letter-spacing:.04em;opacity:.92;max-width:90%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.cover-scrim{position:absolute;left:0;right:0;bottom:0;height:46%;background:linear-gradient(transparent,rgba(20,16,12,.42));pointer-events:none;}
.cat-eyebrow{position:absolute;left:11px;bottom:10px;z-index:2;font-size:10.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.4);pointer-events:none;}
.cover-fav{position:absolute;top:9px;right:9px;z-index:3;width:32px;height:32px;border-radius:50%;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.84);box-shadow:0 1px 4px rgba(0,0,0,.16);
  transition:transform .15s var(--ease),background .15s;}
@supports (backdrop-filter:blur(4px)){.cover-fav{background:rgba(255,255,255,.6);backdrop-filter:blur(6px);}}
.cover-fav svg{width:16px;height:16px;fill:none;stroke:var(--fav-idle);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;transition:fill .15s,stroke .15s;}
.cover-fav[data-fav="true"] svg{fill:var(--accent);stroke:var(--accent);}
.cover-fav:active{transform:scale(.9);}

.card-body{display:flex;flex-direction:column;gap:7px;padding:13px 14px 14px;flex:1 1 auto;}
.card-title{margin:0;font-size:16px;font-weight:600;line-height:1.35;letter-spacing:-.01em;color:var(--ink);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word;}
.card-meta{display:flex;flex-direction:column;gap:4px;margin-top:1px;}
.meta-item{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--ink-soft);min-width:0;}
.meta-item .meta-ico{width:14px;height:14px;flex:0 0 auto;color:var(--ink-soft);}
.meta-item .mt{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ongoing-pill{display:inline-flex;align-items:center;font-size:11px;color:var(--ongoing);background:var(--ongoing-tint);padding:1px 8px;border-radius:var(--r-pill);font-weight:500;}

.card-foot{display:flex;align-items:center;gap:8px;margin-top:auto;padding-top:9px;}
.price{font-size:14px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums;}
.price.free{color:var(--free);background:var(--free-tint);padding:2px 9px;border-radius:var(--r-pill);font-size:12.5px;}
.src{font-size:11px;font-weight:500;letter-spacing:.02em;color:var(--ink-soft);display:inline-flex;align-items:center;gap:5px;}
.card-foot .src{margin-left:auto;}
.src .src-dot{width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.7;}
.cal-btn{position:relative;z-index:3;border:none;background:transparent;color:var(--ink-soft);cursor:pointer;display:inline-flex;align-items:center;gap:4px;
  font-size:11.5px;min-height:28px;padding:4px 8px;border-radius:7px;opacity:1;transition:opacity .15s,color .15s,background .15s,transform .12s var(--ease);}
.cal-btn .btn-ico{width:14px;height:14px;}
.cal-btn:active{transform:scale(.96);}

.card-author{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:12px;color:var(--ink-soft);margin-top:auto;padding-top:9px;}
.card-author .au-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

.hero-grid .card-cover{padding-top:62.5%;}
.hero-grid .card:first-child .card-cover{padding-top:56.25%;}
.hero-grid .card:first-child .card-title{font-size:19px;}

/* discover masonry */
.discover-masonry{columns:4;column-gap:18px;}
.discover-masonry .card{break-inside:avoid;margin-bottom:18px;width:100%;}
.discover-masonry .card-cover{height:auto;padding-top:0;min-height:120px;}
.discover-masonry .cover-img{position:relative;height:auto;}
.discover-masonry .cover-noimg,.discover-masonry .card-cover.cover-failed{height:0;padding-top:125%;}
.discover-more{display:block;width:100%;margin-top:6px;padding:12px;border:1px dashed var(--line);border-radius:var(--r-sm);background:transparent;
  color:var(--ink-soft);font-size:13px;cursor:pointer;transition:border-color .15s,color .15s;}

/* ============================================================ @supports 渐进增强（旧内核兜底已在上面用纯色/padding-top） */
@supports (aspect-ratio:1){
  .card-cover{height:auto;padding-top:0;aspect-ratio:4/3;}
  .hero-grid .card-cover{aspect-ratio:16/10;}
  .hero-grid .card:first-child .card-cover{aspect-ratio:16/9;}
  .discover-masonry .card-cover{aspect-ratio:auto;}
  .discover-masonry .cover-noimg,.discover-masonry .card-cover.cover-failed{aspect-ratio:4/5;padding-top:0;height:auto;}
}
@supports (background:color-mix(in srgb,red,blue)){
  .card-cover{background:linear-gradient(140deg,color-mix(in srgb,var(--tint,#C8702D) 14%,var(--bg-2)),color-mix(in srgb,var(--tint,#C8702D) 24%,#EFE7DA));}
}
@supports (color:color-mix(in srgb,red,blue)){
  .cover-fallback{color:color-mix(in srgb,var(--tint,#C8702D) 74%,#3a332c);}
}

/* ============================================================ Hover (仅可悬停设备) + Press */
@media (hover:hover) and (pointer:fine){
  .card:hover{transform:translateY(-2px);box-shadow:var(--sh-hover);}
  .card:hover .cover-img{transform:scale(1.04);}
  .cal-btn{opacity:0;}
  .card:hover .cal-btn{opacity:1;}
  .chip:hover{border-color:var(--accent);color:var(--accent);}
  .day-chip:hover{border-color:var(--accent);transform:translateY(-1px);}
  .day-chip[data-active="true"]:hover{transform:none;}
  .tab-btn:hover{border-color:var(--accent);}
  .cover-fav:hover{transform:scale(1.12);}
  .cover-fav:hover svg{stroke:var(--accent);}
  .btn-primary:hover{background:var(--accent-press);transform:translateY(-1px);}
  .search-clear:hover{color:var(--ink);background:var(--line-2);}
  .fs-chip button:hover{background:rgba(188,84,54,.16);}
  .fs-clear:hover{color:var(--accent);}
  .cal-btn:hover{color:var(--accent);background:var(--accent-tint);}
  .discover-more:hover{border-color:var(--accent);color:var(--accent);}
}
.chip:active,.tab-btn:active,.btn-primary:active,.day-chip:active{transform:scale(.97);}

/* ============================================================ Favorites bar (.ics) */
.fav-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:22px;padding:14px 16px;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-card);box-shadow:var(--sh-rest);}
.fav-bar .fb-title{font-size:14px;color:var(--ink-soft);}
.fav-bar .fb-title b{color:var(--ink);font-weight:600;}
.btn-primary{display:inline-flex;align-items:center;gap:7px;min-height:38px;padding:9px 15px;border:none;border-radius:var(--r-sm);
  background:var(--accent);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,transform .12s var(--ease);}
.btn-primary .btn-ico{width:16px;height:16px;stroke:#fff;}
.btn-primary:disabled{background:var(--line);color:var(--ink-faint);cursor:not-allowed;}
.btn-primary:disabled .btn-ico{stroke:var(--ink-faint);}

/* ============================================================ Empty */
.empty{text-align:center;padding:72px 20px;color:var(--ink-soft);}
.empty .empty-ico{width:64px;height:64px;color:var(--ink-faint);opacity:.8;margin-bottom:18px;fill:none;stroke:currentColor;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round;}
.empty h3{margin:0 0 8px;color:var(--ink);font-size:18px;font-weight:600;}
.empty p{margin:0 0 18px;font-size:14px;}
.empty .btn-primary{margin:0 auto;}

/* ============================================================ Footer */
.site-footer{border-top:1px solid var(--line);background:var(--bg-2);}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:24px var(--pad);}
.site-footer p{margin:0;font-size:12px;color:var(--ink-soft);}
.site-footer .footer-soft{margin-top:5px;color:var(--ink-faint);}

/* ============================================================ Responsive */
@media (max-width:1080px){.discover-masonry{columns:3;}}
@media (max-width:760px){
  .hero-grid{grid-template-columns:1fr 1fr;}
  .hero-grid .card:first-child{grid-column:1 / -1;}
  .hero-grid .card:first-child .card-cover{padding-top:56.25%;}
  @supports (aspect-ratio:1){.hero-grid .card:first-child .card-cover{aspect-ratio:16/9;}}
  .card-grid{grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:14px;}
  .discover-masonry{columns:2;column-gap:14px;}
  .discover-masonry .card{margin-bottom:14px;}
}
@media (max-width:560px){
  :root{--pad:16px;}
  .header-inner{padding:22px 16px 20px;align-items:flex-start;}
  .header-meta{text-align:left;}
  .brand h1{font-size:23px;}
  .chip-row{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;}
  .chip-row::-webkit-scrollbar{display:none;}
  .control-group{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;}
  .control-group .tab-btn{grid-column:1 / -1;justify-content:center;}
  .card-title{font-size:15px;}
  .date-head .dh-num{font-size:26px;}
  .zone{margin-bottom:32px;}
}
@media (max-width:430px){.hero-grid{grid-template-columns:1fr;}}

@media (prefers-reduced-motion:reduce){
  *{transition:none !important;animation:none !important;scroll-behavior:auto !important;}
  .card:hover{transform:none;}
  .card:hover .cover-img{transform:none;}
}
