/* =====================================================================
   コレ買い！ — 目利き / The Curator's Stamp
   配色: 実りの夕 (Harvest Jewel) — クリーム × 濃茶紫 × 黄金 × 朱赤 × ワイン
   引き算・余白の締め・判子モチーフ。共通デザインシステム（全6ページ）
   ===================================================================== */

@import url("https://fonts.googleapis.com/css2?family=Shippori+Mincho+B1:wght@500;700;800&family=Fraunces:opsz,wght@9..144,400;9..144,600;9..144,900&family=Noto+Sans+JP:wght@400;500;700&display=swap");

:root{
  /* palette — Harvest Jewel */
  --paper:#FAF3E8;          /* base canvas (cream) */
  --paper-2:#F3E9D6;        /* deeper warm panel */
  --ink:#2A1520;            /* body / headings (deep brown-plum) */
  --ink-soft:#6E5A52;       /* secondary text */
  --shu:#C2351A;            /* accent (AA): links / buttons / small accents */
  --shu-bright:#E0431F;     /* vivid accent: seal / large display em / stat */
  --gold:#FFB22E;           /* main warm: on-dark figures / highlighter / underline */
  --wine:#7A2540;           /* 締め: dark section bg / deep accents */
  --teal:#1F7A6B;           /* 差し色 (small only) */
  --line:#E7DAC6;           /* hairlines on cream */
  --white:#FFFFFF;

  --max:1080px;
  --gut:26px;

  --f-disp:"Shippori Mincho B1",serif;
  --f-lat:"Fraunces",serif;
  --f-body:"Noto Sans JP",sans-serif;

  --r:3px;
  --ease:cubic-bezier(.2,.7,.3,1);
  --shadow:0 14px 40px -20px rgba(42,21,32,.34);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--f-body);
  font-weight:400;
  line-height:1.85;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{background:var(--shu);color:#fff}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--gut)}
.lat{font-family:var(--f-lat)}

/* ---------------------------------------------------------------
   judge's seal (判子)
   --------------------------------------------------------------- */
.seal{
  display:inline-grid;place-items:center;
  width:1.7em;height:1.7em;border-radius:50%;
  background:var(--shu-bright);color:#fff;
  font-family:var(--f-disp);font-weight:800;
  font-size:1em;line-height:1;
  box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.4), 0 6px 18px -6px rgba(224,67,31,.6);
  transform:rotate(-6deg);
  flex-shrink:0;
}
.pcard__seal{font-size:17px}
.sent .seal{font-size:34px}

/* ---------------------------------------------------------------
   eyebrow / section index
   --------------------------------------------------------------- */
.eyebrow{
  font-family:var(--f-lat);
  font-size:12px;font-weight:600;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--shu);
  display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--shu)}
.eyebrow .jp{font-family:var(--f-body);letter-spacing:.1em;color:var(--ink-soft);font-weight:500}

/* ---------------------------------------------------------------
   headings + Japanese line-break safety
   --------------------------------------------------------------- */
h1,h2,h3{font-family:var(--f-disp);color:var(--ink);line-height:1.34;font-weight:700;word-break:keep-all;overflow-wrap:anywhere}
.h-sec{font-size:clamp(28px,4.4vw,46px);font-weight:800;line-height:1.26;text-wrap:balance}
.lead{font-size:clamp(15px,1.7vw,17px);color:var(--ink-soft);line-height:2;max-width:38em;word-break:keep-all;overflow-wrap:anywhere;text-wrap:pretty}

/* ---------------------------------------------------------------
   buttons / links
   --------------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--f-body);font-weight:700;font-size:14.5px;
  padding:15px 28px;border-radius:100px;border:1.5px solid transparent;
  cursor:pointer;transition:background .25s var(--ease),color .25s,border-color .25s,transform .25s var(--ease);
}
.btn .arw{transition:transform .3s var(--ease)}
.btn:hover .arw{transform:translateX(5px)}
.btn--shu{background:var(--shu);color:#fff}
.btn--shu:hover{background:#a62d14}
.btn--line{background:transparent;color:var(--ink);border-color:rgba(42,21,32,.24)}
.btn--line:hover{border-color:var(--shu);color:var(--shu)}
.btn--oninK{background:var(--gold);color:var(--ink)}
.btn--oninK:hover{background:#ffc154}
.btn--oninK.ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn--oninK.ghost:hover{background:#fff;color:var(--ink)}

.txtlink{
  display:inline-flex;align-items:center;gap:.5em;
  font-weight:700;font-size:14.5px;color:var(--shu);
  padding-bottom:2px;background:linear-gradient(var(--shu),var(--shu)) 0 100%/0 1.5px no-repeat;
  transition:background-size .3s var(--ease);
}
.txtlink .arw{transition:transform .3s var(--ease)}
.txtlink:hover{background-size:100% 1.5px}
.txtlink:hover .arw{transform:translateX(4px)}

/* ---------------------------------------------------------------
   header
   --------------------------------------------------------------- */
