/*
Theme Name: なやみ晴れ（お悩み相談ナビ）
Theme URI: https://www.onayami-soudan-navi.com/
Author: なやみ晴れ編集部
Description: 「お悩み相談ナビ / なやみ晴れ」専用の自作テーマ。悩み導線・商材出し分け・クリック計測を内蔵。記事はAI相談の代わりとして、まず悩みを整理し、必要なときだけ相談先・サービスへつなぐ設計。
Version: 0.5.4
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: nayami-hare
*/

/* =========================================================
   デザイントークン（:root で一括管理）
   ・白基調＋クリーンな薄グレー。アクセント色はポイント使い
   ・カード化なし。角丸はボタン／ピル／チップ／丸ドット／商材カードのみ
   ・フォント：LINE Seed JP（最大600）
   ========================================================= */
:root{
  --white:#FFFFFF;
  --ink:#1B1F24; --body:#33383E; --muted:#6B7280;
  --gray:#F5F7F8; --gray-2:#EDF0F2; --line:#E3E7EB;
  --emerald:#0FA968; --emerald-d:#0B8A55; --emerald-t:#E7F6EF;
  --sky:#37B4DF; --sky-t:#E8F6FC; --sky-d:#1488B5; --lime:#8CC63F; --gold:#F5B400;
  --orange:#F97316; --orange-d:#E5640A;
  --maxw:1080px; --r:8px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:"LINE Seed JP","Hiragino Sans","Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;color:var(--body);background:var(--white);font-size:17px;font-weight:400;line-height:1.85;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--emerald-d)}
a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
:focus-visible{outline:3px solid var(--emerald);outline-offset:2px}

.sec{padding:44px 0}
.sec-ttl{font-size:24px;line-height:1.4;color:var(--ink);font-weight:600;margin:0 0 4px;padding-left:13px;position:relative;letter-spacing:.01em}
.sec-ttl::before{content:"";position:absolute;left:0;top:.18em;bottom:.18em;width:4px;background:var(--emerald)}
.sec-lead{margin:0 0 22px;padding-left:13px;color:var(--muted);font-size:15px}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;font-size:17px;font-weight:600;cursor:pointer;padding:13px 22px;border-radius:var(--r);border:1.5px solid transparent;transition:.15s ease;text-decoration:none;line-height:1.3}
.btn-cta{background:var(--orange);color:#fff}
.btn-cta:hover{background:var(--orange-d);text-decoration:none;color:#fff}
.btn-ghost{background:#fff;color:var(--emerald-d);border-color:var(--emerald)}
.btn-ghost:hover{background:var(--emerald-t);text-decoration:none}

.ph{position:relative;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--gray-2);color:#98a0a8;border:1.5px dashed #CFD5DA;padding:14px}
.ph .lab{font-size:13px;line-height:1.55}
.ph .lab b{display:block;font-size:11px;letter-spacing:.16em;color:#aab0b6;font-weight:600;margin-bottom:5px}

/* ヘッダー */
.topline{height:4px;background:var(--emerald)}
header.site{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line)}
.hd{display:flex;align-items:center;gap:12px;height:62px}
.hd .menu{font-size:24px;line-height:1;background:none;border:none;color:var(--ink);cursor:pointer;padding:6px}
.brand{display:flex;flex-direction:column;line-height:1.15;margin-right:auto;text-decoration:none}
.brand .b1{font-size:19px;font-weight:600;color:var(--ink)}
.brand .b2{font-size:11px;color:var(--emerald-d);letter-spacing:.08em}
.hd .ic{font-size:20px;background:none;border:none;color:var(--ink);cursor:pointer;padding:6px;text-decoration:none}
.drawer{display:none;border-bottom:1px solid var(--line);background:var(--gray);max-height:calc(100vh - 62px);max-height:calc(100dvh - 62px);overflow-y:auto;-webkit-overflow-scrolling:touch}
.drawer.open{display:block}
.drawer .wrap{padding-top:10px;padding-bottom:14px}
.drawer-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr;gap:2px}
.drawer-list a{display:block;padding:13px 14px;color:var(--ink);font-weight:400;text-decoration:none;border-radius:8px}
.drawer-list a:hover{background:var(--emerald-t);color:var(--emerald-d);text-decoration:none}
@media(min-width:760px){ .drawer-list{grid-template-columns:repeat(3,1fr);gap:4px 18px} }

/* 横スクロール カテゴリナビ */
.catnav{background:#fff;border-bottom:1px solid var(--line)}
.catnav .row{display:flex;gap:6px;overflow-x:auto;padding:10px 18px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.catnav .row::-webkit-scrollbar{display:none}
.catnav a{flex:0 0 auto;font-size:15px;font-weight:400;color:var(--ink);padding:7px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);text-decoration:none}
.catnav a:hover{background:var(--emerald-t);border-color:var(--emerald)}

/* ファーストビュー：OZmall型 無限ループ */
.fvhero{background:#fff;padding:22px 0 10px}
.carousel{position:relative;max-width:none;margin:0 auto;cursor:grab}
.carousel.dragging{cursor:grabbing}
.viewport{overflow:hidden}
.track{display:flex;gap:16px;transition:transform .5s cubic-bezier(.4,0,.2,1);will-change:transform}
.cslide{flex:0 0 auto;width:88%;text-decoration:none;opacity:.45;transition:opacity .45s;user-select:none}
.cslide img{width:100%;height:100%;object-fit:cover;display:block;-webkit-user-drag:none;user-select:none;pointer-events:none}
.cslide.is-active{opacity:1}
.cslide:hover{text-decoration:none}
.cslide .img{display:block;aspect-ratio:4/3;background:var(--gray-2);overflow:hidden}
.cslide img{width:100%;height:100%;object-fit:cover;display:block}
.ph-slide{display:flex;align-items:center;justify-content:center;text-align:center;border:1.5px dashed #CFD5DA;color:#98a0a8;padding:16px}
.ph-slide .lab{font-size:13px;line-height:1.6}
.ph-slide .lab b{display:block;font-size:14px;color:#8a929a;margin-bottom:6px;font-weight:600}
.cnav{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:44px;height:44px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.96);color:var(--ink);font-size:22px;cursor:pointer;display:none;align-items:center;justify-content:center}
.cnav:hover{background:#fff;border-color:var(--emerald);color:var(--emerald-d)}
.cnav.prev{left:8px}.cnav.next{right:8px}
.dots{display:flex;justify-content:center;gap:9px;margin-top:14px}
.dots button{width:10px;height:10px;border-radius:999px;border:none;background:#D3D8DD;cursor:pointer;padding:0}
.dots button[aria-current="true"]{background:var(--emerald);width:26px}

/* 安心の一文 */
.assure{background:#fff}
.assure .box{background:var(--emerald-t);border-left:4px solid var(--emerald);padding:14px 16px;margin-top:22px}
.assure .box p{margin:0;font-size:14.5px;color:#2c4339;line-height:1.7}

/* 悩みから探す */
.worry{background:#fff}
.worry .grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.wbtn{display:flex;align-items:center;gap:10px;text-align:left;text-decoration:none;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:14px;font-size:16px;font-weight:400;color:var(--ink);line-height:1.4;cursor:pointer}
.wbtn:hover{background:var(--emerald-t);border-color:var(--emerald)}
.wbtn .dot{flex:0 0 auto;width:9px;height:9px;border-radius:999px;background:var(--emerald)}

/* カテゴリから探す（4大分類） */
.cats{background:var(--gray)}
.catgrid{display:grid;grid-template-columns:1fr;gap:14px}
.catblock{background:#fff;padding:18px 18px 16px;border-left:4px solid var(--emerald)}
.catblock.c2{border-left-color:var(--lime)}
.catblock.c3{border-left-color:var(--gold)}
.catblock.c4{border-left-color:var(--sky)}
.catblock h3{margin:0 0 4px;font-size:18px;color:var(--ink);font-weight:600}
.catblock .desc{margin:0 0 12px;font-size:13.5px;color:var(--muted)}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chips a{font-size:14px;color:var(--ink);background:var(--gray);border:1px solid var(--line);border-radius:999px;padding:6px 13px;text-decoration:none}
.chips a:hover{border-color:var(--emerald);color:var(--emerald-d)}

/* 記事リスト（よく読まれている） */
.articles{background:#fff}
.alist{display:flex;flex-direction:column;gap:18px}
.acard{display:grid;grid-template-columns:104px 1fr;gap:14px;align-items:start;text-decoration:none}
.acard .thumb{aspect-ratio:4/3;overflow:hidden;background:var(--gray-2)}
.acard .thumb img{width:100%;height:100%;object-fit:cover}
.acard .cat{font-size:12px;color:var(--emerald-d);font-weight:600;letter-spacing:.03em}
.acard .ttl{font-size:16.5px;font-weight:400;color:var(--ink);line-height:1.5;margin:3px 0 4px;display:block}
.acard:hover .ttl{color:var(--emerald-d)}
.acard .date{font-size:12px;color:var(--muted)}
.more{margin-top:22px;text-align:center}

/* カテゴリー別の新着記事（写真＋タイトル） */
.catnews{background:var(--gray)}
.cn-grid{display:grid;grid-template-columns:1fr;gap:24px 34px}
.cn-col h3{margin:0 0 13px;font-size:17px;color:var(--ink);font-weight:600;display:flex;align-items:center;gap:8px}
.cn-col h3 a{color:var(--ink);text-decoration:none}
.cn-col h3 a:hover{color:var(--emerald-d)}
.cn-col h3 .cdot{width:11px;height:11px;border-radius:999px;flex:0 0 auto;background:var(--emerald);overflow:hidden;display:inline-flex;align-items:center;justify-content:center}
.cn-col h3 .cdot.has-img{width:30px;height:30px}
.cn-col h3 .cdot img{width:100%;height:100%;object-fit:cover;display:block}
.cn-col.g-lime h3 .cdot{background:var(--lime)}
.cn-col.g-gold h3 .cdot{background:var(--gold)}
.cn-col.g-sky h3 .cdot{background:var(--sky)}
.cn-items{display:flex;flex-direction:column;gap:13px;margin:0 0 13px}
.cn-item{display:grid;grid-template-columns:84px 1fr;gap:11px;align-items:start;text-decoration:none}
.cn-item .th{display:block;aspect-ratio:4/3;background:var(--gray-2);border:1.5px dashed #CFD5DA;overflow:hidden}
.cn-item .th img{width:100%;height:100%;object-fit:cover;border:0}
.cn-item .t{font-size:14.5px;line-height:1.5;color:var(--ink)}
.cn-item:hover .t{color:var(--emerald-d)}
.cn-more{font-size:13.5px;color:var(--emerald-d);text-decoration:none}
.cn-more:hover{text-decoration:underline}
.cn-other{margin:30px 0 0;padding:16px 0 0;border-top:1px solid var(--line);font-size:14px;color:var(--muted);line-height:2}
.cn-other b{color:var(--ink);font-weight:600;margin-right:8px}
.cn-other a{margin-right:16px;color:var(--emerald-d);white-space:nowrap}

/* 相談先・サービスを探す */
.consult{background:#fff}
.pr-note{font-size:12px;color:var(--muted);margin:0 0 16px;padding-left:13px}
.consult .grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cbtn{display:flex;align-items:center;justify-content:space-between;gap:8px;text-decoration:none;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:14px 15px;font-size:15.5px;font-weight:400;color:var(--ink);cursor:pointer}
.cbtn:hover{background:var(--emerald-t);border-color:var(--emerald)}
.cbtn .ar{color:var(--emerald);font-weight:600}
.consult .cnote{margin:16px 0 0;font-size:13px;color:var(--muted);padding-left:13px}

/* 編集部の考え方 */
.editor{background:var(--gray)}
.editor .box{background:#fff;border-left:4px solid var(--emerald);padding:22px 20px}
.editor h2{margin:0 0 10px;font-size:20px;color:var(--ink);font-weight:600}
.editor p{margin:0 0 14px;font-size:15.5px;color:#42463f;line-height:1.85}

/* フッター */
footer.site{background:var(--ink);color:#c4ccd3;padding:34px 0 28px}
footer .fbrand{font-size:18px;font-weight:600;color:#fff;margin:0 0 4px}
footer .fsub{font-size:13px;color:#98a3ad;margin:0 0 20px}
footer .site nav,footer.site nav{display:flex;flex-wrap:wrap;gap:10px 22px;margin-bottom:20px}
footer.site nav a{color:#c4ccd3;font-size:14px;text-decoration:none}
footer.site nav a:hover{color:#fff}
footer .copy{font-size:12px;color:#7c8893;border-top:1px solid #333a42;padding-top:16px}

/* ===== 記事ページ（single） ===== */
.article{padding-top:30px;padding-bottom:10px}
.crumbs{font-size:13px;color:var(--muted);margin:0 0 14px}
.crumbs a{color:var(--emerald-d)}
.a-cat{font-size:13px;color:var(--emerald-d);font-weight:600}
.a-title{font-size:26px;line-height:1.5;color:var(--ink);font-weight:600;margin:6px 0 10px}
.a-meta{font-size:13px;color:var(--muted);margin:0 0 18px;display:flex;gap:14px;flex-wrap:wrap}
.a-tags{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 22px}
.a-tags a{font-size:13px;color:var(--sky-d);background:var(--sky-t);border-radius:999px;padding:5px 12px;text-decoration:none}
.a-tags a:hover{background:#d6edf8;color:#0f6f95}
.entry{font-size:17px;line-height:1.95;color:var(--body)}
.entry h2{font-size:22px;color:var(--ink);font-weight:600;line-height:1.5;margin:40px 0 14px;padding-left:13px;position:relative}
.entry h2::before{content:"";position:absolute;left:0;top:.18em;bottom:.18em;width:4px;background:var(--emerald)}
.entry h3{font-size:19px;color:var(--emerald-d);font-weight:600;margin:30px 0 10px}
.entry p{margin:0 0 18px}
.entry ul,.entry ol{margin:0 0 18px;padding-left:1.4em}
.entry li{margin:0 0 7px}
.entry a{color:var(--emerald-d);text-decoration:underline}
.entry img{margin:18px 0}
.entry table{width:100%;border-collapse:collapse;margin:18px 0;font-size:15.5px}
.entry th,.entry td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line)}
.entry th{color:var(--ink);font-weight:600}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:18px 0;
	background:
		linear-gradient(to right, #fff 28%, rgba(255,255,255,0)) 0 0 / 26px 100% no-repeat,
		linear-gradient(to left, #fff 28%, rgba(255,255,255,0)) 100% 0 / 26px 100% no-repeat,
		radial-gradient(farthest-side at 0 50%, rgba(31,42,35,.13), rgba(31,42,35,0)) 0 0 / 12px 100% no-repeat,
		radial-gradient(farthest-side at 100% 50%, rgba(31,42,35,.13), rgba(31,42,35,0)) 100% 0 / 12px 100% no-repeat;
	background-attachment: local, local, scroll, scroll}
.entry .table-scroll{margin:18px 0}
.entry .table-scroll table{margin:0;min-width:560px;background:transparent}
.entry .table-scroll th,.entry .table-scroll td{white-space:nowrap}

/* 記事テーブルに色をつけて白い線で区切る（読みやすさ重視） */
.entry .table-scroll table{border-collapse:collapse}
.entry .table-scroll th{background:var(--sky-d);color:#fff;font-weight:600;border:2px solid #fff;padding:11px 14px}
.entry .table-scroll td{background:#EDF3F6;color:var(--body);border:2px solid #fff;padding:11px 14px}
.entry .table-scroll tr:nth-child(even) td{background:#F6FAFB}

/* 記事の目次 */
html{scroll-behavior:smooth}
.entry h2,.entry h3{scroll-margin-top:80px}
.nh-toc{background:var(--gray);border-left:4px solid var(--emerald);padding:16px 18px 16px 20px;margin:0 0 24px}
.nh-toc-ttl{margin:0 0 10px;font-weight:600;color:var(--ink);font-size:16px}
.nh-toc-list{list-style:none;margin:0;padding:0;counter-reset:toc}
.nh-toc-list li{margin:6px 0;line-height:1.55}
.nh-toc-list li.lv2{counter-increment:toc}
.nh-toc-list li.lv2>a::before{content:counter(toc) ". ";color:var(--emerald-d);font-weight:600}
.nh-toc-list li.lv3{margin-left:1.4em}
.nh-toc-list a{color:var(--body);text-decoration:none}
.nh-toc-list li.lv3 a{color:var(--muted);font-size:14.5px}
.nh-toc-list a:hover{color:var(--emerald-d);text-decoration:underline}
.entry blockquote{margin:18px 0;padding:4px 0 4px 16px;border-left:3px solid var(--line);color:var(--muted)}

/* 記事下ブロック共通 */
.blk{padding:26px 0}
.blk-ttl{font-size:19px;color:var(--ink);font-weight:600;margin:0 0 14px;padding-left:13px;position:relative}
.blk-ttl::before{content:"";position:absolute;left:0;top:.18em;bottom:.18em;width:4px;background:var(--emerald)}
.nextstep{display:grid;grid-template-columns:1fr;gap:12px}
.nsbtn{display:block;text-decoration:none;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:16px;color:var(--ink)}
.nsbtn:hover{border-color:var(--emerald);background:var(--emerald-t)}
.nsbtn b{display:block;font-size:16px;font-weight:600;margin-bottom:3px;color:var(--ink)}
.nsbtn span{font-size:13.5px;color:var(--muted)}

/* 商材カード（情報設計上わかりやすいので枠OKの例外） */
.offers{background:var(--gray);padding:26px 0}
.offers .pr{font-size:12px;color:var(--muted);margin:0 0 14px;padding-left:13px}
.offers .pr a{color:var(--emerald-d)}
.ocard{background:#fff;border:1px solid var(--line);border-left:4px solid var(--emerald);border-radius:var(--r);padding:18px;margin:0 0 14px}
.ocard .tag{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.06em;color:#fff;background:var(--emerald);border-radius:999px;padding:3px 10px;margin:0 0 8px}
.ocard h4{margin:0 0 6px;font-size:18px;color:var(--ink);font-weight:600}
.ocard .catch{font-size:14.5px;color:#444;margin:0 0 12px}
.ocard dl{margin:0 0 12px;display:grid;grid-template-columns:auto 1fr;gap:5px 12px;font-size:14px}
.ocard dt{color:var(--muted);white-space:nowrap}
.ocard dd{margin:0;color:var(--ink)}
.ocard .date{font-size:12px;color:var(--muted);margin:0 0 12px}
.ocard .cta{display:inline-flex;align-items:center;gap:6px}
.ocard-img{margin:0 0 12px}
.ocard-img img{width:100%;height:auto;max-height:180px;object-fit:cover;border-radius:6px;display:block}

/* 記事冒頭の結論（答え）ボックス：AEO/AIO/LLMO対策 */
.lead-answer{background:var(--emerald-t);border-left:4px solid var(--emerald);padding:16px 18px;margin:0 0 24px;border-radius:0 8px 8px 0}
.lead-answer .lab{display:block;font-size:12px;font-weight:600;letter-spacing:.06em;color:var(--emerald-d);margin-bottom:6px}
.lead-answer p{margin:0;font-size:16px;line-height:1.85;color:#2c4339}

/* 休息導線 */
.refresh{background:var(--sky-t);padding:24px 0}
.refresh .box{border-left:4px solid var(--sky);padding:4px 0 4px 16px}
.refresh h3{margin:0 0 8px;font-size:18px;color:var(--ink);font-weight:600}
.refresh p{margin:0 0 12px;font-size:15px;color:#3a4a4e}
.refresh ul{margin:0;padding-left:1.2em}
.refresh li{margin:0 0 6px}

/* FAQ */
.faq{padding:26px 0}
.faq .q{font-size:16px;color:var(--ink);font-weight:600;margin:18px 0 6px}
.faq .a{font-size:15px;color:var(--body);margin:0}

/* アーカイブ（カテゴリページ） */
.arch-head{background:var(--gray);padding:34px 0}
.arch-head h1{margin:0 0 8px;font-size:26px;color:var(--ink);font-weight:600}
.arch-head p{margin:0;color:var(--muted);font-size:15px}
.arch-img{margin:0 0 16px;border-radius:10px;overflow:hidden;max-height:260px}
.arch-img img{width:100%;height:auto;max-height:260px;object-fit:cover;display:block}
.grid-cards{display:grid;grid-template-columns:1fr;gap:20px}
.pagenav{margin:30px 0 0;display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.pagenav .page-numbers{display:inline-flex;min-width:40px;height:40px;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:var(--r);color:var(--ink);text-decoration:none;padding:0 10px}
.pagenav .page-numbers.current{background:var(--emerald);color:#fff;border-color:var(--emerald)}

/* 商品詳細ページ /item/ */
.item-head h1{font-size:25px;color:var(--ink);font-weight:600;margin:6px 0 10px}
.item-img{aspect-ratio:16/9;background:var(--gray-2);overflow:hidden;margin:0 0 18px}
.item-img img{width:100%;height:100%;object-fit:cover}
.item dl{display:grid;grid-template-columns:auto 1fr;gap:8px 14px;margin:18px 0;font-size:15.5px}
.item dt{color:var(--muted);white-space:nowrap}
.item dd{margin:0;color:var(--ink)}

/* 検索フォーム */
.searchform{display:flex;gap:8px;max-width:520px}
.searchform input[type=search]{flex:1;font:inherit;font-size:16px;padding:11px 14px;border:1px solid var(--line);border-radius:var(--r)}
.searchform button{font:inherit;font-weight:600;padding:11px 18px;border:none;border-radius:var(--r);background:var(--emerald);color:#fff;cursor:pointer}

/* WordPress 標準クラス（最小） */
.alignleft{float:left;margin:6px 18px 12px 0}
.alignright{float:right;margin:6px 0 12px 18px}
.aligncenter{margin:6px auto;display:block}
.wp-caption-text{font-size:13px;color:var(--muted)}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* レスポンシブ（PC） */
@media(min-width:760px){
  body{font-size:18px}
  .sec{padding:56px 0}
  .sec-ttl{font-size:27px}
  .cslide{width:46%}
  .cnav{display:flex}
  .worry .grid{grid-template-columns:repeat(3,1fr);gap:12px}
  .wbtn{font-size:17px;padding:16px}
  .catgrid{grid-template-columns:1fr 1fr;gap:18px}
  .alist{display:grid;grid-template-columns:1fr 1fr;gap:26px 30px}
  .acard{grid-template-columns:150px 1fr}
  .cn-grid{grid-template-columns:1fr 1fr}
  .consult .grid{grid-template-columns:repeat(3,1fr)}
  .nextstep{grid-template-columns:repeat(3,1fr)}
  .grid-cards{grid-template-columns:repeat(2,1fr);gap:26px 30px}
  .a-title{font-size:30px}
  .entry{max-width:none}
}
@media(min-width:1000px){
  .cslide{width:43%}
  .worry .grid{grid-template-columns:repeat(4,1fr)}
  .cn-grid{grid-template-columns:repeat(3,1fr)}
  .grid-cards{grid-template-columns:repeat(3,1fr)}
}
@media(prefers-reduced-motion:reduce){ .track{transition:none} }