.hdr{position:sticky;top:0;z-index:100;background:rgba(250,243,232,.88);backdrop-filter:saturate(150%) blur(10px);border-bottom:1px solid var(--line)}
.hdr__in{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:11px}
.brand__seal{font-family:var(--f-disp);font-weight:800;color:#fff;background:var(--shu-bright);width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-size:17px;transform:rotate(-6deg);box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.4)}
.brand__name{font-family:var(--f-disp);font-weight:800;font-size:20px;letter-spacing:.02em}
.brand__name .ex{color:var(--shu)}
.nav{display:flex;align-items:center;gap:30px}
.nav a{font-size:13.5px;font-weight:500;color:var(--ink-soft);position:relative;padding:6px 0;transition:color .2s}
.nav a:hover{color:var(--ink)}
.nav a.is-active{color:var(--ink)}
.nav a.is-active::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:2px;background:var(--shu)}
.hdr__cta{display:inline-flex}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);transition:.3s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile{display:none;border-top:1px solid var(--line);background:var(--paper)}
.mobile.show{display:block}
.mobile a{display:block;padding:16px var(--gut);font-size:16px;font-family:var(--f-disp);font-weight:700;border-bottom:1px solid var(--line)}
.mobile .btn{margin:18px var(--gut)}

/* ---------------------------------------------------------------
   section scaffolding
   --------------------------------------------------------------- */
.sec{padding:clamp(56px,8vw,96px) 0}
.sec--paper2{background:var(--paper-2)}
.sec--ink{background:var(--ink);color:#fff}
.sec--wine{background:var(--wine);color:#fff}
.sec--ink h1,.sec--ink h2,.sec--ink h3,.sec--wine h1,.sec--wine h2,.sec--wine h3{color:#fff}
.sec--ink .lead,.sec--wine .lead{color:rgba(255,255,255,.72)}
.sec--ink .eyebrow,.sec--wine .eyebrow{color:var(--gold)}
.sec--ink .eyebrow::before,.sec--wine .eyebrow::before{background:var(--gold)}
.sec--ink .eyebrow .jp,.sec--wine .eyebrow .jp{color:rgba(255,255,255,.55)}
.sec__head{max-width:660px;margin-bottom:clamp(36px,5vw,60px)}
.sec__head .h-sec{margin-top:18px}
.sec__head .lead{margin-top:18px}

/* page header (subpage hero) */
.phead{padding:clamp(56px,8vw,96px) 0 clamp(26px,4vw,40px);border-bottom:1px solid var(--line);background:linear-gradient(180deg,var(--paper),var(--paper-2))}
.phead .h-sec{margin-top:16px;font-size:clamp(32px,5.2vw,56px)}
.phead .lead{margin-top:20px}

/* ---------------------------------------------------------------
   hero (home) — centered editorial head + full-width specimen strip
   --------------------------------------------------------------- */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%)}
.hero__wrap{padding:clamp(44px,6.5vw,80px) var(--gut) clamp(44px,6vw,72px)}
.hero__head{max-width:880px;margin:0 auto;text-align:center}
.hero__eyebrow{margin-bottom:22px}
.hero__eyebrow .seal{font-size:18px;margin-right:2px}
.hero__title{font-family:var(--f-disp);font-weight:800;font-size:clamp(34px,6vw,66px);line-height:1.26;letter-spacing:.01em;word-break:keep-all;overflow-wrap:anywhere;text-wrap:balance}
.hero__title .ln{display:block}
.hero__title em{font-style:normal;color:var(--shu-bright);position:relative;z-index:0}
.hero__title em::after{content:"";position:absolute;left:-.02em;right:-.02em;bottom:.08em;height:.16em;background:var(--gold);border-radius:3px;z-index:-1}
.hero__lead{margin:26px auto 0;text-align:center;max-width:32em;color:var(--ink-soft)}
.hero__lead strong{color:var(--ink);font-weight:700;background:linear-gradient(transparent 62%, color-mix(in srgb,var(--gold) 70%,transparent) 0)}
.hero__cta{display:flex;justify-content:center;flex-wrap:wrap;gap:14px;margin-top:32px}

/* hero feature photo band */
.hero__photo{position:relative;margin-top:clamp(36px,4.5vw,56px);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:16/7}
.hero__photo img{width:100%;height:100%;object-fit:cover;display:block}
.hero__photo .cap{position:absolute;inset:auto 0 0 0;display:flex;align-items:center;gap:12px;padding:18px 22px;background:linear-gradient(transparent,rgba(42,21,32,.74));color:#fff;font-family:var(--f-disp);font-weight:700;font-size:14px}
.hero__photo .cap .seal{font-size:24px;margin-left:auto;flex-shrink:0}

/* on-the-ground photo gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gframe{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3;margin:0}
.gframe img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .55s var(--ease)}
.gframe:hover img{transform:scale(1.05)}
.gframe figcaption{position:absolute;inset:auto 0 0 0;padding:14px 15px;background:linear-gradient(transparent,rgba(42,21,32,.76));color:#fff;font-family:var(--f-disp);font-weight:700;font-size:13.5px;display:flex;flex-direction:column;gap:3px}
.gframe figcaption .pl{font-family:var(--f-lat);font-weight:600;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}

/* ---------------------------------------------------------------
   single big stat (wine band, gold figure)
   --------------------------------------------------------------- */
.stat{display:flex;align-items:center;gap:clamp(20px,4vw,52px);flex-wrap:wrap}
.stat__num{font-family:var(--f-lat);font-weight:900;font-size:clamp(72px,13vw,150px);line-height:.86;color:var(--gold)}
.stat__unit{font-family:var(--f-lat);font-weight:900;font-size:clamp(30px,5vw,54px);color:var(--gold)}
.stat__cap{flex:1 1 380px;max-width:660px}
.stat__cap .t{font-family:var(--f-disp);font-weight:700;font-size:clamp(18px,2.4vw,25px);line-height:1.5;color:#fff;text-wrap:balance}
.stat__cap .d{color:rgba(255,255,255,.72);font-size:14px;margin-top:12px}
.src{font-family:var(--f-lat);font-size:11px;color:rgba(255,255,255,.5);margin-top:14px;letter-spacing:.02em}

/* ---------------------------------------------------------------
   doors (home 3 entrances)
   --------------------------------------------------------------- */
.doors{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.door{background:var(--paper);padding:36px 30px 32px;display:flex;flex-direction:column;min-height:218px;transition:background .3s var(--ease)}
.door:hover{background:var(--white)}
.door__no{font-family:var(--f-lat);font-weight:900;font-size:15px;color:var(--shu)}
.door h3{font-size:23px;margin:auto 0 12px;font-weight:800}
.door p{font-size:13.5px;color:var(--ink-soft);line-height:1.75;margin-bottom:18px}
.door .go{font-size:24px;color:var(--shu);transition:transform .3s var(--ease)}
.door:hover .go{transform:translateX(8px)}

/* ---------------------------------------------------------------
   mini point row (home trust summary)
   --------------------------------------------------------------- */
.points{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-top:36px}
.point{background:var(--paper);padding:24px 22px}
.point .k{display:flex;align-items:center;gap:9px;font-family:var(--f-disp);font-weight:800;font-size:16px}
.point .k .seal{font-size:13px}
.point p{font-size:12.5px;color:var(--ink-soft);margin-top:10px;line-height:1.7}

/* ---------------------------------------------------------------
   steps (method 3STEP)
   --------------------------------------------------------------- */
.steps{display:grid;gap:0}
.stepr{display:grid;grid-template-columns:120px 1fr;gap:36px;padding:36px 0;border-top:1px solid var(--line)}
.stepr:last-child{border-bottom:1px solid var(--line)}
.stepr__n{font-family:var(--f-lat);font-weight:900;font-size:clamp(52px,7vw,84px);color:var(--shu);line-height:.9}
.stepr__en{font-family:var(--f-lat);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft)}
.stepr h3{font-size:24px;font-weight:800;margin:8px 0 12px}
.stepr p{color:var(--ink-soft);font-size:14.5px;max-width:44em}

/* ---------------------------------------------------------------
   value list (data return / responsibility)
   --------------------------------------------------------------- */
.vlist{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.vitem{background:var(--paper);padding:28px 28px}
.sec--ink .vlist,.sec--wine .vlist{background:rgba(255,255,255,.16)}
.sec--ink .vitem{background:var(--ink)}
.sec--wine .vitem{background:var(--wine)}
.vitem .k{display:flex;align-items:center;gap:10px;font-family:var(--f-disp);font-weight:800;font-size:18px}
.vitem .k .seal{font-size:.8em;background:var(--gold);color:var(--ink)}
.vitem p{color:var(--ink-soft);font-size:13.5px;margin-top:12px;line-height:1.75}
.sec--ink .vitem p,.sec--wine .vitem p{color:rgba(255,255,255,.68)}

/* ---------------------------------------------------------------
   members
   --------------------------------------------------------------- */
.members{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.member{padding-top:22px;border-top:2px solid var(--ink)}
.member .role{font-family:var(--f-lat);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--shu);font-weight:600}
.member .nm{font-family:var(--f-disp);font-weight:800;font-size:21px;margin:12px 0 4px}
.member .af{font-size:12.5px;color:var(--ink-soft)}
.member.lead{border-top-color:var(--shu)}

/* ---------------------------------------------------------------
   products (取扱事例)
   --------------------------------------------------------------- */
.callout{display:flex;gap:14px;align-items:flex-start;background:var(--white);border:1px solid var(--line);border-left:3px solid var(--shu);border-radius:var(--r);padding:18px 22px;font-size:13.5px;color:var(--ink-soft);margin-bottom:44px}
.callout b{color:var(--ink)}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.pcard{display:flex;flex-direction:column}
.pcard__img{aspect-ratio:4/5;background:var(--paper-2);border-radius:var(--r);position:relative;overflow:hidden;display:grid;place-items:center}
.pcard__img::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,transparent,transparent 18px,rgba(42,21,32,.03) 18px,rgba(42,21,32,.03) 19px)}
.pcard__img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.pcard__ph{font-family:var(--f-lat);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);z-index:1}
.pcard__seal{position:absolute;top:14px;right:14px;z-index:2}
.pcard__b{padding-top:18px}
.pcard .area{font-family:var(--f-lat);font-size:11px;letter-spacing:.1em;color:var(--shu);font-weight:600;text-transform:uppercase}
.pcard h3{font-size:21px;font-weight:800;margin:8px 0 8px}
.pcard p{font-size:13.5px;color:var(--ink-soft);line-height:1.7;min-height:3.4em}
.pcard__foot{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding-top:16px;border-top:1px solid var(--line)}

/* status tag */
.tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--f-lat);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:100px}
.tag--live{background:var(--shu);color:#fff}
.tag--src{background:transparent;color:var(--ink);border:1px solid rgba(42,21,32,.3)}
.tag .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.tag--live .dot{background:#fff;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

/* ---------------------------------------------------------------
   producers flow
   --------------------------------------------------------------- */
.flow{display:flex;align-items:center;gap:18px;flex-wrap:wrap;font-family:var(--f-disp);font-weight:800;font-size:clamp(18px,2.6vw,26px)}
.flow .ar{color:var(--shu);font-family:var(--f-lat);font-weight:900}
.do-list{display:grid;grid-template-columns:repeat(2,1fr);gap:24px 40px;margin-top:8px}
.do-item{border-top:1px solid var(--line);padding-top:18px}
.do-item h3{font-size:18px;font-weight:800;display:flex;gap:10px;align-items:baseline}
.do-item .i{font-family:var(--f-lat);font-weight:900;color:var(--shu);font-size:15px}
.do-item p{color:var(--ink-soft);font-size:13.5px;margin-top:8px}

/* ---------------------------------------------------------------
   forms (contact)
   --------------------------------------------------------------- */
.form{display:grid;gap:24px;max-width:600px}
.field label{display:block;font-weight:700;font-size:13.5px;margin-bottom:9px}
.field label .req{color:var(--shu)}
.field input,.field textarea,.field select{
  width:100%;background:var(--white);border:1px solid var(--line);border-radius:var(--r);
  padding:14px 16px;font-family:var(--f-body);font-size:15px;color:var(--ink);
  transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--shu);box-shadow:0 0 0 3px rgba(194,53,26,.14)}
.field textarea{resize:vertical;min-height:140px;line-height:1.8}
.radios{display:grid;gap:10px}
.radio{display:flex;gap:11px;align-items:flex-start;background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:13px 16px;cursor:pointer;font-size:14px;transition:border-color .2s}
.radio:hover{border-color:var(--shu)}
.radio input{width:auto;margin-top:5px;accent-color:var(--shu)}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--ink-soft)}
.consent input{accent-color:var(--shu);margin-top:4px}
.form__note{font-size:12px;color:var(--ink-soft);margin-top:6px}
.sent{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:46px 30px;text-align:center}
.sent .seal{margin:0 auto 18px}
.sent h3{font-size:24px;font-weight:800;margin-bottom:10px}
.sent p{color:var(--ink-soft);font-size:14px}

/* ---------------------------------------------------------------
   CTA band (pre-footer) — wine
   --------------------------------------------------------------- */
.cta-band{background:var(--wine);color:#fff;text-align:center;padding:clamp(60px,8vw,96px) 0}
.cta-band h2{color:#fff;font-size:clamp(26px,4vw,42px);font-weight:800;max-width:20ch;margin:0 auto 26px;word-break:keep-all;overflow-wrap:anywhere;text-wrap:balance;line-height:1.4}
.cta-band h2 em{font-style:normal;color:var(--gold)}

/* ---------------------------------------------------------------
   footer
   --------------------------------------------------------------- */
.ft{background:var(--ink);color:rgba(255,255,255,.72);padding:62px 0 32px}
.ft__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.ft__brand .row{display:flex;align-items:center;gap:11px}
.ft__brand .nm{font-family:var(--f-disp);font-weight:800;font-size:21px;color:#fff}
.ft__brand .nm .ex{color:var(--gold)}
.ft__brand .mi{font-family:var(--f-disp);color:#fff;font-size:15px;margin-top:18px;line-height:1.7;max-width:22ch}
.ft__entity{margin-top:20px;display:grid;grid-template-columns:auto 1fr;gap:7px 16px;font-size:12px}
.ft__entity dt{color:rgba(255,255,255,.5);font-family:var(--f-lat);font-size:10px;letter-spacing:.1em;text-transform:uppercase;align-self:center}
.ft__entity dd{color:rgba(255,255,255,.86)}
.ft__col h4{font-family:var(--f-lat);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:16px}
.ft__col a{display:block;font-size:13.5px;padding:6px 0;color:rgba(255,255,255,.78);transition:color .2s}
.ft__col a:hover{color:var(--gold)}
.ft__notice{border-top:1px solid rgba(255,255,255,.14);margin-top:46px;padding-top:22px;font-size:11.5px;color:rgba(255,255,255,.5);line-height:1.85;max-width:62ch}
.ft__copy{margin-top:16px;font-family:var(--f-lat);font-size:11px;color:rgba(255,255,255,.4);letter-spacing:.04em}

/* ---------------------------------------------------------------
   reveal
   --------------------------------------------------------------- */
.rv{opacity:0;transform:translateY(14px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rv.in{opacity:1;transform:none}
.d1{transition-delay:.09s}.d2{transition-delay:.18s}.d3{transition-delay:.27s}.d4{transition-delay:.36s}

/* hero load animation (balanced, full-width) */
@media (prefers-reduced-motion:no-preference){
  .hero__eyebrow{opacity:0;animation:fadeUp .8s var(--ease) .05s forwards}
  .hero__title .ln{opacity:0;animation:fadeUp .9s var(--ease) forwards}
  .hero__title .ln:nth-child(1){animation-delay:.16s}
  .hero__title .ln:nth-child(2){animation-delay:.30s}
  .hero__lead{opacity:0;animation:fadeUp .8s var(--ease) .48s forwards}
  .hero__cta{opacity:0;animation:fadeUp .8s var(--ease) .60s forwards}
  .hero__photo{opacity:0;animation:fadeUp .9s var(--ease) .55s forwards}
}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ---------------------------------------------------------------
   responsive
   --------------------------------------------------------------- */
@media(max-width:900px){
  .nav,.hdr__cta{display:none}
  .burger{display:flex}
  .doors{grid-template-columns:1fr}
  .points{grid-template-columns:1fr 1fr}
  .members{grid-template-columns:1fr 1fr}
  .vlist{grid-template-columns:1fr}
  .pgrid{grid-template-columns:1fr 1fr}
  .ft__top{grid-template-columns:1fr 1fr}
  .stepr{grid-template-columns:1fr;gap:8px}
}
@media(max-width:560px){
  .gallery{grid-template-columns:1fr}
  .points,.members,.pgrid,.do-list{grid-template-columns:1fr}
  .ft__top{grid-template-columns:1fr}
  .stat{gap:14px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .rv{opacity:1;transform:none}
  html{scroll-behavior:auto}
}
