/* ============================================================
   "Stardust Notebook" — light theme
   ============================================================ */

:root{
  /* color: paper */
  --cream:#FAF6EB;
  --cream-2:#F2EBD9;
  --cream-3:#E8DFC8;
  --shade:#D8CFB6;
  /* color: ink */
  --ink:#2A2730;
  --ink-2:#4F4956;
  --ink-3:#6E6776;
  --ink-4:#A39CA8;
  /* color: accents */
  --rose:#D77A95;
  --rose-2:#B4546F;
  --rose-pale:#FBE8EE;
  --sage:#8AAE96;
  --sage-pale:#E5EFE7;
  --butter:#F2C95C;
  --butter-pale:#FBEBC2;
  --mauve:#A38AC4;
  --mauve-pale:#ECE3F4;
  --peach:#F4C4A1;
  --lilac:#DCC9E8;
  --mint:#C8E0CB;
  --sky:#B7D3E5;

  /* type */
  --f-disp-jp: "Hina Mincho", "Shippori Mincho", serif;
  --f-disp-en: "Fraunces", "DM Serif Display", serif;
  --f-jp: "Noto Sans JP", system-ui, sans-serif;
  --f-en: "DM Sans", "Helvetica Neue", sans-serif;
  --f-hand-jp: "Klee One", cursive;
  --f-hand-en: "Caveat", cursive;
  --f-italic: "Cormorant Garamond", serif;

  /* layout — fluid: smoothly grows from medium to ultra-wide */
  --maxw: clamp(1120px, 88vw, 1480px);
  --pad: clamp(20px, 3.6vw, 64px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-jp);font-weight:500;
  background:var(--cream);
  color:var(--ink);
  line-height:1.85;
  letter-spacing:.025em;
  overflow-x:hidden;
  font-feature-settings:"palt";
  -webkit-font-smoothing:antialiased;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

/* ----- background paper layers ----- */
.paper-rules{
  position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:repeating-linear-gradient(0deg, transparent 0 31px, rgba(42,39,48,.045) 31px 32px);
  mask-image:linear-gradient(to bottom, transparent 0, #000 80px, #000 calc(100% - 80px), transparent);
}
.paper-grain{
  position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.55;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' seed='3'/><feColorMatrix values='0 0 0 0 .1 0 0 0 0 .09 0 0 0 0 .12 0 0 0 .35 0'/></filter><rect width='220' height='220' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;
}
.paper-warm{
  position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 60% 40% at 80% 0%, rgba(247,196,161,.18), transparent 60%),
    radial-gradient(ellipse 60% 40% at 0% 70%, rgba(220,201,232,.16), transparent 60%),
    radial-gradient(ellipse 60% 40% at 100% 100%, rgba(200,224,203,.12), transparent 60%);
}

/* ----- floating stars (twinkle) ----- */
.sky{position:fixed;inset:0;pointer-events:none;z-index:1;overflow:hidden}
.star{
  position:absolute;color:var(--butter);opacity:.65;
  animation:twinkle var(--dur,3.4s) ease-in-out infinite;
  animation-delay:var(--d,0s);
  filter:drop-shadow(0 0 6px rgba(242,201,92,.4));
}
.star.s-rose{color:var(--rose);filter:drop-shadow(0 0 6px rgba(215,122,149,.45))}
.star.s-mauve{color:var(--mauve);filter:drop-shadow(0 0 6px rgba(163,138,196,.5))}
.star.s-sky{color:var(--sky);filter:drop-shadow(0 0 6px rgba(183,211,229,.5))}
@keyframes twinkle{
  0%,100%{opacity:.25;transform:scale(.7) rotate(0deg)}
  50%{opacity:.95;transform:scale(1.1) rotate(8deg)}
}

/* shooting star */
.shooting{
  position:absolute;width:160px;height:1.5px;
  background:linear-gradient(to right,transparent,var(--mauve) 70%,var(--rose));
  opacity:0;
  animation:shoot 14s ease-in infinite;
  animation-delay:var(--sd,3s);
  border-radius:3px;
}
.shooting::after{
  content:"";position:absolute;right:-3px;top:-3px;
  width:8px;height:8px;border-radius:50%;background:var(--rose);
  box-shadow:0 0 10px var(--rose),0 0 20px rgba(215,122,149,.4);
}
@keyframes shoot{
  0%{opacity:0;transform:translate(0,0) rotate(20deg)}
  3%{opacity:1}
  10%{opacity:0;transform:translate(420px,160px) rotate(20deg)}
  100%{opacity:0;transform:translate(420px,160px) rotate(20deg)}
}

/* ----- shared utilities ----- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad);position:relative;z-index:3}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--f-italic);font-style:italic;font-size:18px;color:var(--rose);letter-spacing:.02em;
}
.eyebrow::before{content:"";width:32px;height:1.5px;background:var(--rose);border-radius:2px}
.eyebrow .num{font-family:var(--f-en);font-style:normal;font-size:12px;color:var(--ink-3);letter-spacing:.18em;text-transform:uppercase}

h1,h2,h3{font-family:var(--f-disp-jp);font-weight:400;line-height:1.35;letter-spacing:.005em;color:var(--ink)}
.section{padding:clamp(40px,5vw,70px) 0;position:relative}
.section-title{
  font-size:clamp(28px,4.5vw,52px);margin:14px 0 .5em;line-height:1.4;
}
/* about.html — ミッションのh2は1行に収めて縦幅を節約 */
#mission .section-title{
  font-size:clamp(24px,3.4vw,44px);
  line-height:1.3;
  letter-spacing:-.005em;
  white-space:nowrap;
}
@media(max-width:880px){
  #mission .section-title{
    white-space:normal;
    font-size:clamp(22px,4.5vw,32px);
    line-height:1.35;
  }
}
.section-sub{font-size:16.5px;color:var(--ink-2);line-height:2;font-family:var(--f-jp);font-weight:400}

/* hand-drawn underline span */
.hl{position:relative;display:inline-block;color:var(--rose-2);white-space:nowrap}
.hl svg{position:absolute;left:-2%;right:-2%;bottom:-.18em;width:104%;height:.45em;overflow:visible}
.hl svg path{fill:none;stroke:var(--rose);stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.hl.sage{color:var(--sage)} .hl.sage svg path{stroke:var(--sage)}
.hl.mauve{color:var(--mauve)} .hl.mauve svg path{stroke:var(--mauve)}
.hl.butter{color:#9B7A12} .hl.butter svg path{stroke:var(--butter);stroke-width:5}

/* hand-drawn arrow */
.arrow{display:inline-block;color:var(--ink-3);width:42px;vertical-align:middle}
.arrow path{fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round}

/* margin doodle / sticky note */
.doodle{
  font-family:var(--f-hand-jp);color:var(--rose-2);
  font-size:16px;letter-spacing:.04em;line-height:1.6;
  display:inline-flex;align-items:center;gap:6px;
}

/* ----- buttons ----- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--f-jp);font-weight:700;font-size:15.5px;letter-spacing:.06em;
  padding:14px 26px;border-radius:999px;
  transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s,background .25s;
  position:relative;
}
.btn .mark{font-family:var(--f-en);font-weight:500;font-size:12.5px;opacity:.75;letter-spacing:.06em}
.btn-primary{
  background:var(--rose);color:#fff;
  box-shadow:0 1px 2px rgba(180,84,111,.2),0 14px 28px -10px rgba(215,122,149,.5);
}
.btn-primary:hover{transform:translateY(-2px) rotate(-.5deg);background:var(--rose-2);box-shadow:0 1px 2px rgba(180,84,111,.3),0 18px 32px -10px rgba(180,84,111,.55)}
.btn-ghost{
  border:1.5px solid var(--ink);color:var(--ink);background:rgba(255,255,255,.5);
}
.btn-ghost:hover{background:#fff;transform:translateY(-1px) rotate(.4deg)}
.btn-ghost .play{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;background:var(--ink);color:var(--cream);font-size:9px;
}
.btn-soft{
  background:var(--cream-2);color:var(--ink);border:1.5px dashed var(--ink-3);
}
.btn-soft:hover{background:var(--butter-pale);transform:rotate(-1deg)}

/* sparkle on hover */
.btn-primary::after{
  content:"✦";position:absolute;top:-10px;right:-2px;color:var(--butter);font-size:15px;
  opacity:0;transition:all .4s;
}
.btn-primary:hover::after{opacity:1;transform:translate(4px,-4px) rotate(20deg);text-shadow:0 0 8px var(--butter)}

/* ============================================================
   washi tape
   ============================================================ */
.washi{
  position:absolute;width:96px;height:22px;
  background-image:
    repeating-linear-gradient(45deg,rgba(255,255,255,.22) 0 6px,transparent 6px 12px),
    linear-gradient(135deg,var(--peach),#F0AD80);
  background-blend-mode:overlay;
  opacity:.86;
  -webkit-mask-image:linear-gradient(to right,transparent 0,#000 6px,#000 calc(100% - 6px),transparent);
  mask-image:linear-gradient(to right,transparent 0,#000 6px,#000 calc(100% - 6px),transparent);
  box-shadow:0 1px 2px rgba(42,39,48,.08);
  z-index:2;
}
.washi.lilac{background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.22) 0 6px,transparent 6px 12px),linear-gradient(135deg,var(--lilac),#C7AEDA)}
.washi.mint{background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.22) 0 6px,transparent 6px 12px),linear-gradient(135deg,var(--mint),#A5C9AB)}
.washi.rose{background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.22) 0 6px,transparent 6px 12px),linear-gradient(135deg,var(--rose-pale),var(--rose))}
.washi.butter{background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.22) 0 6px,transparent 6px 12px),linear-gradient(135deg,var(--butter-pale),var(--butter))}
.washi.sage{background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.22) 0 6px,transparent 6px 12px),linear-gradient(135deg,var(--sage-pale),var(--sage))}
.washi.mauve{background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.22) 0 6px,transparent 6px 12px),linear-gradient(135deg,var(--mauve-pale),var(--mauve))}

/* ============================================================
   placeholder for nano banana
   ============================================================ */
.ph{
  position:relative;background:var(--cream-2);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  gap:6px;color:var(--ink-3);font-family:var(--f-en);font-size:12px;
  letter-spacing:.18em;text-transform:uppercase;overflow:hidden;
  background-image:
    repeating-linear-gradient(135deg,rgba(42,39,48,.045) 0 2px,transparent 2px 12px),
    linear-gradient(135deg,var(--cream-2),var(--cream-3));
}
.ph::before,.ph::after{
  content:"";position:absolute;width:18px;height:18px;border:1.5px solid var(--ink-3);
}
.ph::before{top:10px;left:10px;border-right:0;border-bottom:0}
.ph::after{bottom:10px;right:10px;border-left:0;border-top:0}
.ph .ph-key{font-family:var(--f-en);font-weight:700;font-size:14px;letter-spacing:.16em;color:var(--rose-2);text-align:center;padding:0 14px;z-index:1}
.ph .ph-hint{font-family:var(--f-jp);font-weight:500;font-size:12.5px;letter-spacing:.04em;color:var(--ink-2);text-transform:none;padding:0 16px;text-align:center;line-height:1.6;max-width:90%}
.ph .ph-tag{position:absolute;top:14px;right:14px;font-size:9.5px;color:var(--sage);letter-spacing:.2em;font-family:var(--f-en);font-weight:700}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:sticky;top:0;z-index:40;
  background:rgba(250,246,235,.75);
  backdrop-filter:blur(14px);
  border-bottom:1px dashed var(--cream-3);
}
.nav-inner{
  max-width:var(--maxw);margin-inline:auto;padding:14px var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:baseline;gap:12px}
.brand-jp{font-family:var(--f-disp-jp);font-size:22px;color:var(--ink);letter-spacing:.04em}
.brand-logo{height:48px;width:auto;display:block}
.brand-en{font-family:var(--f-italic);font-style:italic;font-size:15px;color:var(--rose-2)}
.nav-links{display:flex;gap:24px;align-items:center;font-size:14.5px}
.nav-links a{color:var(--ink-2);position:relative;padding:6px 0;transition:color .2s}
.nav-links a:hover{color:var(--rose-2)}
.nav-links a.cta-mini{
  color:#fff;background:var(--rose);padding:9px 18px;border-radius:999px;font-weight:700;
  box-shadow:0 6px 14px -6px rgba(215,122,149,.6);
}
.nav-links a.cta-mini:hover{background:var(--rose-2);transform:rotate(-1deg)}

/* social icon group */
.nav-social{
  display:inline-flex;align-items:center;gap:2px;
  padding-left:6px;margin-left:2px;
  border-left:1px dashed var(--cream-3);
}
.nav-social .social-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:9px;
  color:var(--ink-2);
  transition:color .25s ease,background .25s ease,transform .25s cubic-bezier(.2,.8,.2,1);
}
.nav-social .social-icon svg{width:18px;height:18px;display:block}
.nav-social .social-icon:hover{
  color:var(--rose-2);
  background:var(--rose-pale);
  transform:translateY(-1px) rotate(-3deg);
}
.nav-social .social-icon:active{transform:translateY(0) rotate(0)}
.nav-social .social-icon:focus-visible{
  outline:2px solid var(--rose);outline-offset:2px;
}

@media(max-width:760px){
  .nav-link-text{display:none}
  .nav-links{gap:10px}
  .nav-social{padding-left:0;border-left:0}
  .nav-social .social-icon{width:30px;height:30px}
  .nav-social .social-icon svg{width:16px;height:16px}
  .brand{gap:8px}
  .brand-logo{height:36px}
  .brand-en{display:none}
}
@media(max-width:380px){
  .nav-social{gap:0}
  .nav-social .social-icon{width:28px;height:28px}
  .brand-logo{height:30px}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  padding:clamp(40px,7vw,80px) 0 clamp(80px,10vw,140px);
  position:relative;
  isolation:isolate;
}
.hero::before{
  content:"";
  position:absolute;
  top:0;bottom:0;right:0;left:42%;
  background:url('images/hero-bg.png') center right/cover no-repeat;
  opacity:.5;
  filter:blur(3px) saturate(.78) brightness(1.04);
  z-index:0;
  pointer-events:none;
  -webkit-mask-image:linear-gradient(to right, transparent 0%, rgba(0,0,0,.45) 30%, #000 65%);
          mask-image:linear-gradient(to right, transparent 0%, rgba(0,0,0,.45) 30%, #000 65%);
}
.hero::after{
  content:"";
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(ellipse 50% 70% at 78% 50%, rgba(250,246,235,.35) 0%, rgba(250,246,235,0) 60%),
    linear-gradient(to bottom, rgba(250,246,235,0) 80%, var(--cream,#FAF6EB) 100%);
}
@media(max-width:920px){
  .hero::before{
    left:0;right:0;top:0;bottom:auto;
    height:42vh;min-height:280px;max-height:480px;
    background-position:center 30%;
    background-size:cover;
    opacity:.42;
    filter:blur(2px) saturate(.82) brightness(1.05);
    -webkit-mask-image:linear-gradient(to bottom, #000 0%, rgba(0,0,0,.55) 55%, transparent 95%);
            mask-image:linear-gradient(to bottom, #000 0%, rgba(0,0,0,.55) 55%, transparent 95%);
  }
  .hero::after{
    background:
      linear-gradient(to bottom, rgba(250,246,235,0) 0%, rgba(250,246,235,.55) 35%, var(--cream,#FAF6EB) 55%);
  }
}
.hero-grid{
  display:grid;gap:clamp(32px,5vw,72px);
  grid-template-columns:1.05fr .95fr;
  align-items:center;position:relative;
}
@media(max-width:920px){.hero-grid{grid-template-columns:1fr}}

.hero-tag{
  display:inline-flex;gap:14px;align-items:center;flex-wrap:wrap;
  font-family:var(--f-en);font-size:12.5px;letter-spacing:.16em;color:var(--ink-3);text-transform:uppercase;
  margin-bottom:32px;
}
.hero-tag .pill{
  background:var(--cream-2);padding:6px 14px;border-radius:999px;
  border:1px solid var(--cream-3);
}
.hero-tag .pill b{color:var(--rose-2);font-weight:700}
.hero-tag .pill.live{background:var(--rose-pale);border-color:var(--rose-pale);color:var(--rose-2)}
.hero-tag .pill.live::before{content:"●";color:var(--rose);margin-right:5px;animation:twinkle 1.6s ease-in-out infinite}

.hero h1{
  font-family:var(--f-disp-jp);font-weight:400;
  font-size:clamp(38px,7.2vw,84px);line-height:1.32;color:var(--ink);
  letter-spacing:.01em;margin-bottom:.4em;
  position:relative;
}
.hero h1 .accent{position:relative;display:inline-block;color:var(--rose-2)}
.hero h1 small{
  display:block;font-family:var(--f-jp);font-weight:500;
  font-size:clamp(13px,1.5vw,16px);color:var(--ink-2);letter-spacing:.05em;
  margin-top:18px;line-height:1.9;
}

.hero-features{
  list-style:none;padding:0;margin:20px 0 28px;
  display:flex;flex-direction:column;gap:9px;
}
.hero-features li{
  font-family:var(--f-jp);font-size:clamp(14px,1.5vw,16px);
  color:var(--ink-2);padding-left:1.6em;position:relative;line-height:1.6;
}
.hero-features li::before{
  content:"◎";position:absolute;left:0;
  color:var(--rose);font-size:.85em;top:.1em;
}

.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

.hero-stats{
  margin-top:40px;
  display:flex;gap:36px;align-items:center;flex-wrap:wrap;
}
.stat{display:flex;flex-direction:column;gap:4px;position:relative}
.stat-num{
  font-family:var(--f-disp-en);font-style:italic;font-weight:700;
  font-size:clamp(36px,4.5vw,52px);color:var(--rose-2);line-height:1;letter-spacing:-.01em;
}
.stat-num small{font-family:var(--f-jp);font-style:normal;font-weight:500;color:var(--ink-2);font-size:.42em;margin-left:6px;letter-spacing:.04em}
.stat-label{font-family:var(--f-hand-jp);font-size:14px;color:var(--ink-3);letter-spacing:.04em;line-height:1.4;margin-top:4px}
.stat-divider{
  width:1px;height:42px;background:var(--cream-3);
}

/* hero visual right — scrapbook composition (fluid scaling, no hard breakpoints) */
.hero-visual{position:relative;height:100%;min-height:clamp(440px, 36vw, 640px)}
.photo-card{
  position:absolute;background:#fff;
  padding:14px 14px 56px;
  box-shadow:
    0 1px 2px rgba(0,0,0,.04),
    0 12px 28px -10px rgba(42,39,48,.18),
    0 28px 56px -20px rgba(42,39,48,.12);
  transition:transform .55s cubic-bezier(.2,.8,.2,1);
}
.photo-card .ph{aspect-ratio:4/5;width:100%}
.photo-card .photo-img{aspect-ratio:4/5;width:100%;display:block;object-fit:cover;border-radius:2px}
.voice .photo-card .photo-img{aspect-ratio:4/3}
.hero-pol-1 .photo-img,
.hero-pol-2 .photo-img,
.hero-pol-3 .photo-img{aspect-ratio:4/3;object-position:center 38%}
.hero-pol-3 .photo-img{object-position:center 50%}
.photo-card .cap{
  display:block;text-align:center;font-family:var(--f-hand-jp);font-size:15px;color:#3a3540;margin-top:14px;
  line-height:1.55;
}
.photo-card .cap em{font-style:normal;color:#7e7888;font-size:.78em;display:block;margin-top:2px;font-family:var(--f-en);letter-spacing:.08em}
.photo-card .stamp{
  position:absolute;bottom:10px;right:14px;
  font-family:var(--f-en);font-size:9.5px;color:var(--rose-2);letter-spacing:.16em;
  border:1px solid var(--rose-2);padding:3px 6px;border-radius:2px;
  transform:rotate(-3deg);background:rgba(255,255,255,.6);
}

.hero-pol-1{
  top:0;right:0;
  width:min(86%, clamp(330px, 32vw, 540px));
  transform:rotate(3.5deg);
}
.hero-pol-1 .washi{
  top:-12px;left:50%;
  transform:translateX(-50%) rotate(-2deg);
  width:clamp(96px, 7vw, 130px);
  height:clamp(18px, 1.4vw, 22px);
}
.hero-pol-1:hover{transform:rotate(0) translateY(-4px)}

.hero-pol-2{
  bottom:0;left:clamp(120px, 16vw, 220px);
  /* enlarged ~1.5× so the "外でも、測ってみる" frame reads clearly */
  width:min(80%, clamp(315px, 33vw, 540px));
  transform:rotate(-7deg);
  z-index:2;
}
.hero-pol-2 .washi{
  top:-10px;left:18px;
  transform:rotate(38deg);
  width:clamp(72px, 5.2vw, 96px);
  height:clamp(16px, 1.3vw, 22px);
}
.hero-pol-2:hover{transform:rotate(-2deg) translateY(-4px)}

/* hero-pol-3 — uvsor, sits behind & to the left of hero-pol-2 */
.hero-pol-3{
  bottom:clamp(40px, 5vw, 88px);
  left:0;
  /* enlarged ~1.5× so the "放射光で、当ててみる" frame reads clearly */
  width:min(68%, clamp(270px, 27vw, 420px));
  transform:rotate(-2deg);
  z-index:1;
}
.hero-pol-3 .washi{
  top:-10px;left:50%;
  transform:translateX(-50%) rotate(-6deg);
  width:clamp(80px, 5.6vw, 110px);
  height:clamp(16px, 1.3vw, 22px);
}
.hero-pol-3:hover{transform:rotate(0) translateY(-4px);z-index:3}

/* polaroid chrome (padding / cap / stamp) scales fluidly with viewport */
.hero-pol-1, .hero-pol-2, .hero-pol-3{
  padding:clamp(12px, .95vw, 18px) clamp(12px, .95vw, 18px) clamp(18px, 1.4vw, 26px);
}
.hero-pol-1 .cap, .hero-pol-2 .cap, .hero-pol-3 .cap{font-size:clamp(13px, .95vw, 16px)}
.hero-pol-1 .stamp{
  font-size:clamp(9.5px, .7vw, 11.5px);
  padding:clamp(3px, .25vw, 4px) clamp(6px, .55vw, 8px);
}

/* hero margin sticky note — fluid */
.hero-note{
  position:absolute;
  left:clamp(-48px, -1.6vw, -24px);
  bottom:clamp(60px, 5vw, 100px);
  background:var(--butter-pale);
  padding:clamp(12px, .9vw, 18px) clamp(16px, 1.1vw, 22px);
  font-family:var(--f-hand-jp);
  font-size:clamp(13.5px, 1vw, 15.5px);
  color:var(--ink-2);line-height:1.6;
  transform:rotate(-3deg);
  max-width:clamp(180px, 16vw, 240px);
  box-shadow:0 4px 14px -4px rgba(242,201,92,.3);
}
.hero-note::before{
  content:"";position:absolute;top:-8px;left:50%;transform:translateX(-50%);
  width:38px;height:14px;background:var(--butter);opacity:.7;border-radius:2px;
}
.hero-note .star-bullet{color:var(--rose);font-family:var(--f-en);font-weight:700;margin-right:4px}

/* page corner fold */
.corner{
  position:absolute;top:0;right:0;width:80px;height:80px;
  background:linear-gradient(225deg,var(--cream-2) 50%,var(--cream-3) 50%);
  clip-path:polygon(100% 0,100% 100%,0 0);
  z-index:5;pointer-events:none;
  box-shadow:-4px 4px 8px -4px rgba(0,0,0,.1);
}

/* mobile: layout switches to stacked. polaroid sizes here are deliberately
   smaller than the bottom of the desktop fluid range to avoid a size jump. */
@media(max-width:920px){
  .hero-visual{min-height:520px;margin-top:30px}
  .hero-pol-1{width:min(64%, 340px)}
  /* mobile sizes also enlarged ~1.5× to match the desktop rebalance */
  .hero-pol-2{width:min(68%, 360px);left:6%}
  .hero-pol-3{
    left:auto;right:0;
    top:auto;bottom:36%;
    width:min(56%, 270px);
    transform:rotate(4deg);
  }
  .hero-pol-3 .washi{transform:translateX(-50%) rotate(-4deg)}
  .hero-note{left:auto;right:0;bottom:auto;top:-20px}
}

/* hero floating doodle stars within the hero only */
.hero-deco{position:absolute;color:var(--butter);pointer-events:none}
.hero-deco.d1{top:8%;left:36%;width:28px;animation:twinkle 3.2s ease-in-out infinite}
.hero-deco.d2{bottom:12%;right:38%;width:18px;color:var(--mauve);animation:twinkle 4s .6s ease-in-out infinite}
.hero-deco.d3{top:38%;left:0;width:20px;color:var(--rose);animation:twinkle 3s 1.2s ease-in-out infinite}

/* constellation lines */
.constellation{position:absolute;inset:0;pointer-events:none;z-index:0}
.constellation path{fill:none;stroke:var(--rose);stroke-width:1;opacity:.35;stroke-dasharray:4 4;stroke-linecap:round}

/* ============================================================
   SECTION: 申込後の流れ — notebook pages
   ============================================================ */
.flow-section{position:relative}
.flow-section::before{
  content:"";position:absolute;top:0;left:0;right:0;height:60px;
  background:linear-gradient(to bottom,transparent,rgba(232,223,200,.4));
  pointer-events:none;
}

.flow{
  display:grid;grid-template-columns:repeat(12,1fr);gap:24px 18px;
  margin-top:60px;position:relative;
}
.flow::before{
  content:"";position:absolute;top:48px;left:6%;right:6%;height:2px;
  background-image:radial-gradient(circle,var(--rose) 0 1.5px,transparent 1.5px);
  background-size:14px 2px;background-position:center;background-repeat:repeat-x;
  z-index:0;
}
/* row 1 — preparation + observation experience: 4 cards */
.step:nth-child(1),
.step:nth-child(2),
.step:nth-child(3),
.step:nth-child(4){grid-column:span 3}
/* row 2 — mandatory own-theme inquiry: 3 wider cards */
.step:nth-child(5),
.step:nth-child(6),
.step:nth-child(7){grid-column:span 4}
.step{
  position:relative;background:#fff;padding:30px 22px 28px;
  border-radius:6px;
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 14px 30px -16px rgba(42,39,48,.16);
  transition:transform .35s,box-shadow .35s;
}
.step:nth-child(1){transform:rotate(-1.2deg)}
.step:nth-child(2){transform:rotate(.8deg) translateY(-6px)}
.step:nth-child(3){transform:rotate(-.5deg) translateY(2px)}
.step:nth-child(4){transform:rotate(1.4deg)}
.step:nth-child(5){transform:rotate(-1deg) translateY(4px)}
.step:nth-child(6){transform:rotate(.6deg) translateY(-4px)}
.step:nth-child(7){transform:rotate(-1.6deg) translateY(2px)}
/* row 2 cards stand out a touch — this is "あなたの研究" phase */
.step:nth-child(n+5){
  border-top:3px solid var(--rose);
}
.step:hover{transform:rotate(0) translateY(-4px);box-shadow:0 18px 40px -16px rgba(42,39,48,.2)}
.step .washi{top:-12px;left:50%;transform:translateX(-50%) rotate(var(--wr,-3deg));width:76px;height:18px}
.step:nth-child(1) .washi{--wr:-4deg}
.step:nth-child(2) .washi{--wr:5deg}
.step:nth-child(3) .washi{--wr:-2deg}
.step:nth-child(4) .washi{--wr:6deg}
.step:nth-child(5) .washi{--wr:-3deg;width:90px}
.step:nth-child(6) .washi{--wr:4deg;width:90px}
.step:nth-child(7) .washi{--wr:-5deg;width:90px}
.step-em{
  display:block;margin-top:8px;
  font-family:var(--f-italic);font-style:italic;font-size:13.5px;
  color:var(--rose-2);letter-spacing:.02em;
}
.step-icon{
  width:64px;height:64px;border-radius:50%;
  background:var(--cream-2);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 18px;color:var(--rose-2);
  position:relative;z-index:1;
}
.step-icon svg{width:30px;height:30px}
.step-icon img{width:64px;height:64px;border-radius:50%;object-fit:cover;display:block}
.step-num{
  position:absolute;top:-6px;right:-6px;
  width:26px;height:26px;border-radius:50%;
  background:var(--butter);color:var(--ink);
  font-family:var(--f-disp-en);font-style:italic;font-weight:700;font-size:15px;
  display:flex;align-items:center;justify-content:center;
}
.step-time{
  font-family:var(--f-hand-jp);font-size:13px;color:var(--rose-2);
  text-align:center;margin-bottom:6px;letter-spacing:.04em;
}
.step-title{
  font-family:var(--f-jp);font-weight:700;font-size:17px;color:var(--ink);
  text-align:center;margin-bottom:10px;line-height:1.55;letter-spacing:.02em;
}
.step-desc{
  font-size:14px;color:var(--ink);line-height:1.85;text-align:center;
  font-family:var(--f-jp);font-weight:500;letter-spacing:.01em;
}
.step-desc b{font-weight:700}
@media(max-width:1100px){
  .flow{grid-template-columns:repeat(6,1fr)}
  .step:nth-child(1),.step:nth-child(2),.step:nth-child(3),.step:nth-child(4){grid-column:span 3}
  .step:nth-child(5),.step:nth-child(6),.step:nth-child(7){grid-column:span 2}
}
@media(max-width:760px){
  .flow{grid-template-columns:1fr;gap:48px}
  .flow::before{display:none}
  .step,.step:nth-child(n){transform:none;grid-column:1/-1}
}

/* ============================================================
   SECTION: メンバーズ・ボイス — scrapbook
   ============================================================ */
.voices-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:60px 36px;
  margin-top:80px;position:relative;
}
@media(max-width:920px){.voices-grid{grid-template-columns:1fr;gap:80px}}

.voice{
  position:relative;
}
.voice .photo-card{position:relative;background:#fff;padding:14px 14px 24px}
.voice:nth-child(1) .photo-card{transform:rotate(-3deg)}
.voice:nth-child(2) .photo-card{transform:rotate(2deg) translateY(-12px)}
.voice:nth-child(3) .photo-card{transform:rotate(-1.5deg) translateY(8px)}
.voice .photo-card:hover{transform:rotate(0) translateY(-6px)}
.voice .photo-card .ph{aspect-ratio:4/3}
.voice .washi{top:-12px;left:50%;transform:translateX(-50%) rotate(var(--wr,-4deg))}
.voice:nth-child(1) .washi{--wr:-7deg;width:100px}
.voice:nth-child(2) .washi{--wr:6deg;width:88px}
.voice:nth-child(3) .washi{--wr:-3deg;width:110px}

.voice-quote-card{
  position:relative;
  background:var(--cream);
  margin-top:22px;padding:18px 20px 18px 26px;
  font-family:var(--f-hand-jp);font-size:16px;color:var(--ink);line-height:1.85;
  border-left:3px solid var(--rose);
  background-image:repeating-linear-gradient(0deg,transparent 0 27px,rgba(42,39,48,.07) 27px 28px);
  background-position:0 -2px;
  transform:rotate(.7deg);
  box-shadow:0 6px 14px -8px rgba(42,39,48,.18);
}
.voice:nth-child(2) .voice-quote-card{transform:rotate(-.5deg)}
.voice:nth-child(3) .voice-quote-card{transform:rotate(1.2deg)}
.voice-quote-card::before{
  content:"";position:absolute;top:-6px;left:24px;
  width:14px;height:14px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#ff8b6e,#c94524);
  box-shadow:0 2px 4px rgba(0,0,0,.25);
}

.voice-meta{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-top:18px;padding:0 6px;
}
.voice-meta .who{
  font-family:var(--f-disp-jp);font-size:15.5px;color:var(--ink);line-height:1.5;
}
.voice-meta .who em{font-style:normal;display:block;color:var(--ink-3);font-family:var(--f-jp);font-weight:400;font-size:12.5px;margin-top:3px;letter-spacing:.04em}
.voice-meta .duration{
  font-family:var(--f-hand-en);font-size:18px;color:var(--rose-2);
}

/* ============================================================
   SECTION: 5つの特徴 — index cards
   ============================================================ */
.features-section{position:relative;background:linear-gradient(to bottom,transparent,rgba(232,223,200,.3) 30%,rgba(232,223,200,.3) 70%,transparent)}
.features-grid{
  display:grid;grid-template-columns:repeat(6,1fr);
  grid-auto-rows:minmax(180px,auto);
  gap:20px;margin-top:60px;
}
.feat{
  background:#fff;border-radius:8px;
  padding:28px;display:flex;flex-direction:column;gap:14px;
  position:relative;overflow:hidden;
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 12px 24px -16px rgba(42,39,48,.18);
  transition:transform .35s,box-shadow .35s;
  border:1px solid rgba(232,223,200,.6);
}
.feat::after{
  content:"";position:absolute;left:0;right:0;top:0;height:6px;
  background:linear-gradient(90deg,var(--rose),var(--butter),var(--sage),var(--mauve));
  opacity:0;transition:opacity .3s;
}
.feat:hover{transform:translateY(-4px) rotate(-.4deg);box-shadow:0 1px 2px rgba(0,0,0,.04),0 18px 36px -16px rgba(42,39,48,.22)}
.feat:hover::after{opacity:1}
.feat-num{
  font-family:var(--f-italic);font-style:italic;font-size:16px;color:var(--rose-2);
}
.feat-title{
  font-family:var(--f-jp);font-size:19px;color:var(--ink);line-height:1.5;font-weight:700;letter-spacing:.02em;
}
.feat-desc{font-size:14.5px;color:var(--ink);line-height:1.9;margin-top:auto;font-family:var(--f-jp);font-weight:500;letter-spacing:.01em}
.feat-emoji{
  position:absolute;right:20px;top:20px;font-size:22px;color:var(--butter);opacity:.85;
}
.feat-1{grid-column:span 4}
.feat-2{grid-column:span 2}
.feat-3{grid-column:span 2}
.feat-4{grid-column:span 2}
.feat-5{grid-column:span 2}
@media(max-width:920px){
  .features-grid{grid-template-columns:1fr 1fr}
  .feat,.feat-1,.feat-2,.feat-3,.feat-4,.feat-5{grid-column:span 1}
}
@media(max-width:520px){.features-grid{grid-template-columns:1fr}}

/* ============================================================
   SECTION: 先輩 (alumni / achievements)
   ============================================================ */
.alumni-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-hand-jp);font-size:14.5px;color:var(--mauve);
  padding:5px 14px;border:1.5px dashed var(--mauve);border-radius:999px;
  background:var(--mauve-pale);margin-bottom:14px;
}
.alumni-tag::before{content:"✦";color:var(--mauve)}
.alumni-list{
  margin-top:48px;display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
}
.alumnus{
  display:flex;flex-direction:column;
  background:#fff;
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 8px 24px -10px rgba(42,39,48,.18);
  transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s;
  position:relative;text-decoration:none;
}
.alumnus:nth-child(1){transform:rotate(-1deg)}
.alumnus:nth-child(2){transform:rotate(.8deg) translateY(-8px)}
.alumnus:nth-child(3){transform:rotate(-1.5deg)}
.alumnus:nth-child(4){transform:rotate(1.2deg) translateY(6px)}
.alumnus:nth-child(5){transform:rotate(-.7deg)}
.alumnus:nth-child(6){transform:rotate(1deg) translateY(-4px)}
.alumnus:hover{
  transform:rotate(0) translateY(-8px) !important;
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 20px 48px -10px rgba(42,39,48,.24);
}
.alumnus-img{overflow:hidden;aspect-ratio:4/3;margin:10px 10px 0}
.alumnus-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .55s cubic-bezier(.2,.8,.2,1);
}
.alumnus:hover .alumnus-img img{transform:scale(1.06)}
.alumnus-body{
  padding:14px 14px 16px;
  display:grid;grid-template-columns:auto 1fr auto;gap:6px 14px;align-items:center;
  border-top:none;
}
.alumnus-body .alumnus-title{grid-column:1 / -1;grid-row:2}
.alumnus-body .alumnus-year{grid-row:1}
.alumnus-body .alumnus-arrow{grid-row:1}
.alumnus-year{
  font-family:var(--f-italic);font-style:italic;font-size:18px;color:var(--rose-2);min-width:64px;
}
.alumnus-title{
  font-family:var(--f-disp-jp);font-size:15px;color:var(--ink);line-height:1.6;
}
.alumnus-title em{
  font-style:normal;display:block;font-family:var(--f-jp);font-weight:400;
  color:var(--ink-3);font-size:12px;margin-top:4px;letter-spacing:.04em;
}
.alumnus-arrow{
  color:var(--ink-3);font-family:var(--f-disp-en);font-size:18px;
  transition:transform .3s,color .3s;
}
.alumnus:hover .alumnus-arrow{color:var(--rose-2);transform:translateX(6px)}
@media(max-width:900px){.alumni-list{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){
  .alumni-list{grid-template-columns:1fr}
  .alumnus:nth-child(n){transform:none}
}
.alumni-archive{margin-top:48px}
.archive-divider{
  display:flex;align-items:center;gap:16px;margin-bottom:24px;
}
.archive-divider-line{
  flex:1;height:1px;
  background:repeating-linear-gradient(90deg,var(--cream-3) 0 4px,transparent 4px 9px);
}
.archive-divider-label{
  font-family:var(--f-hand-jp);font-size:13px;color:var(--ink-3);
  letter-spacing:.16em;white-space:nowrap;
}
.archive-links{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.archive-link{
  display:flex;align-items:center;gap:14px;padding:16px 20px;
  background:var(--cream);border:1px dashed var(--cream-3);border-radius:8px;
  text-decoration:none;
  transition:border-color .25s,background .25s,transform .25s,box-shadow .25s;
}
.archive-link:hover{
  border-color:var(--rose);background:var(--rose-pale);
  transform:translateY(-3px);
  box-shadow:0 6px 24px -8px rgba(215,122,149,.22);
}
.archive-ico{
  width:26px;height:26px;flex-shrink:0;
  color:var(--ink-3);transition:color .25s;
}
.archive-link:hover .archive-ico{color:var(--rose-2)}
.archive-link-text{
  flex:1;display:flex;flex-direction:column;gap:3px;
}
.archive-link-text b{
  font-family:var(--f-disp-jp);font-size:16px;font-weight:400;color:var(--ink);
}
.archive-link-text small{
  font-family:var(--f-en);font-size:11px;color:var(--ink-3);letter-spacing:.08em;
}
.archive-link-arrow{
  font-size:18px;color:var(--ink-4);flex-shrink:0;
  font-family:var(--f-disp-en);
  transition:transform .25s,color .25s;
}
.archive-link:hover .archive-link-arrow{
  color:var(--rose-2);transform:translate(3px,-3px);
}
@media(max-width:600px){.archive-links{grid-template-columns:1fr}}

/* ============================================================
   SECTION: 専門家の声 (experts / endorsements)
   ============================================================ */
.experts-section{
  position:relative;
}
.experts-section::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 60% 50% at 92% 8%, rgba(220,201,232,.22), transparent 60%),
    radial-gradient(ellipse 50% 50% at 4% 92%, rgba(229,239,231,.30), transparent 60%);
}

/* ----- pair of letter cards ----- */
.experts-pair{
  margin-top:64px;
  display:grid;grid-template-columns:1fr 1fr;gap:36px 32px;
}
@media(max-width:960px){.experts-pair{grid-template-columns:1fr;gap:64px}}

.expert-letter-card{
  position:relative;background:#fff;
  border:1px solid var(--cream-3);border-radius:6px;
  padding:42px 38px 32px;
  display:flex;flex-direction:column;gap:24px;
  box-shadow:
    0 1px 2px rgba(42,39,48,.04),
    0 26px 48px -24px rgba(42,39,48,.24);
  transition:transform .4s cubic-bezier(.2,.8,.2,1),box-shadow .35s;
  isolation:isolate;
}
.expert-letter-card.card-1{transform:rotate(-.55deg)}
.expert-letter-card.card-2{transform:rotate(.55deg) translateY(8px)}
.expert-letter-card:hover{
  transform:rotate(0) translateY(-4px);
  box-shadow:0 1px 2px rgba(42,39,48,.05),0 32px 60px -22px rgba(42,39,48,.32);
}
.expert-letter-card::before{
  /* aged paper top edge */
  content:"";position:absolute;left:0;right:0;top:0;height:5px;
  background:repeating-linear-gradient(90deg,
    transparent 0 13px, rgba(216,207,182,.5) 13px 14px);
  pointer-events:none;
}
.expert-letter-card::after{
  /* faint ruled lines on the body */
  content:"";position:absolute;left:38px;right:38px;top:200px;bottom:80px;
  background-image:repeating-linear-gradient(0deg, transparent 0 31px, rgba(42,39,48,.04) 31px 32px);
  -webkit-mask-image:linear-gradient(to bottom, transparent 0, #000 30px, #000 calc(100% - 30px), transparent);
          mask-image:linear-gradient(to bottom, transparent 0, #000 30px, #000 calc(100% - 30px), transparent);
  pointer-events:none;z-index:0;opacity:.7;
}
.expert-letter-card .washi{top:-12px;left:46px;transform:rotate(var(--wr,-3deg));width:104px}
.expert-letter-card.card-2 .washi{left:auto;right:46px}
.expert-letter-card .paperclip{
  position:absolute;top:-22px;right:38px;width:24px;height:60px;
  color:var(--ink-3);opacity:.55;
  filter:drop-shadow(0 2px 1px rgba(42,39,48,.18));
  transform:rotate(8deg);z-index:3;
}
.expert-letter-card.card-2 .paperclip{right:auto;left:38px;transform:rotate(-8deg)}

/* head: portrait + ID + seal */
.expert-letter-card .expert-card-head{
  display:grid;grid-template-columns:96px 1fr;gap:20px;align-items:start;
  position:relative;z-index:2;
}
.expert-letter-card .expert-mini{
  background:var(--cream);padding:8px 8px 26px;border:1px solid var(--cream-3);
  transform:rotate(-3deg);
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 12px 22px -12px rgba(42,39,48,.3);
}
.expert-letter-card.card-2 .expert-mini{transform:rotate(2.5deg)}
.expert-letter-card .expert-mini .ph,
.expert-letter-card .expert-mini .photo-img{aspect-ratio:4/5;width:100%;display:block;border-radius:1px}
.expert-letter-card .expert-mini .photo-img{object-fit:cover;object-position:center 28%}
.expert-letter-card .expert-mini .ph .ph-key{font-size:11px;letter-spacing:.16em}
.expert-letter-card .expert-mini .ph .ph-tag{font-size:8px;top:6px;right:6px;letter-spacing:.18em}
.expert-letter-card .expert-mini .ph .ph-hint{display:none}
.expert-letter-card .expert-mini .ph::before,
.expert-letter-card .expert-mini .ph::after{width:10px;height:10px}
.expert-letter-card .expert-mini .ph::before{top:6px;left:6px}
.expert-letter-card .expert-mini .ph::after{bottom:6px;right:6px}

.expert-letter-card .expert-card-id{padding-top:2px;padding-right:78px}
.expert-letter-card .role-tag{font-size:12.5px;padding:3px 12px;margin-bottom:10px}
.expert-letter-card .expert-card-id h4{
  font-family:var(--f-disp-jp);font-weight:400;font-size:21px;color:var(--ink);
  letter-spacing:.04em;line-height:1.35;margin-bottom:6px;
  display:flex;align-items:baseline;flex-wrap:wrap;gap:8px;
}
.expert-letter-card .expert-card-id h4 small{
  font-family:var(--f-italic);font-style:italic;font-size:14px;font-weight:400;
  color:var(--rose-2);letter-spacing:.05em;
}
.expert-letter-card .expert-card-id p{
  font-family:var(--f-jp);font-weight:400;font-size:13px;color:var(--ink-3);
  line-height:1.7;letter-spacing:.04em;
}
.expert-letter-card .expert-card-id p em{
  font-style:normal;display:block;margin-top:4px;
  font-family:var(--f-italic);font-style:italic;font-size:14px;color:var(--ink-2);
  letter-spacing:.05em;
}

/* seal */
.role-tag{
  display:inline-block;font-family:var(--f-italic);font-style:italic;font-size:14px;
  color:var(--mauve);background:var(--mauve-pale);
  padding:4px 14px;border-radius:999px;letter-spacing:.05em;
  border:1px solid rgba(163,138,196,.3);
}
.role-tag.sage{color:#3F6B52;background:var(--sage-pale);border-color:rgba(63,107,82,.28)}

.expert-letter-card .seal{
  position:absolute;top:24px;right:28px;
  width:78px;height:78px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, #B58CD2 0%, #7A56A0 70%, #5C3D80 100%);
  color:#ECE3F4;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-en);font-weight:700;font-size:11.5px;letter-spacing:.16em;text-align:center;line-height:1.4;
  box-shadow:
    inset 0 2px 4px rgba(255,255,255,.2),
    inset 0 -2px 6px rgba(0,0,0,.28),
    0 4px 14px -4px rgba(122,86,160,.55);
  transform:rotate(-9deg);
  z-index:3;
  filter:drop-shadow(0 1px 0 rgba(0,0,0,.15));
}
.expert-letter-card .seal-inner{position:relative;z-index:2;padding:4px}
.expert-letter-card .seal-ring{position:absolute;inset:7px;border:1.5px dashed rgba(236,227,244,.55);border-radius:50%}
.expert-letter-card .seal::after{
  content:"✦";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-size:9px;color:rgba(236,227,244,.35);
}
.expert-letter-card .seal.seal-sage{
  background:radial-gradient(circle at 30% 30%, #9CC2A6 0%, #5E8B6B 70%, #466B51 100%);
  color:var(--sage-pale);
  box-shadow:
    inset 0 2px 4px rgba(255,255,255,.2),
    inset 0 -2px 6px rgba(0,0,0,.28),
    0 4px 14px -4px rgba(94,139,107,.55);
  transform:rotate(7deg);
}
.expert-letter-card .seal.seal-sage .seal-ring{border-color:rgba(229,239,231,.55)}


/* quote body */
.expert-pull{
  font-family:var(--f-disp-jp);font-weight:400;
  font-size:clamp(17px,1.5vw,20px);line-height:1.95;color:var(--ink);
  letter-spacing:.01em;position:relative;z-index:1;
}
.expert-pull em{
  font-style:normal;color:var(--mauve);
  background-image:linear-gradient(transparent 70%, rgba(220,201,232,.55) 70%);
  background-repeat:no-repeat;padding:0 2px;
}
.card-2 .expert-pull em{
  color:#3F6B52;
  background-image:linear-gradient(transparent 70%, rgba(200,224,203,.7) 70%);
}

.expert-body{
  font-size:15px;color:var(--ink-2);line-height:1.95;
  font-family:var(--f-jp);font-weight:400;
  position:relative;z-index:1;
}

.expert-sign{
  margin-top:auto;padding-top:18px;border-top:1px dashed var(--cream-3);
  display:flex;justify-content:flex-end;align-items:flex-end;
  position:relative;z-index:1;
}
.expert-sign-name{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.sig-script{
  font-family:var(--f-hand-en);font-weight:700;font-size:28px;line-height:1;color:var(--mauve);
  transform:rotate(-3deg);transform-origin:right center;display:inline-block;margin-bottom:6px;
  letter-spacing:.01em;
}
.sig-script.sage-ink{color:#3F6B52;transform:rotate(2deg)}
.sig-meta{
  font-family:var(--f-italic);font-style:italic;font-size:13px;color:var(--ink-3);
  letter-spacing:.04em;
}

@media(max-width:520px){
  .expert-letter-card{padding:36px 24px 26px}
  .expert-letter-card .expert-card-head{grid-template-columns:80px 1fr;gap:14px}
  .expert-letter-card .expert-card-id{padding-right:62px}
  .expert-letter-card .seal{width:60px;height:60px;font-size:9px;top:18px;right:18px}
  .expert-letter-card .washi{left:50%;transform:translateX(-50%) rotate(-3deg)}
  .expert-letter-card.card-2 .washi{left:50%;right:auto}
  .expert-letter-card::after{left:24px;right:24px}
}

/* ----- backers (supporting institutions) ----- */
.experts-backers{
  margin-top:96px;
  display:flex;flex-direction:column;align-items:center;gap:36px;
  position:relative;
}

.backers-eyebrow{
  display:flex;align-items:center;gap:14px;
  font-family:var(--f-en);font-style:italic;font-size:13.5px;color:var(--rose-2);
  letter-spacing:.22em;text-transform:uppercase;
}
.backers-eyebrow .dash{
  display:inline-block;width:48px;height:1px;background:var(--rose);opacity:.6;
}
.backers-eyebrow .label{padding-bottom:1px}

.backers-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  width:100%;
}
@media(max-width:920px){.backers-grid{grid-template-columns:1fr 1fr;gap:28px}}
@media(max-width:520px){.backers-grid{grid-template-columns:1fr;gap:24px}}

.backer-card{
  position:relative;background:#fff;
  border:1px solid var(--cream-3);border-radius:4px;
  padding:34px 22px 22px;
  display:flex;flex-direction:column;align-items:center;gap:18px;text-align:center;
  box-shadow:
    0 1px 2px rgba(42,39,48,.04),
    0 16px 30px -18px rgba(42,39,48,.22);
  transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s,border-color .35s;
  isolation:isolate;
}
.backer-card::before{
  /* faint paper-rule top edge */
  content:"";position:absolute;left:0;right:0;top:0;height:3px;
  background:repeating-linear-gradient(90deg,
    transparent 0 9px, rgba(216,207,182,.45) 9px 10px);
  pointer-events:none;
}
.backer-card .washi{
  top:-10px;left:50%;transform:translateX(-50%) rotate(var(--wr,-3deg));
  width:64px;height:18px;
}
.backer-card:nth-child(1) .washi{--wr:-4deg}
.backer-card:nth-child(2) .washi{--wr:3deg}
.backer-card:nth-child(3) .washi{--wr:-2deg}
.backer-card:nth-child(4) .washi{--wr:5deg}
.backer-card:hover{
  transform:translateY(-6px);
  border-color:rgba(180,84,111,.18);
  box-shadow:
    0 1px 2px rgba(42,39,48,.05),
    0 24px 44px -18px rgba(42,39,48,.32);
}

.backer-logo{
  width:100%;height:84px;
  display:flex;align-items:center;justify-content:center;
  padding:8px 6px;
  position:relative;
}
.backer-logo::before{
  /* light paper-tinted backdrop so logos with dark colors don't fight */
  content:"";position:absolute;inset:0;border-radius:2px;
  background:linear-gradient(180deg, rgba(250,246,235,0) 0%, rgba(250,246,235,.5) 100%);
  pointer-events:none;
}
.backer-logo img{
  max-width:100%;max-height:100%;
  width:auto;height:auto;
  object-fit:contain;
  filter:saturate(.86);
  transition:filter .35s,transform .35s cubic-bezier(.2,.8,.2,1);
  position:relative;z-index:1;
}
.backer-card:hover .backer-logo img{filter:saturate(1);transform:scale(1.04)}

.backer-id{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  padding-top:8px;border-top:1px dashed var(--cream-3);width:100%;
}
.backer-kind{
  font-family:var(--f-italic);font-style:italic;font-size:12.5px;
  color:var(--rose-2);letter-spacing:.06em;
  padding:1px 12px;background:var(--rose-pale);border-radius:999px;
  margin-bottom:2px;
}
.backer-card:nth-child(1) .backer-kind{color:#5C3D80;background:rgba(220,201,232,.5)}
.backer-card:nth-child(2) .backer-kind{color:#3F6B52;background:var(--sage-pale)}
.backer-card:nth-child(3) .backer-kind{color:var(--rose-2);background:var(--rose-pale)}
.backer-card:nth-child(4) .backer-kind{color:#9B7A12;background:var(--butter-pale)}
.backer-id h5{
  font-family:var(--f-disp-jp);font-weight:400;font-size:16.5px;color:var(--ink);
  letter-spacing:.04em;line-height:1.4;
  display:flex;flex-direction:column;align-items:center;gap:2px;
}
.backer-id h5 small{
  font-family:var(--f-jp);font-weight:400;font-size:12px;color:var(--ink-3);
  letter-spacing:.06em;
}
.backer-id p{
  font-family:var(--f-jp);font-weight:400;font-size:12.5px;color:var(--ink-3);
  line-height:1.65;letter-spacing:.04em;word-break:keep-all;overflow-wrap:break-word;
}
.backer-id p em{
  font-style:italic;font-family:var(--f-italic);font-size:.95em;
  color:var(--rose-2);display:block;margin-top:4px;letter-spacing:.05em;
}

/* keep rotations after reveal animation finishes (override .reveal-stagger.in) */
.experts-pair.reveal-stagger.in>.expert-letter-card.card-1{transform:rotate(-.55deg)}
.experts-pair.reveal-stagger.in>.expert-letter-card.card-2{transform:rotate(.55deg) translateY(8px)}
.experts-pair.reveal-stagger.in>.expert-letter-card:hover{transform:rotate(0) translateY(-4px)}
@media(max-width:960px){
  .experts-pair.reveal-stagger.in>.expert-letter-card.card-1,
  .experts-pair.reveal-stagger.in>.expert-letter-card.card-2{transform:none}
  .experts-pair.reveal-stagger.in>.expert-letter-card:hover{transform:translateY(-4px)}
}

/* ============================================================
   SECTION: マップ — illustrated
   ============================================================ */
.map-section{position:relative}
.map-grid{display:grid;grid-template-columns:.6fr 1.4fr;gap:64px;align-items:center;margin-top:60px}
@media(max-width:920px){.map-grid{grid-template-columns:1fr}}
.map-stats{display:flex;flex-direction:column;gap:32px}
.map-stat{position:relative;padding-left:28px}
.map-stat::before{
  content:"";position:absolute;left:0;top:18px;width:14px;height:14px;
  background:var(--rose);border-radius:50%;
  box-shadow:0 0 0 6px rgba(215,122,149,.18);
}
.map-stat:nth-child(2)::before{background:var(--sage);box-shadow:0 0 0 6px rgba(138,174,150,.18)}
.map-stat:nth-child(3)::before{background:var(--mauve);box-shadow:0 0 0 6px rgba(163,138,196,.18)}
.map-stat-num{
  font-family:var(--f-disp-en);font-style:italic;font-weight:700;
  font-size:46px;color:var(--ink);line-height:1;letter-spacing:-.01em;
}
.map-stat-num small{font-family:var(--f-jp);font-style:normal;font-weight:500;color:var(--ink-3);font-size:.42em;margin-left:6px}
.map-stat-label{
  font-family:var(--f-hand-jp);font-size:15px;color:var(--rose-2);margin-top:6px;letter-spacing:.04em;
}
.map-stat-detail{
  font-size:14.5px;color:var(--ink-2);margin-top:8px;line-height:1.85;font-family:var(--f-jp);font-weight:400;
}

.geo-card{
  background:#fff;border-radius:8px;
  padding:24px;position:relative;overflow:hidden;
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 18px 36px -20px rgba(42,39,48,.18);
  border:1px solid var(--cream-3);
}
.geo-card .washi{top:-10px;left:30px;transform:rotate(-4deg);width:90px}
.geo-card-title{
  font-family:var(--f-hand-jp);font-size:15px;color:var(--ink);
  margin-bottom:12px;letter-spacing:.04em;line-height:1.5;
}
.geo-card-title em{font-style:normal;font-family:var(--f-italic);font-style:italic;color:var(--rose-2);font-size:.95em;display:block}
.geo-canvas{
  position:relative;width:100%;border-radius:4px;overflow:hidden;
  background:var(--cream)
    repeating-linear-gradient(0deg,transparent 0 23px,rgba(42,39,48,.055) 23px 24px);
}
.geo-map-img{width:100%;height:auto;display:block;mix-blend-mode:multiply}

/* ============================================================
   SECTION: 5月の仲間 — invitation
   ============================================================ */
.invite{
  background:#fff;border-radius:8px;
  padding:clamp(40px,5vw,64px);
  display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:center;
  position:relative;overflow:hidden;
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 30px 60px -20px rgba(42,39,48,.18);
  border:1.5px solid var(--rose-pale);
}
.invite::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 0%,var(--rose-pale),transparent 50%),
    radial-gradient(circle at 80% 100%,var(--butter-pale),transparent 50%);
  pointer-events:none;
}
.invite::after{
  content:"";position:absolute;inset:18px;border:1px dashed var(--rose);
  border-radius:4px;pointer-events:none;
}
.invite .washi{top:-14px;left:50%;transform:translateX(-50%) rotate(-2deg);width:120px;height:24px}

.invite-date{
  position:relative;z-index:1;text-align:center;
  border-right:1px solid var(--cream-3);padding-right:48px;
}
.invite-date .month{font-family:var(--f-italic);font-style:italic;font-size:18px;color:var(--rose-2)}
.invite-date .day{
  font-family:var(--f-disp-jp);font-weight:400;font-size:96px;line-height:1;color:var(--ink);
  margin:6px 0;
}
.invite-date .week{font-family:var(--f-hand-jp);font-size:16px;color:var(--ink-2);margin-bottom:14px}
.invite-date .time{font-family:var(--f-en);font-size:14px;color:var(--rose-2);letter-spacing:.1em}
.invite-body{position:relative;z-index:1}
.invite-body h3{font-family:var(--f-disp-jp);font-weight:400;font-size:clamp(22px,3vw,32px);line-height:1.5;color:var(--ink);margin-bottom:14px}
.invite-body p{color:var(--ink-2);font-size:15.5px;line-height:1.95;margin-bottom:18px;font-family:var(--f-jp);font-weight:400;max-width:48ch}
.invite-meta{
  display:flex;gap:14px;flex-wrap:wrap;
  font-family:var(--f-hand-jp);font-size:14px;color:var(--ink-2);
  margin-bottom:24px;
}
.invite-meta .pill{
  background:var(--cream-2);padding:5px 12px;border-radius:999px;
  border:1px solid var(--cream-3);
}
.invite-meta .pill b{color:var(--rose-2);font-weight:600;margin-right:4px}
@media(max-width:760px){
  .invite{grid-template-columns:1fr;gap:24px;text-align:center}
  .invite-date{border-right:0;border-bottom:1px solid var(--cream-3);padding:0 0 24px;padding-right:0}
  .invite-meta{justify-content:center}
}

/* ============================================================
   SECTION: 保護者・教員
   ============================================================ */
.dual{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:60px}
@media(max-width:760px){.dual{grid-template-columns:1fr}}
.dual-card{
  background:var(--cream-2);padding:36px 32px;border-radius:6px;
  position:relative;border:1px solid var(--cream-3);
}
.dual-card.parents{background:var(--sage-pale);border-color:#C8DBCB}
.dual-card.teachers{background:var(--mauve-pale);border-color:#D5C5E0}
.dual-card .washi{top:-10px;left:30px;width:90px;transform:rotate(-3deg)}
.dual-card .tag{
  display:inline-block;font-family:var(--f-italic);font-style:italic;font-size:15px;
  color:var(--ink);margin-bottom:8px;letter-spacing:.02em;
}
.dual-card.parents .tag{color:#4A7659}
.dual-card.teachers .tag{color:#6B5A8F}
.dual-card h3{font-family:var(--f-disp-jp);font-weight:400;font-size:20px;color:var(--ink);margin-bottom:18px;line-height:1.5}
.dual-card ul{list-style:none}
.dual-card li{
  font-size:14.5px;color:var(--ink);padding:9px 0 9px 22px;border-bottom:1px dashed rgba(42,39,48,.15);
  position:relative;line-height:1.8;font-family:var(--f-jp);font-weight:400;
}
.dual-card li::before{content:"✦";position:absolute;left:0;color:var(--rose);font-size:13px;top:11px}
.dual-card.parents li::before{color:#4A7659}
.dual-card.teachers li::before{color:#6B5A8F}
.dual-card li:last-child{border-bottom:0}
.dual-card .pdf{
  display:inline-flex;align-items:center;gap:8px;margin-top:18px;
  font-family:var(--f-hand-jp);font-size:14.5px;color:var(--ink);
  border-bottom:1px solid var(--ink);padding-bottom:2px;
}
.dual-card .pdf::after{content:"↗"}

/* ============================================================
   SECTION: FAQ — notebook tabs
   ============================================================ */
.faq-list{margin-top:48px;display:flex;flex-direction:column;gap:14px}
.faq-item{
  background:#fff;border-radius:6px;
  border:1px solid var(--cream-3);
  overflow:hidden;
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 6px 18px -10px rgba(42,39,48,.12);
  transition:box-shadow .25s;
}
.faq-item[open]{box-shadow:0 1px 2px rgba(0,0,0,.04),0 12px 30px -14px rgba(42,39,48,.2)}
.faq-q{
  width:100%;text-align:left;padding:20px 24px;
  display:flex;justify-content:space-between;align-items:center;gap:18px;
  /* body sans (Noto Sans JP) at semibold for readability — Hina Mincho was
     too thin/decorative at this size for kanji-heavy questions */
  font-family:var(--f-jp);font-weight:600;font-size:17px;color:var(--ink);
  cursor:pointer;line-height:1.6;letter-spacing:.01em;
  list-style:none;
}
.faq-q::-webkit-details-marker{display:none}
.faq-q .qmark{
  font-family:var(--f-italic);font-style:italic;font-size:18px;color:var(--rose-2);
  flex-shrink:0;width:36px;
}
.faq-q .qtoggle{
  flex-shrink:0;width:30px;height:30px;border-radius:50%;
  border:1.5px solid var(--rose);background:var(--rose-pale);
  display:flex;align-items:center;justify-content:center;color:var(--rose-2);
  font-family:var(--f-italic);font-size:18px;font-style:italic;
  transition:transform .35s,background .25s;
}
.faq-item[open] .faq-q .qtoggle{
  background:var(--rose);color:#fff;transform:rotate(45deg);
}
.faq-a{
  padding:0 24px 24px 60px;
  font-size:15px;color:var(--ink-2);line-height:1.95;font-family:var(--f-jp);font-weight:400;
}
.faq-a b{color:var(--ink);font-weight:700}
.faq-em{
  font-family:var(--f-italic);font-style:italic;color:var(--rose-2);
  font-size:15.5px;letter-spacing:.02em;
}
@media(max-width:520px){.faq-a{padding-left:36px}}

/* ============================================================
   FINAL CTA — letter from cosmos
   ============================================================ */
.final-cta{
  background:#fff;border-radius:8px;
  padding:clamp(48px,7vw,90px) clamp(32px,5vw,72px);
  text-align:center;position:relative;overflow:hidden;
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 30px 60px -20px rgba(42,39,48,.18);
}
.final-cta::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 40% 30% at 50% 0%,var(--butter-pale),transparent 60%),
    radial-gradient(ellipse 50% 30% at 50% 100%,var(--rose-pale),transparent 60%);
  pointer-events:none;
}
.final-cta .stars-deco{
  position:absolute;top:30px;right:30px;left:30px;
  display:flex;justify-content:space-between;color:var(--butter);font-size:18px;opacity:.4;pointer-events:none;
}
.final-cta h2{
  font-family:var(--f-disp-jp);font-weight:400;
  font-size:clamp(28px,4.5vw,48px);line-height:1.5;color:var(--ink);position:relative;
  max-width:18em;margin:0 auto .6em;
}
.final-cta .lead{
  font-family:var(--f-jp);font-size:16px;color:var(--ink-2);max-width:30em;margin:0 auto 36px;
  line-height:2;font-weight:400;position:relative;
}
.final-cta .hero-cta{justify-content:center;position:relative}
.final-cta .signature{
  margin-top:36px;font-family:var(--f-hand-jp);font-size:15px;color:var(--rose-2);position:relative;
}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{
  border-top:1px dashed var(--cream-3);padding:60px 0 36px;margin-top:60px;
  position:relative;z-index:3;background:rgba(242,235,217,.45);
}
.foot-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;
}
.foot h4{font-family:var(--f-italic);font-style:italic;font-size:16px;color:var(--rose-2);margin-bottom:14px}
.foot ul{list-style:none}
.foot li{font-size:14px;color:var(--ink-2);padding:4px 0;font-family:var(--f-jp);font-weight:400}
.foot a:hover{color:var(--rose-2)}
.foot-brand .brand{margin-bottom:14px}
.foot-brand .brand-jp{font-size:24px}
.foot-brand p{font-size:14px;color:var(--ink-2);line-height:1.85;max-width:30ch;font-family:var(--f-jp);font-weight:400}
.foot-bottom{
  margin-top:48px;padding-top:24px;border-top:1px dashed var(--cream-3);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;
  font-family:var(--f-en);font-size:12px;color:var(--ink-3);letter-spacing:.12em;text-transform:uppercase;
}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr;gap:24px}}

/* ============================================================
   reveal animations
   ============================================================ */
.reveal{opacity:0;transform:translateY(20px);transition:opacity 1s ease,transform 1s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal-stagger>*{opacity:0;transform:translateY(20px);transition:opacity 1s ease,transform 1s cubic-bezier(.2,.8,.2,1)}
.reveal-stagger.in>*{opacity:1;transform:none}
.reveal-stagger.in>*:nth-child(1){transition-delay:.0s}
.reveal-stagger.in>*:nth-child(2){transition-delay:.08s}
.reveal-stagger.in>*:nth-child(3){transition-delay:.16s}
.reveal-stagger.in>*:nth-child(4){transition-delay:.24s}
.reveal-stagger.in>*:nth-child(5){transition-delay:.32s}
.reveal-stagger.in>*:nth-child(6){transition-delay:.40s}

/* selection */
::selection{background:var(--rose-pale);color:var(--rose-2)}

/* utility for stagger photos retaining their rotation */
.voice .photo-card,.voice .voice-quote-card,
.step:nth-child(n){transition:transform .55s cubic-bezier(.2,.8,.2,1),box-shadow .35s !important}

/* ============================================================
   SECTION: 現場の手ざわり (field notebook / photo essay)
   ============================================================ */
.field-section{
  position:relative;
  padding:clamp(56px,7vw,96px) 0;
  background:
    radial-gradient(ellipse 80% 50% at 100% 10%, rgba(220,201,232,.18), transparent 60%),
    radial-gradient(ellipse 70% 50% at 0% 90%, rgba(200,224,203,.18), transparent 60%);
}
.field-section::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(circle at 20% 8%, rgba(163,138,196,.18) 1.5px, transparent 2px),
    radial-gradient(circle at 80% 6%, rgba(215,122,149,.18) 1.5px, transparent 2px),
    radial-gradient(circle at 12% 92%, rgba(138,174,150,.18) 1.5px, transparent 2px),
    radial-gradient(circle at 88% 94%, rgba(242,201,92,.22) 1.5px, transparent 2px);
}

.field-scrapbook{
  margin-top:44px;display:flex;flex-direction:column;gap:20px;position:relative;
}
.meetup-section{padding-top:0;padding-bottom:0}

/* — chapter heading: vertical kanji + handwritten label + dashed rule — */
.field-chapter{
  display:flex;align-items:flex-end;gap:22px;margin-top:8px;padding-bottom:6px;
  position:relative;
}
.chapter-num{
  font-family:var(--f-disp-jp);font-size:88px;line-height:.85;color:var(--ink);
  letter-spacing:-.04em;
  text-shadow:2px 2px 0 var(--rose-pale);
  flex:0 0 auto;
}
.field-chapter.tone-sage .chapter-num{text-shadow:2px 2px 0 var(--sage-pale)}
.field-chapter.tone-mauve .chapter-num{text-shadow:2px 2px 0 var(--mauve-pale)}
.field-chapter.tone-butter .chapter-num{text-shadow:2px 2px 0 var(--butter-pale)}
.chapter-text{display:flex;flex-direction:column;gap:4px;padding-bottom:10px}
.chapter-jp{
  font-family:var(--f-disp-jp);font-size:clamp(22px,2.8vw,30px);color:var(--ink);
  line-height:1.3;letter-spacing:.02em;
}
.chapter-en{
  font-family:var(--f-en);font-size:12px;letter-spacing:.22em;color:var(--ink-3);
  text-transform:uppercase;
}
.chapter-rule{
  flex:1;height:1px;margin-bottom:18px;
  background-image:linear-gradient(to right, var(--cream-3) 0 6px, transparent 6px 12px);
  background-size:12px 1px;background-repeat:repeat-x;
}

/* — field row: irregular polaroid arrangement — */
.field-row{
  display:grid;grid-template-columns:repeat(12,1fr);gap:24px;
  align-items:start;position:relative;padding:6px 0 14px;
}

/* — polaroid card — */
.polaroid{
  position:relative;background:#fff;
  padding:14px 14px 22px;
  box-shadow:
    0 1px 2px rgba(0,0,0,.04),
    0 14px 30px -14px rgba(42,39,48,.22),
    0 32px 56px -28px rgba(42,39,48,.18);
  transition:transform .55s cubic-bezier(.2,.8,.2,1), box-shadow .35s;
  will-change:transform;
}
.polaroid:hover{transform:rotate(0) translateY(-6px);box-shadow:0 1px 2px rgba(0,0,0,.04),0 22px 44px -16px rgba(42,39,48,.28),0 40px 70px -30px rgba(42,39,48,.22);z-index:2}

.polaroid .washi{
  position:absolute;top:-12px;left:50%;
  width:96px;height:20px;
  transform:translateX(-50%) rotate(var(--wr,-3deg));
  z-index:3;
}
.polaroid-img{
  width:100%;aspect-ratio:4/3;overflow:hidden;background:var(--cream-2);
  border-radius:1px;
  position:relative;
}
.polaroid-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  filter:saturate(.95) contrast(1.02);
}
/* click-to-play video poster (used in #meetup) */
button.polaroid-img.video-poster{
  appearance:none;border:0;padding:0;background:transparent;
  cursor:pointer;color:inherit;font:inherit;display:block;
}
button.polaroid-img.video-poster:disabled{cursor:default}
.polaroid-img.video-poster .play-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(42,39,48,0) 35%,rgba(42,39,48,.42) 100%);
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;transition:background .35s,opacity .25s;
}
.polaroid-img.video-poster:hover:not(:disabled) .play-overlay{
  background:linear-gradient(135deg,rgba(42,39,48,.08) 35%,rgba(42,39,48,.55) 100%);
}
.polaroid-img.video-poster:disabled .play-overlay{opacity:0}
.polaroid-img.video-poster .play-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.96);color:var(--rose-2);
  font-size:16px;padding-left:4px;line-height:1;
  box-shadow:0 8px 24px rgba(0,0,0,.25),inset 0 0 0 1px rgba(255,255,255,.6);
  transition:transform .35s cubic-bezier(.2,.8,.2,1);
}
.polaroid-img.video-poster:hover:not(:disabled) .play-btn{transform:scale(1.1)}
.polaroid-img.video-poster .embedded-video{
  position:absolute;inset:0;
  width:100%;height:100%;border:0;display:block;background:#000;
}

.polaroid figcaption{
  display:flex;flex-direction:column;gap:2px;text-align:center;margin-top:14px;padding:0 4px;
}
.polaroid .cap-jp{
  font-family:var(--f-hand-jp);font-size:15.5px;color:#3a3540;line-height:1.5;letter-spacing:.01em;
}
.polaroid .cap-en{
  font-family:var(--f-en);font-size:11px;color:var(--ink-4);letter-spacing:.18em;
  text-transform:uppercase;
}

.polaroid .stamp{
  position:absolute;top:14px;right:14px;
  font-family:var(--f-en);font-size:9.5px;color:var(--rose-2);letter-spacing:.18em;
  border:1px solid var(--rose-2);padding:3px 7px;border-radius:2px;
  transform:rotate(-6deg);background:rgba(255,255,255,.7);z-index:2;
}
.polaroid .stamp.butter-stamp{color:#9B7A12;border-color:#9B7A12;transform:rotate(4deg)}
.polaroid .stamp.mauve-stamp{color:var(--mauve);border-color:var(--mauve);transform:rotate(-7deg)}

/* row 1: 3 polaroids — slight cascade */
.chapter-1-row .p-1{grid-column:span 4;transform:rotate(-2.2deg)}
.chapter-1-row .p-2{grid-column:span 4;transform:rotate(1.4deg) translateY(20px)}
.chapter-1-row .p-3{grid-column:span 4;transform:rotate(-.8deg) translateY(-10px)}
.chapter-1-row .p-1 .washi{--wr:-7deg;width:108px}
.chapter-1-row .p-2 .washi{--wr:5deg;width:88px}
.chapter-1-row .p-3 .washi{--wr:-3deg;width:96px}

/* row 2: 3 polaroids on row 1, fact card on row 2 */
.chapter-2-row{grid-template-rows:auto auto;align-items:start}
.chapter-2-row .p-4{grid-column:span 4;grid-row:1;transform:rotate(-1.6deg)}
.chapter-2-row .p-pf{grid-column:span 4;grid-row:1;transform:rotate(1.4deg) translateY(14px)}
.chapter-2-row .p-5{grid-column:span 4;grid-row:1;transform:rotate(2.2deg) translateY(28px)}
.chapter-2-row .p-4 .washi{--wr:-5deg;width:104px}
.chapter-2-row .p-pf .washi{--wr:4deg;width:96px}
.chapter-2-row .p-5 .washi{--wr:6deg;width:96px}
.chapter-2-row .field-fact{grid-column:4 / span 6;grid-row:2;justify-self:center;align-items:center;text-align:center;margin-top:28px;max-width:520px}
.chapter-2-row .field-fact .fact-list{text-align:center}

/* row 3: CERN wide (2 rows) + Geneva (top right) + quote (bottom right) */
.chapter-3-row .p-6{grid-column:1 / span 4;transform:rotate(-1.4deg)}
.chapter-3-row .p-6 .washi{--wr:-4deg;width:100px}
.chapter-3-row .p-6 .polaroid-img{aspect-ratio:3/2}
.chapter-3-row .p-6b{grid-column:5 / span 4;transform:rotate(2.2deg) translateY(10px)}
.chapter-3-row .p-6b .washi{--wr:5deg;width:90px}
.chapter-3-row .p-6b .polaroid-img{aspect-ratio:3/2}
.chapter-3-row .p-8{grid-column:9 / span 4;transform:rotate(-1.2deg) translateY(20px)}
.chapter-3-row .p-8 .washi{--wr:-4deg;width:100px}
.chapter-3-row .p-8 .polaroid-img{aspect-ratio:3/2}

/* row 4: world peers — Langmuir + Thai */

/* coda: two photos side by side */
.chapter-coda .p-7{grid-column:1 / span 7;transform:rotate(-.8deg)}
.chapter-coda .p-7 .washi{--wr:-2deg;width:110px;left:30%}
.chapter-coda .p-7 .polaroid-img{aspect-ratio:3/2}

/* meetup: photo + quote */
.chapter-coda .p-7b{grid-column:8 / span 5;transform:rotate(1.8deg) translateY(12px)}
.chapter-coda .p-7b .washi{--wr:4deg;width:90px}
.chapter-coda .p-7b .polaroid-img{aspect-ratio:4/3}

/* — handwritten arrow between rows — */
.hand-arrow{
  position:absolute;left:50%;bottom:-32px;transform:translateX(-50%) rotate(-2deg);
  font-family:var(--f-hand-jp);font-size:16px;color:var(--rose-2);
  background:var(--rose-pale);padding:6px 16px;border-radius:999px;
  border:1px dashed var(--rose);white-space:nowrap;letter-spacing:.04em;
  z-index:5;
}

/* — fact card next to the accelerator polaroids — */
.field-fact{
  align-self:start;margin-top:18px;
  background:var(--butter-pale);
  border:1px solid rgba(242,201,92,.5);
  padding:24px 18px;border-radius:6px;
  display:flex;flex-direction:column;gap:8px;align-items:flex-start;
  transform:rotate(1.5deg);
  box-shadow:0 14px 28px -18px rgba(155,122,18,.35);
  position:relative;
}
.field-fact::before{
  content:"";position:absolute;top:-8px;right:14px;width:18px;height:18px;
  background:var(--rose);border-radius:50%;
  box-shadow:0 2px 4px rgba(180,84,111,.4);
}
.fact-num{
  font-family:var(--f-italic);font-style:italic;font-size:80px;color:#9B7A12;line-height:.9;
}
.fact-label{
  font-family:var(--f-disp-jp);font-size:15.5px;color:var(--ink);line-height:1.5;
}
.fact-list{
  font-family:var(--f-en);font-size:11.5px;color:var(--ink-3);letter-spacing:.16em;
  margin-top:4px;border-top:1px dashed rgba(155,122,18,.4);padding-top:8px;align-self:stretch;
}

/* — pull quote next to CERN — */
.field-quote{
  align-self:center;
  position:relative;padding:36px 12px 12px 28px;
}
.field-quote .q-mark{
  position:absolute;left:-10px;top:-10px;
  font-family:var(--f-disp-jp);font-size:90px;color:var(--mauve);opacity:.4;line-height:1;
}
.field-quote p{
  font-family:var(--f-disp-jp);font-size:clamp(17px,1.6vw,21px);color:var(--ink);line-height:1.85;
  letter-spacing:.02em;
}
.field-quote .q-attr{
  display:block;margin-top:16px;
  font-family:var(--f-hand-jp);font-size:14px;color:var(--mauve);letter-spacing:.04em;
}

/* — responsive — */
@media(max-width:980px){
  .field-row{grid-template-columns:repeat(6,1fr);gap:20px}
  .chapter-1-row .p-1,.chapter-1-row .p-2,.chapter-1-row .p-3{grid-column:span 6;transform:none;margin:0 auto;max-width:420px}
  .chapter-1-row .p-2{transform:rotate(1deg)}
  .chapter-1-row .p-1{transform:rotate(-1.2deg)}
  .chapter-1-row .p-3{transform:rotate(-.6deg)}
  .chapter-2-row{grid-template-rows:none}
  .chapter-2-row .p-4,.chapter-2-row .p-5,.chapter-2-row .p-pf{grid-column:auto / span 6;grid-row:auto;transform:none;margin:0 auto;max-width:420px}
  .chapter-2-row .p-4{transform:rotate(-1.2deg)}
  .chapter-2-row .p-pf{transform:rotate(.8deg)}
  .chapter-2-row .p-5{transform:rotate(1.4deg)}
  .chapter-2-row .field-fact{grid-column:auto / span 6;grid-row:auto;transform:none;margin:0 auto;max-width:420px;align-items:center;text-align:center}
  .chapter-2-row .field-fact .fact-list{text-align:center}
  .chapter-3-row .p-6,.chapter-3-row .p-6b,.chapter-3-row .p-8{grid-column:auto / span 4}
  .chapter-3-row .p-6b,.chapter-3-row .p-8{transform:rotate(1.6deg) translateY(0)}
  .chapter-coda .p-7,.chapter-coda .p-7b{grid-column:auto / span 6;grid-row:auto}
  .chapter-coda .p-7b{transform:rotate(.8deg) translateY(0)}
  .chapter-num{font-size:62px}
  .hand-arrow{bottom:-26px;font-size:14px}
}
@media(max-width:520px){
  .field-chapter{flex-wrap:wrap;gap:14px}
  .chapter-rule{display:none}
  .chapter-num{font-size:54px}
  .field-scrapbook{gap:28px}
  .polaroid{padding:10px 10px 18px}
  .polaroid .cap-jp{font-size:14.5px}
  .field-fact{padding:18px 14px}
  .fact-num{font-size:64px}
}

/* ============================================================
   ========  PRESS SCRAPBOOK  ─  media.html only  ============
   ============================================================ */

/* ---- nav active state ---- */
.nav-links a.is-active{color:var(--rose-2);font-weight:700}
.nav-links a.is-active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;
  background:var(--rose);border-radius:2px;
}

/* ============================================================
   media-hero — newsroom corkboard
   ============================================================ */
.media-hero{
  padding:clamp(48px,7vw,96px) 0 clamp(72px,9vw,128px);
  position:relative;isolation:isolate;
}
.media-hero::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 50% 40% at 88% 18%, rgba(220,201,232,.32), transparent 60%),
    radial-gradient(ellipse 40% 35% at 6% 88%, rgba(251,232,238,.4), transparent 60%);
}
.media-hero-grid{
  display:grid;gap:clamp(32px,5vw,72px);
  grid-template-columns:1.05fr .95fr;align-items:center;position:relative;
}
.media-hero-text h1{
  font-family:var(--f-disp-jp);font-weight:400;
  font-size:clamp(40px,7vw,82px);line-height:1.32;color:var(--ink);
  letter-spacing:.01em;margin:18px 0 .4em;
}
.media-hero-sub{
  font-family:var(--f-jp);font-weight:400;
  font-size:clamp(15px,1.6vw,17px);color:var(--ink-2);
  line-height:2;max-width:34em;margin:24px 0 36px;
}
.media-hero-stats{margin-top:48px}
.media-hero-stats .stat-num{font-size:clamp(32px,3.6vw,44px);color:var(--mauve)}
.media-hero-stats .stat-num small{color:var(--ink-3)}

/* corkboard right side */
.media-hero-board{
  position:relative;height:100%;min-height:clamp(440px,38vw,620px);
}

/* big photo on the board */
.hero-photo{
  position:absolute;top:0;right:4%;
  width:min(80%, clamp(320px, 30vw, 460px));
  background:#fff;padding:14px 14px 56px;
  transform:rotate(-2.8deg);
  box-shadow:
    0 1px 2px rgba(0,0,0,.04),
    0 14px 30px -12px rgba(42,39,48,.22),
    0 32px 56px -22px rgba(42,39,48,.16);
  transition:transform .55s cubic-bezier(.2,.8,.2,1);
  z-index:2;
}
.hero-photo:hover{transform:rotate(0) translateY(-4px)}
.hero-photo .washi{top:-12px;left:50%;transform:translateX(-50%) rotate(2deg);width:108px;height:22px}
.hero-photo .stamp{
  position:absolute;bottom:14px;right:14px;
  font-family:var(--f-en);font-weight:700;font-size:10px;
  color:var(--mauve);border:1px solid var(--mauve);
  padding:3px 8px;border-radius:2px;letter-spacing:.18em;
  transform:rotate(-6deg);background:rgba(255,255,255,.8);
}
.hero-photo-img{aspect-ratio:4/3;overflow:hidden;border-radius:2px}
.hero-photo-img img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.95) contrast(1.02)}
.hero-photo figcaption{
  display:flex;flex-direction:column;gap:2px;text-align:center;margin-top:14px;padding:0 4px;
}
.hero-photo .cap-jp{font-family:var(--f-hand-jp);font-size:14.5px;color:#3a3540;line-height:1.5}
.hero-photo .cap-en{font-family:var(--f-en);font-size:10px;color:var(--ink-4);letter-spacing:.18em;text-transform:uppercase}

/* faux-newspaper clipping cards */
.hero-clip{
  position:absolute;background:#FCF8EC;
  padding:14px 16px 12px;
  display:flex;flex-direction:column;gap:6px;
  max-width:240px;
  border:1px solid rgba(216,207,182,.7);
  box-shadow:
    0 1px 2px rgba(0,0,0,.04),
    0 12px 24px -10px rgba(42,39,48,.2);
  transition:transform .45s cubic-bezier(.2,.8,.2,1);
  z-index:3;
}
.hero-clip::before{
  /* top torn rule like newsprint */
  content:"";position:absolute;left:8px;right:8px;top:0;height:2px;
  background:repeating-linear-gradient(90deg,transparent 0 8px,rgba(42,39,48,.4) 8px 9px);
  opacity:.7;
}
.hero-clip .washi{top:-10px;left:14px;width:46px;height:14px;transform:rotate(-8deg)}
.hero-clip:hover{transform:translateY(-3px)}

.clip-asahi{top:18%;left:0;transform:rotate(3.2deg)}
.clip-ntv{bottom:8%;left:8%;transform:rotate(-4deg)}
.clip-nhk{bottom:30%;right:0;transform:rotate(2.4deg)}

.hero-clip .clip-masthead-mini{
  font-family:var(--f-disp-jp);font-weight:700;font-size:14px;color:var(--ink);
  letter-spacing:.06em;border-bottom:2px double rgba(42,39,48,.4);
  padding-bottom:3px;margin-bottom:2px;
}
.hero-clip .clip-channel{
  font-family:var(--f-en);font-weight:700;font-size:9.5px;letter-spacing:.18em;
  color:var(--rose-2);text-transform:uppercase;
}
.hero-clip .clip-headline-mini{
  font-family:var(--f-disp-jp);font-weight:400;font-size:13.5px;color:var(--ink);
  line-height:1.55;
}
.hero-clip .clip-date-mini{
  font-family:var(--f-italic);font-style:italic;font-size:11.5px;color:var(--ink-3);
  letter-spacing:.04em;margin-top:auto;
}

/* sticky note on the board */
.hero-board-note{
  position:absolute;top:6%;left:-2%;
  background:var(--butter-pale);
  padding:14px 18px;
  font-family:var(--f-hand-jp);font-size:14px;color:var(--ink);line-height:1.6;
  transform:rotate(-4deg);
  box-shadow:0 4px 14px -4px rgba(242,201,92,.4);
  z-index:4;
  max-width:160px;
}
.hero-board-note .note-pin{color:var(--rose);font-family:var(--f-en);margin-right:4px}
.hero-board-note::before{
  content:"";position:absolute;top:-7px;left:50%;transform:translateX(-50%) rotate(2deg);
  width:30px;height:11px;background:var(--butter);opacity:.7;border-radius:2px;
}

/* responsive — hero */
@media(max-width:920px){
  .media-hero-grid{grid-template-columns:1fr}
  .media-hero-board{min-height:540px;margin-top:40px}
  .hero-photo{right:0;left:auto;top:0;width:min(72%,400px);transform:rotate(-2deg)}
  .clip-asahi{top:auto;bottom:46%;left:0;width:230px}
  .clip-ntv{bottom:14%;left:6%;width:215px}
  .clip-nhk{bottom:0;right:6%;width:215px}
  .hero-board-note{top:auto;bottom:60%;left:auto;right:0}
}
@media(max-width:520px){
  .media-hero-board{min-height:600px}
  .hero-photo{width:84%;right:6%}
  .hero-clip{max-width:200px;padding:12px 14px}
  .clip-asahi{bottom:50%;left:0}
  .clip-ntv{bottom:18%;left:0}
  .clip-nhk{bottom:0;right:0;left:auto}
  .hero-board-note{display:none}
  .media-hero-stats{margin-top:32px;gap:18px}
  .media-hero-stats .stat-divider{height:32px}
}

/* ============================================================
   featured-section — three big moments
   ============================================================ */
.featured-section{
  position:relative;
  background:linear-gradient(to bottom,transparent,rgba(232,223,200,.22) 30%,rgba(232,223,200,.22) 70%,transparent);
}

/* ── single story spread ── */
.story-spread{
  position:relative;background:#fff;
  border-radius:8px;border:1px solid var(--cream-3);
  padding:clamp(28px,3.2vw,48px);
  margin-top:60px;
  display:grid;gap:clamp(24px,3vw,48px);
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 26px 56px -28px rgba(42,39,48,.24);
  transition:box-shadow .35s,transform .35s;
}
.story-spread::before{
  content:"";position:absolute;left:0;right:0;top:0;height:5px;
  background:repeating-linear-gradient(90deg,transparent 0 13px,rgba(216,207,182,.5) 13px 14px);
  pointer-events:none;border-radius:8px 8px 0 0;
}
.story-spread:hover{box-shadow:0 1px 2px rgba(0,0,0,.04),0 32px 66px -26px rgba(42,39,48,.3)}

/* main story: photo left, text right, outlet strip below */
.story-main{
  grid-template-columns:.95fr 1.05fr;
  grid-template-areas:
    "photo text"
    "strip strip";
}
.story-main .story-photo{grid-area:photo}
.story-main .story-text{grid-area:text}
.story-main .outlet-strip{grid-area:strip;margin-top:8px}

/* mini story: photo top, text bottom */
.story-mini{
  grid-template-columns:1fr;
  grid-template-areas:
    "photo"
    "text";
}

.story-pair{
  margin-top:32px;display:grid;grid-template-columns:1fr 1fr;gap:32px;
}

.story-photo{position:relative}
.story-photo .polaroid{
  width:min(100%,520px);margin:0 auto;
  transform:rotate(-1.6deg);
}
.story-mini .story-photo .polaroid{transform:rotate(1.4deg)}
.story-photo .polaroid:hover{transform:rotate(0) translateY(-4px)}
.story-photo .polaroid-img{aspect-ratio:5/4}
.story-photo .polaroid .washi{top:-12px;left:50%;transform:translateX(-50%) rotate(-3deg);width:104px}

.story-counter{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--f-italic);font-style:italic;font-size:14px;color:var(--mauve);
  background:var(--mauve-pale);padding:5px 14px;border-radius:999px;
  border:1px solid rgba(163,138,196,.3);
  margin-bottom:20px;letter-spacing:.04em;
}
.story-counter .dot{
  width:8px;height:8px;border-radius:50%;background:var(--mauve);
  box-shadow:0 0 0 4px rgba(163,138,196,.18);
}
.story-counter.butter{color:#9B7A12;background:var(--butter-pale);border-color:rgba(242,201,92,.4)}
.story-counter.butter .dot{background:#D9A926;box-shadow:0 0 0 4px rgba(242,201,92,.25)}
.story-counter.sage{color:#3F6B52;background:var(--sage-pale);border-color:rgba(63,107,82,.28)}
.story-counter.sage .dot{background:#5E8B6B;box-shadow:0 0 0 4px rgba(138,174,150,.25)}

.story-title{
  font-family:var(--f-disp-jp);font-weight:400;
  font-size:clamp(28px,3.6vw,46px);line-height:1.4;color:var(--ink);
  margin-bottom:18px;letter-spacing:.005em;
}
.story-title-sm{
  font-family:var(--f-disp-jp);font-weight:400;
  font-size:clamp(22px,2.4vw,30px);line-height:1.45;color:var(--ink);
  margin-bottom:14px;
}

.story-lede{
  font-family:var(--f-jp);font-weight:400;font-size:15.5px;color:var(--ink-2);
  line-height:1.95;margin-bottom:14px;
}
.story-lede b{font-weight:700;color:var(--ink);background:linear-gradient(transparent 70%,var(--butter-pale) 70%);padding:0 2px}

.story-pull{
  position:relative;
  margin-top:22px;padding:22px 22px 22px 36px;
  background:var(--cream);border-left:3px solid var(--mauve);
  font-family:var(--f-disp-jp);font-weight:400;font-size:17px;color:var(--ink);
  line-height:1.95;letter-spacing:.01em;
  background-image:repeating-linear-gradient(0deg,transparent 0 27px,rgba(42,39,48,.07) 27px 28px);
  transform:rotate(.5deg);
}
.story-pull .q{
  position:absolute;left:8px;top:6px;
  font-family:var(--f-disp-jp);font-size:54px;color:var(--mauve);opacity:.45;line-height:1;
}

/* outlet strip — chained chain of media outlets */
.outlet-strip{
  list-style:none;display:flex;flex-wrap:wrap;gap:8px;
  padding:24px 0 0;border-top:1px dashed var(--cream-3);
  margin-top:20px;
}
.outlet-strip li{display:contents}
.outlet-strip li>*{
  display:inline-flex;align-items:baseline;gap:8px;
  padding:7px 12px;border-radius:4px;
  background:var(--cream);border:1px solid var(--cream-3);
  font-family:var(--f-jp);font-weight:500;font-size:13px;color:var(--ink);
  transition:all .25s;
  text-decoration:none;
}
.outlet-strip li>a:hover{
  background:var(--mauve-pale);border-color:rgba(163,138,196,.45);
  color:var(--ink);transform:translateY(-1px);
}
.outlet-strip .om{font-family:var(--f-disp-jp);font-weight:400;color:var(--ink);}
.outlet-strip .od{font-family:var(--f-italic);font-style:italic;color:var(--ink-3);font-size:12px;letter-spacing:.04em}
.outlet-strip li>a em{font-style:normal;color:var(--mauve);font-family:var(--f-en);font-size:11px;font-weight:700}
.outlet-strip li>span{opacity:.78;cursor:default}

.outlet-strip-sm{padding-top:16px;margin-top:14px}
.outlet-strip-sm li>*{font-size:12.5px;padding:5px 10px}

/* press-release link — own announcement, distinct from .outlet-strip */
.press-release-link{
  display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;
  margin:14px 0 4px;padding:9px 14px;border-radius:6px;
  background:var(--cream);border:1px dashed var(--cream-3);
  text-decoration:none;transition:all .25s;
  max-width:100%;
}
.press-release-link:hover{
  background:var(--mauve-pale);border-color:rgba(163,138,196,.45);border-style:solid;
  transform:translateY(-1px);
}
.press-release-link .prl-label{
  font-family:var(--f-jp);font-size:11px;font-weight:700;letter-spacing:.08em;
  color:var(--mauve);
  padding:3px 8px;border-radius:3px;background:rgba(163,138,196,.14);
  flex-shrink:0;
}
.press-release-link .prl-title{
  font-family:var(--f-disp-jp);font-weight:400;font-size:13.5px;color:var(--ink);
}
.press-release-link .prl-date{
  font-family:var(--f-italic);font-style:italic;color:var(--ink-3);
  font-size:12px;letter-spacing:.04em;
}
.press-release-link em{
  font-style:normal;color:var(--mauve);font-family:var(--f-en);
  font-size:11px;font-weight:700;
}

@media(max-width:920px){
  .story-main{grid-template-columns:1fr;grid-template-areas:"photo" "text" "strip"}
  .story-pair{grid-template-columns:1fr;gap:36px}
  .story-photo .polaroid{transform:rotate(-1deg)}
}

/* ============================================================
   broadcast-section — TV / Radio cards
   ============================================================ */
.broadcast-section{position:relative}
.broadcast-grid{
  margin-top:36px;
  display:flex;flex-direction:column;
  border-top:1px solid rgba(42,39,48,.18);
}

/* compact row — no thumbnails, no fake TV/radio decoration */
.broadcast-card{
  position:relative;
  display:flex;flex-wrap:wrap;align-items:center;
  column-gap:18px;row-gap:4px;
  padding:13px 8px;
  border-bottom:1px dashed rgba(42,39,48,.14);
  text-decoration:none;color:inherit;
  transition:background .25s ease;
  isolation:isolate;
}
.broadcast-card:hover{background:rgba(252,247,234,.6)}
.broadcast-card.no-link{cursor:default}
.broadcast-card.no-link:hover{background:transparent;opacity:.88}

/* hide the decorative TV screen / radio wave — they were standing in for thumbnails */
.broadcast-card .bc-screen,
.broadcast-card .bc-wave,
.broadcast-card .bc-static,
.broadcast-card .bc-play{display:none}

.bc-kind{
  position:static;flex:0 0 auto;
  font-family:var(--f-en);font-weight:700;font-size:10px;
  letter-spacing:.22em;padding:3px 9px;border-radius:3px;
  background:var(--ink);color:var(--cream);
  width:54px;text-align:center;
  align-self:center;
}
.kind-radio .bc-kind{background:var(--rose-2)}

.bc-date{
  flex:0 0 132px;
  font-family:var(--f-italic);font-style:italic;font-size:13.5px;color:var(--ink-3);
  letter-spacing:.04em;
}
.bc-channel{
  flex:0 0 auto;
  font-family:var(--f-disp-jp);font-weight:400;font-size:14px;color:var(--rose-2);
  letter-spacing:.04em;
}
.bc-program{
  flex:1 1 220px;min-width:0;
  font-family:var(--f-disp-jp);font-weight:400;font-size:15.5px;color:var(--ink);
  line-height:1.5;
}
.bc-blurb{
  flex:1 1 100%;
  font-family:var(--f-jp);font-weight:400;font-size:12.5px;color:var(--ink-3);
  line-height:1.7;font-style:italic;
  padding-left:80px;
}
.bc-host{
  flex:0 0 auto;margin-left:auto;
  font-family:var(--f-en);font-size:11px;color:var(--ink-3);letter-spacing:.08em;
  display:inline-flex;align-items:center;gap:5px;white-space:nowrap;
  border:0;padding:0;
}
.bc-host em{font-style:normal;color:var(--rose-2);font-weight:700;font-size:13px;line-height:1}
.bc-host.muted{color:var(--ink-4);font-family:var(--f-hand-jp);font-style:normal;font-size:12px;letter-spacing:0}

@media(max-width:760px){
  .broadcast-card{column-gap:12px;row-gap:6px;padding:13px 4px}
  .bc-date{flex-basis:auto;order:2;font-size:12.5px}
  .bc-channel{order:3}
  .bc-program{flex-basis:100%;order:4;font-size:14.5px}
  .bc-blurb{padding-left:0;order:5}
  .bc-host{order:6;margin-left:0}
}

/* ============================================================
   archive-section — newspaper clip cards
   ============================================================ */
.archive-section{
  position:relative;
  background:linear-gradient(to bottom,transparent 0,rgba(229,239,231,.18) 20%,rgba(236,227,244,.16) 60%,transparent 100%);
}
.clip-archive{
  margin-top:64px;display:flex;flex-direction:column;gap:36px;
}
.clip-year{
  margin-top:18px;
}
.clip-year .chapter-num{
  font-family:var(--f-disp-en);font-style:italic;font-weight:700;
  font-size:96px;line-height:.85;color:var(--ink);letter-spacing:-.03em;
  text-shadow:3px 3px 0 var(--rose-pale);
}
.clip-year.tone-mauve .chapter-num{text-shadow:3px 3px 0 var(--mauve-pale)}
.clip-year.tone-sage .chapter-num{text-shadow:3px 3px 0 var(--sage-pale)}
.clip-year.tone-butter .chapter-num{text-shadow:3px 3px 0 var(--butter-pale)}

.clip-grid{
  display:flex;flex-direction:column;
  padding:6px 0 14px;
  border-top:1px solid rgba(42,39,48,.18);
}

/* ── clip-card: compact newsprint row ── */
.clip-card{
  position:relative;
  display:flex;flex-wrap:wrap;align-items:center;
  column-gap:16px;row-gap:4px;
  background:transparent;
  padding:13px 8px;
  border:0;border-bottom:1px dashed rgba(42,39,48,.14);
  border-radius:0;
  transform:none;box-shadow:none;
  text-decoration:none;color:inherit;
  transition:background .25s ease;
  isolation:isolate;
}
.clip-card::before,
.clip-card::after{display:none}
.clip-card:hover{transform:none;background:rgba(252,247,234,.6);box-shadow:none}
.clip-card.no-link{cursor:default}
.clip-card.no-link:hover{background:transparent;opacity:.85}

/* drop the per-card washi tape — keep washi only at year-chapter level */
.clip-card .washi{display:none}

.clip-masthead{
  position:static;z-index:auto;
  flex:0 0 142px;
  font-family:var(--f-disp-jp);font-weight:700;font-size:14px;color:var(--ink);
  letter-spacing:.06em;
  border-right:1px solid rgba(42,39,48,.18);
  padding-right:12px;
}
/* drop the underline rule */
.clip-rule{display:none}

.clip-headline{
  position:static;z-index:auto;
  flex:1 1 280px;min-width:0;
  font-family:var(--f-disp-jp);font-weight:400;font-size:15px;color:var(--ink);
  line-height:1.55;letter-spacing:.005em;margin:0;
}
.clip-blurb{
  position:static;z-index:auto;
  flex:1 1 100%;
  font-family:var(--f-jp);font-weight:400;font-size:12.5px;color:var(--ink-3);
  line-height:1.7;font-style:italic;
  border:0;padding-left:154px;margin:0;
}
.clip-meta{
  flex:0 0 auto;margin:0 0 0 auto;padding:0;border:0;
  font-family:var(--f-italic);font-style:italic;font-size:13px;color:var(--ink-3);
  display:inline-flex;align-items:center;gap:14px;white-space:nowrap;
  letter-spacing:.04em;position:static;z-index:auto;
}
.clip-meta time{color:var(--rose-2);font-weight:500}
.clip-host{
  font-family:var(--f-en);font-style:normal;font-size:10.5px;color:var(--ink-3);
  letter-spacing:.1em;display:inline-flex;align-items:center;gap:5px;
}
.clip-host em{font-style:normal;color:var(--rose-2);font-weight:700;font-size:13px;line-height:1}

/* `.ostub` (no-link inline list items elsewhere on the page) — keep tidy */

@media(max-width:760px){
  .clip-card{column-gap:10px;row-gap:6px;padding:13px 4px}
  .clip-masthead{flex-basis:auto;border-right:0;padding-right:0;font-size:13px}
  .clip-headline{flex-basis:100%;font-size:14.5px}
  .clip-blurb{padding-left:0}
  .clip-meta{flex-basis:100%;margin-left:0;justify-content:flex-start}
}

/* ============================================================
   serial-section — column stack + web cards
   ============================================================ */
.serial-section{position:relative}
.serial-layout{
  margin-top:60px;display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start;
}
@media(max-width:920px){.serial-layout{grid-template-columns:1fr;gap:48px}}

.serial-stack{
  position:relative;
  background:#fff;border-radius:8px;padding:36px 32px 32px;
  border:1px solid var(--cream-3);
  box-shadow:
    0 1px 2px rgba(0,0,0,.04),
    0 22px 44px -22px rgba(42,39,48,.22);
}
.serial-stack::before{
  /* spine */
  content:"";position:absolute;top:0;bottom:0;left:0;width:6px;
  background:linear-gradient(180deg,var(--butter) 0%,var(--rose) 50%,var(--mauve) 100%);
  border-radius:8px 0 0 8px;
}
.serial-stack::after{
  /* corner fold */
  content:"";position:absolute;top:0;right:0;width:36px;height:36px;
  background:linear-gradient(225deg,var(--cream-2) 50%,var(--cream-3) 50%);
  clip-path:polygon(100% 0,100% 100%,0 0);
  border-radius:0 8px 0 0;
}
.serial-tag{
  display:inline-block;font-family:var(--f-italic);font-style:italic;font-size:13.5px;
  color:#9B7A12;background:var(--butter-pale);
  padding:4px 14px;border-radius:999px;letter-spacing:.04em;
  border:1px solid rgba(242,201,92,.4);margin-bottom:14px;
}
.serial-stack h3{
  font-family:var(--f-disp-jp);font-weight:400;font-size:22px;color:var(--ink);
  line-height:1.5;margin-bottom:14px;
}
.serial-stack p{
  font-family:var(--f-jp);font-weight:400;font-size:14px;color:var(--ink-2);
  line-height:1.95;margin-bottom:24px;
}
.serial-issues{
  list-style:none;display:flex;flex-direction:column;gap:0;
  border-top:1px dashed var(--cream-3);
}
.serial-issues li{border-bottom:1px dashed var(--cream-3)}
.serial-issues a{
  display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;
  padding:16px 4px;color:inherit;text-decoration:none;
  transition:padding .25s,background .25s;
}
.serial-issues a:hover{background:var(--butter-pale);padding-inline:14px}
.iss-num{
  font-family:var(--f-italic);font-style:italic;font-size:22px;color:#9B7A12;
  min-width:48px;
}
.iss-body{display:flex;flex-direction:column;gap:2px}
.iss-title{font-family:var(--f-disp-jp);font-size:15.5px;color:var(--ink);line-height:1.5}
.iss-year{font-family:var(--f-jp);font-weight:400;font-size:12.5px;color:var(--ink-3)}
.serial-issues a em{font-style:normal;color:var(--ink-3);font-family:var(--f-en);font-size:14px;transition:color .25s,transform .25s}
.serial-issues a:hover em{color:#9B7A12;transform:translateX(4px)}

/* ── web cards ── */
.web-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:18px;
}
@media(max-width:520px){.web-grid{grid-template-columns:1fr}}
.web-card{
  position:relative;display:flex;flex-direction:column;gap:8px;
  background:#fff;border-radius:6px;
  padding:20px 22px 18px;border:1px solid var(--cream-3);
  text-decoration:none;color:inherit;
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 10px 22px -14px rgba(42,39,48,.2);
  transition:transform .35s,box-shadow .35s,border-color .35s;
}
.web-card:hover{transform:translateY(-3px);border-color:rgba(180,84,111,.25);box-shadow:0 1px 2px rgba(0,0,0,.04),0 18px 36px -16px rgba(42,39,48,.28)}
.web-card.no-link{cursor:default;opacity:.92}
.web-card.no-link:hover{transform:none}
.web-card.highlight{
  background:linear-gradient(135deg,#fff 0%,var(--butter-pale) 100%);
  border-color:rgba(242,201,92,.5);
}
.web-host{
  font-family:var(--f-italic);font-style:italic;font-size:12.5px;color:var(--rose-2);
  letter-spacing:.04em;
}
.web-title{
  font-family:var(--f-disp-jp);font-weight:400;font-size:15.5px;color:var(--ink);
  line-height:1.6;
}
.web-meta{
  margin-top:auto;padding-top:10px;border-top:1px dashed var(--cream-3);
  display:flex;justify-content:space-between;align-items:baseline;
  font-family:var(--f-italic);font-style:italic;font-size:12.5px;color:var(--ink-3);
}
.web-meta time{color:var(--rose-2);font-weight:500;letter-spacing:.06em}
.web-meta em{font-style:normal;color:var(--rose-2);font-family:var(--f-en);font-size:13px;font-weight:700}

/* ============================================================
   press-kit-section — dual cards override
   ============================================================ */
.press-kit-section{position:relative}
.press-dual{margin-top:60px}
.press-dual .dual-card.press-contact{
  background:var(--mauve-pale);border-color:#D5C5E0;
}
.press-dual .dual-card.press-contact .tag{color:#6B5A8F}
.press-dual .dual-card.press-contact li::before{color:#6B5A8F}

.press-dual .dual-card.press-assets{
  background:var(--sage-pale);border-color:#C8DBCB;
}
.press-dual .dual-card.press-assets .tag{color:#4A7659}
.press-dual .dual-card.press-assets li::before{color:#4A7659}

.press-dual .dual-card li b{
  font-family:var(--f-disp-jp);font-weight:700;color:var(--ink);
  margin-right:6px;
}
.press-dual .dual-card li a{
  color:var(--ink);border-bottom:1px solid var(--ink);
}
.press-dual .dual-card li a:hover{color:var(--rose-2);border-color:var(--rose-2)}

/* ============================================================
   final-cta tweak — signature
   ============================================================ */
.final-cta .signature{
  position:relative;margin-top:32px;
  font-family:var(--f-hand-jp);font-size:14.5px;color:var(--rose-2);
}

/* ============================================================
   ledger-section — complete record (appendix)
   ============================================================ */
.ledger-section{
  position:relative;
  background:linear-gradient(to bottom,transparent 0,rgba(232,223,200,.18) 50%,transparent 100%);
}
.ledger{
  margin-top:60px;
  background:#fff;border:1px solid var(--cream-3);border-radius:8px;
  padding:clamp(28px,3.5vw,52px);
  display:flex;flex-direction:column;gap:42px;
  box-shadow:
    0 1px 2px rgba(0,0,0,.04),
    0 22px 44px -22px rgba(42,39,48,.22);
  position:relative;
}
.ledger::before{
  /* Spine — colored ribbon down the left */
  content:"";position:absolute;top:0;bottom:0;left:0;width:5px;
  background:linear-gradient(180deg,var(--rose) 0%,var(--mauve) 35%,var(--sage) 70%,var(--butter) 100%);
  border-radius:8px 0 0 8px;
}
.ledger::after{
  /* Bottom rule like a closing ledger book */
  content:"";position:absolute;left:24px;right:24px;bottom:8px;
  height:1px;border-top:1px dashed var(--cream-3);pointer-events:none;
}

.ledger-year{display:flex;flex-direction:column;gap:0}

.ledger-year-head{
  display:flex;align-items:baseline;gap:14px;
  border-bottom:1.5px solid var(--ink);
  padding-bottom:8px;margin-bottom:6px;position:relative;
}
.ledger-year-num{
  font-family:var(--f-disp-en);font-style:italic;font-weight:700;
  font-size:30px;color:var(--ink);letter-spacing:-.01em;line-height:1;
}
.ledger-year-count{
  font-family:var(--f-italic);font-style:italic;font-size:13px;color:var(--ink-3);
  letter-spacing:.03em;
}
.ledger-year-rule{
  flex:1;height:1px;align-self:center;margin-top:6px;
  background-image:linear-gradient(to right,var(--cream-3) 0 6px,transparent 6px 12px);
  background-size:12px 1px;background-repeat:repeat-x;
}

.ledger-row{
  display:grid;
  grid-template-columns:60px 1fr 70px 18px;
  grid-template-areas:"pill outlet date arrow"
                      ".    title title title";
  column-gap:14px;row-gap:2px;align-items:baseline;
  padding:11px 6px;border-bottom:1px dashed var(--cream-3);
  font-family:var(--f-jp);font-weight:500;font-size:14px;color:var(--ink);
  transition:background .25s,padding .25s;
  text-decoration:none;
  position:relative;
}
.ledger-row:last-child{border-bottom:0}
.ledger-row:hover{background:var(--cream-2);padding-inline:14px}
.ledger-row.no-link{cursor:default;color:var(--ink-2);opacity:.88}
.ledger-row.no-link:hover{background:transparent;padding-inline:6px}

.ledger-pill{
  grid-area:pill;
  font-family:var(--f-en);font-weight:700;font-size:9px;letter-spacing:.18em;
  padding:3px 6px;border-radius:3px;text-align:center;text-transform:uppercase;
  align-self:center;
}
.ledger-pill.pill-tv{background:var(--ink);color:var(--cream)}
.ledger-pill.pill-radio{background:var(--rose-2);color:#fff}
.ledger-pill.pill-press{background:var(--mauve);color:#fff}
.ledger-pill.pill-mag{background:#9B7A12;color:var(--butter-pale)}
.ledger-pill.pill-web{background:var(--sage);color:#fff}
.ledger-pill.pill-pr{background:#3D6B8A;color:#fff}

.ledger-outlet{
  grid-area:outlet;
  font-family:var(--f-disp-jp);font-weight:400;color:var(--ink);
  letter-spacing:.04em;font-size:14.5px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.ledger-row.no-link .ledger-outlet{color:var(--ink-2)}

.ledger-title{
  grid-area:title;
  font-family:var(--f-jp);font-weight:400;font-size:13.5px;color:var(--ink-2);
  line-height:1.7;letter-spacing:.02em;
  padding-left:0;
}

.ledger-date{
  grid-area:date;
  font-family:var(--f-italic);font-style:italic;font-size:13px;color:var(--rose-2);
  letter-spacing:.04em;text-align:right;font-weight:500;
  align-self:center;
}
.ledger-row.no-link .ledger-date{color:var(--ink-3)}

.ledger-arrow{
  grid-area:arrow;
  font-family:var(--f-en);font-weight:700;font-size:14px;color:var(--rose-2);
  text-align:center;align-self:center;
  transition:transform .25s,color .25s;
}
.ledger-row:hover .ledger-arrow{transform:translateX(3px)}
.ledger-row.no-link .ledger-arrow{color:var(--ink-4);font-weight:400;font-size:18px;line-height:.5}

@media(max-width:760px){
  .ledger{padding:24px 18px;gap:32px}
  .ledger-row{
    grid-template-columns:auto 1fr auto;
    grid-template-areas:"pill outlet date"
                        "title title title";
    column-gap:10px;
  }
  .ledger-row .ledger-arrow{display:none}
  .ledger-outlet{font-size:13.5px;white-space:normal}
  .ledger-title{font-size:13px;color:var(--ink-2);padding-top:2px}
  .ledger-date{font-size:12px;text-align:right}
  .ledger-pill{font-size:8.5px;padding:3px 6px}
}

.ledger-foot{
  display:flex;flex-direction:column;align-items:center;gap:14px;
  margin-top:8px;padding-top:24px;
  border-top:1.5px solid var(--ink);
  position:relative;
}
.ledger-foot::before{
  content:"✦";position:absolute;top:-10px;left:50%;transform:translateX(-50%);
  background:#fff;color:var(--rose);padding:0 12px;font-size:14px;
}
.ledger-foot-note{
  font-family:var(--f-hand-jp);font-size:13.5px;color:var(--ink-3);
  text-align:center;line-height:1.8;letter-spacing:.02em;
}
.ledger-foot-note a{color:var(--rose-2);border-bottom:1px solid var(--rose-2)}
.ledger-foot-note a:hover{color:var(--rose)}

/* ============================================================
   EVENT.HTML — additions only, scoped where possible
   ============================================================ */

/* nav active state (also used by media.html / about.html) */
.nav-link-text.is-active{color:var(--rose-2);font-weight:700}
.nav-link-text.is-active::after{
  content:"";display:block;height:2px;width:100%;
  background:var(--rose);margin-top:2px;border-radius:1px;
}

/* event hero — drop the bg image overlay used in LP, since we don't have one yet */
.event-hero::before{display:none}
.event-hero::after{
  background:linear-gradient(to bottom, rgba(250,246,235,0) 80%, var(--cream,#FAF6EB) 100%);
}
.event-hero .hero-tag{margin-bottom:24px}
.event-hero .hero-stats{margin-top:48px;gap:28px}
.event-hero .stat-label{line-height:1.5}
.event-hero .stat-label em{font-style:italic;font-family:var(--f-italic);color:var(--ink-4);font-size:.92em;letter-spacing:.06em}

/* ============================================================
   01 OFFERINGS — 6 index-card grid
   ============================================================ */
.offerings-section{position:relative}
.offerings-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:44px 28px;margin-top:64px;
}
@media(max-width:1024px){.offerings-grid{grid-template-columns:repeat(2,1fr);gap:52px 24px}}
@media(max-width:600px){.offerings-grid{grid-template-columns:1fr;gap:44px}}

.offering{
  position:relative;background:#fff;
  border:1px solid var(--cream-3);border-radius:8px;
  padding:42px 30px 28px;
  display:flex;flex-direction:column;gap:14px;
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 18px 36px -22px rgba(42,39,48,.22);
  transition:transform .45s cubic-bezier(.2,.8,.2,1),box-shadow .35s,border-color .35s;
  isolation:isolate;
}
.offering:nth-child(odd){transform:rotate(-.55deg)}
.offering:nth-child(even){transform:rotate(.6deg) translateY(8px)}
.offering:hover{
  transform:rotate(0) translateY(-4px);
  box-shadow:0 1px 2px rgba(0,0,0,.05),0 28px 50px -20px rgba(42,39,48,.28);
  border-color:rgba(180,84,111,.18);
}
.offering .washi{
  top:-12px;left:30px;width:96px;height:20px;
  transform:rotate(var(--wr,-3deg));
}
.offering:nth-child(2) .washi,
.offering:nth-child(4) .washi,
.offering:nth-child(6) .washi{left:auto;right:30px;--wr:4deg}
.offering-num{
  font-family:var(--f-italic);font-style:italic;font-size:13px;
  color:var(--rose-2);letter-spacing:.22em;text-transform:uppercase;
}
.offering-title{
  font-family:var(--f-disp-jp);font-size:22px;color:var(--ink);font-weight:400;
  line-height:1.5;margin:0;letter-spacing:.02em;
}
.offering-desc{
  font-size:14.5px;color:var(--ink-2);line-height:1.95;
  font-family:var(--f-jp);font-weight:400;
}
.offering-meta{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px 14px;
  padding-top:14px;margin-top:4px;border-top:1px dashed var(--cream-3);
}
.offering-meta div{display:flex;flex-direction:column;gap:2px}
.offering-meta dt{
  font-family:var(--f-en);font-weight:700;font-size:10px;color:var(--ink-3);
  letter-spacing:.18em;text-transform:uppercase;
}
.offering-meta dd{
  font-family:var(--f-jp);font-weight:500;font-size:13px;color:var(--ink);
  line-height:1.55;letter-spacing:.02em;
}
.offering-track{
  font-family:var(--f-italic);font-style:italic;font-size:12.5px;
  color:var(--ink-3);letter-spacing:.02em;line-height:1.7;
  margin-top:auto;padding-top:14px;border-top:1px dashed var(--cream-3);
}
@media(max-width:600px){
  .offering-meta{grid-template-columns:1fr 1fr;gap:8px 12px}
}

/* ============================================================
   02 FLOW-DAY — 5-step variant of LP .flow
   ============================================================ */
.flow.flow-day{grid-template-columns:repeat(5,1fr);gap:24px 14px}
.flow.flow-day::before{left:8%;right:8%}
.flow.flow-day .step:nth-child(n){grid-column:auto/span 1;border-top:0}
.flow.flow-day .step:nth-child(1){transform:rotate(-1.2deg)}
.flow.flow-day .step:nth-child(2){transform:rotate(.8deg) translateY(-6px)}
.flow.flow-day .step:nth-child(3){transform:rotate(-.5deg) translateY(2px)}
.flow.flow-day .step:nth-child(4){transform:rotate(1.4deg)}
.flow.flow-day .step:nth-child(5){transform:rotate(-1deg) translateY(4px)}
.flow.flow-day .step:hover{transform:rotate(0) translateY(-4px)}
@media(max-width:1100px){
  .flow.flow-day{grid-template-columns:repeat(3,1fr)}
  .flow.flow-day .step:nth-child(n){grid-column:span 1}
  .flow.flow-day::before{display:none}
}
@media(max-width:760px){
  .flow.flow-day{grid-template-columns:1fr;gap:36px}
  .flow.flow-day .step:nth-child(n){transform:none;grid-column:1/-1}
}

/* step photo thumbnail — flow-day only */
.flow-day .step{padding-top:0}
.flow-day .step-photo{
  margin:0 -22px 18px;
  height:150px;
  overflow:hidden;
  border-radius:6px 6px 0 0;
  position:relative;
}
.flow-day .step-photo img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .55s cubic-bezier(.2,.8,.2,1);
}
.flow-day .step:hover .step-photo img{transform:scale(1.06)}
/* number badge stuck onto the photo — overrides the default .step-num
   so the cosmicray.html flow (which still uses .step-icon icons) is untouched */
.flow-day .step-photo .step-num{
  top:12px;right:12px;left:auto;
  width:38px;height:38px;
  font-size:18px;
  letter-spacing:.01em;
  background:var(--butter);color:var(--ink);
  box-shadow:
    0 0 0 3px rgba(255,253,247,.92),
    0 6px 14px -4px rgba(42,39,48,.32);
  transform:rotate(-5deg);
  transition:transform .45s cubic-bezier(.2,.8,.2,1);
  z-index:2;
}
.flow-day .step:hover .step-photo .step-num{transform:rotate(0) scale(1.04)}
@media(max-width:760px){
  .flow-day .step-photo{height:200px}
  .flow-day .step-photo .step-num{width:42px;height:42px;font-size:20px;top:14px;right:14px}
}

/* ============================================================
   04 INTL band (under map)
   ============================================================ */
.intl-band{
  margin-top:64px;padding:28px 32px;
  background:rgba(255,253,247,.7);border-radius:6px;
  border:1px dashed var(--cream-3);
  display:flex;flex-direction:column;gap:18px;
  position:relative;
}
.intl-eyebrow{
  font-family:var(--f-italic);font-style:italic;font-size:14.5px;color:var(--rose-2);
  letter-spacing:.04em;
}
.intl-list{
  list-style:none;display:flex;flex-wrap:wrap;gap:18px 36px;padding:0;margin:0;
}
.intl-list li{
  display:flex;flex-direction:column;gap:1px;
  font-family:var(--f-jp);font-size:14px;color:var(--ink);
}
.intl-list b{
  font-family:var(--f-disp-en);font-weight:700;font-style:italic;
  font-size:18px;color:var(--ink);letter-spacing:.02em;
}
.intl-list em{
  font-style:normal;font-family:var(--f-italic);font-style:italic;
  font-size:12px;color:var(--ink-3);letter-spacing:.06em;
}

/* ============================================================
   05 UPCOMING — 3-card calendar tease
   ============================================================ */
.upcoming-section{position:relative}
.upcoming-section::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 70% 50% at 90% 10%, rgba(247,196,161,.18), transparent 60%);
}
.upcoming-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  margin-top:60px;
}
@media(max-width:920px){.upcoming-grid{grid-template-columns:1fr 1fr;gap:24px}}
@media(max-width:600px){.upcoming-grid{grid-template-columns:1fr}}

.upcoming-card{
  position:relative;background:#fff;
  border:1px solid var(--cream-3);border-radius:6px;
  padding:42px 28px 28px;
  display:flex;flex-direction:column;gap:14px;
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 16px 30px -18px rgba(42,39,48,.2);
  transition:transform .45s,box-shadow .35s;
}
.upcoming-card:hover{transform:translateY(-4px);box-shadow:0 1px 2px rgba(0,0,0,.05),0 24px 44px -20px rgba(42,39,48,.28)}
.upcoming-card .washi{top:-12px;left:50%;transform:translateX(-50%) rotate(-3deg);width:90px}
.upcoming-pill{
  display:inline-block;align-self:flex-start;
  font-family:var(--f-italic);font-style:italic;font-size:12.5px;
  color:var(--rose-2);background:var(--rose-pale);
  padding:3px 12px;border-radius:999px;letter-spacing:.04em;
  border:1px solid rgba(215,122,149,.25);
}
.upcoming-card:nth-child(2) .upcoming-pill{color:#3F6B52;background:var(--sage-pale);border-color:rgba(63,107,82,.22)}
.upcoming-card:nth-child(3) .upcoming-pill{color:#9B7A12;background:var(--butter-pale);border-color:rgba(155,122,18,.28)}

.upcoming-date{
  display:flex;align-items:baseline;gap:10px;
  padding-bottom:8px;border-bottom:1px dashed var(--cream-3);
}
.up-month{
  font-family:var(--f-en);font-weight:700;font-size:14px;
  color:var(--rose-2);letter-spacing:.16em;text-transform:uppercase;
}
.up-day{
  font-family:var(--f-disp-jp);font-weight:400;
  font-size:42px;color:var(--ink);line-height:1;letter-spacing:.02em;
}
.up-year{
  font-family:var(--f-italic);font-style:italic;font-size:13px;
  color:var(--ink-3);letter-spacing:.04em;margin-left:auto;text-transform:uppercase;
}
.upcoming-title{
  font-family:var(--f-disp-jp);font-size:19px;color:var(--ink);
  line-height:1.55;font-weight:400;margin:0;letter-spacing:.02em;
}
.upcoming-desc{
  font-size:14px;color:var(--ink-2);line-height:1.85;
  font-family:var(--f-jp);font-weight:400;
}
.upcoming-meta{
  font-family:var(--f-hand-jp);font-size:13px;color:var(--rose-2);
  letter-spacing:.04em;margin-top:auto;
}
.upcoming-card.upcoming-cta{
  background:linear-gradient(155deg,var(--rose-pale),#FFF5F8);
  border-color:rgba(215,122,149,.3);
  text-align:center;align-items:center;
}
.upcoming-card.upcoming-cta .upcoming-title{font-size:21px;color:var(--rose-2);line-height:1.5}
.upcoming-card.upcoming-cta .upcoming-desc{color:var(--ink)}
.upcoming-card.upcoming-cta .btn{margin-top:8px}

/* ============================================================
   06 ARCHIVE — magazine record
   ============================================================ */
.archive-section{position:relative}
.archive-section::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 60% 40% at 0% 5%, rgba(220,201,232,.16), transparent 60%),
    radial-gradient(ellipse 60% 40% at 100% 95%, rgba(247,196,161,.14), transparent 60%);
}

/* jumper — タイポグラフィー型年ナビ */
.archive-jumper{
  display:flex;gap:0;flex-wrap:wrap;
  margin-top:48px;padding:16px 0;
  background:none;border-radius:0;
  border-top:1px solid var(--cream-3);
  border-bottom:1px solid var(--cream-3);
  align-items:center;justify-content:center;
  position:relative;
}
.archive-jumper::before{
  content:'年代で絞る';
  font-family:var(--f-italic);font-style:italic;
  font-size:11px;color:var(--ink-3);letter-spacing:.14em;
  position:absolute;top:-8px;left:50%;transform:translateX(-50%);
  background:var(--cream);padding:0 14px;
  white-space:nowrap;
}
.archive-jumper a{
  font-family:var(--f-disp-en);font-style:italic;font-weight:700;
  font-size:16px;color:var(--ink-2);
  padding:2px 18px;line-height:1;
  border-right:1px solid var(--cream-3);
  transition:color .2s;
  letter-spacing:.02em;
}
.archive-jumper a:last-child{border-right:none}
.archive-jumper a:hover{
  color:var(--rose-2);
}

/* category legend */
.archive-legend{
  display:flex;gap:8px;flex-wrap:wrap;align-items:center;
  margin-top:24px;padding:0 4px;
}
.al-label{
  font-family:var(--f-italic);font-style:italic;font-size:13px;
  color:var(--ink-3);letter-spacing:.04em;margin-right:6px;
}
.archive-cat{
  display:inline-block;font-family:var(--f-en);font-weight:700;
  font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
  padding:3px 10px;border-radius:999px;
  background:var(--cream-2);color:var(--ink-3);
  border:1px solid var(--cream-3);
  white-space:nowrap;line-height:1.6;
}
.archive-cat.cat-cosmic{background:var(--rose-pale);color:var(--rose-2);border-color:rgba(215,122,149,.3)}
.archive-cat.cat-radiation{background:var(--sage-pale);color:#3F6B52;border-color:rgba(63,107,82,.28)}
.archive-cat.cat-school{background:var(--mauve-pale);color:#5C3D80;border-color:rgba(92,61,128,.28)}
.archive-cat.cat-museum{background:var(--butter-pale);color:#9B7A12;border-color:rgba(155,122,18,.28)}
.archive-cat.cat-steam{background:#DCEFE0;color:#3F6B52;border-color:rgba(63,107,82,.22)}
.archive-cat.cat-booth{background:#EAE0F1;color:var(--mauve);border-color:rgba(163,138,196,.32)}
.archive-cat.cat-intl{background:#E2EBF3;color:#3D6E92;border-color:rgba(61,110,146,.28)}
.archive-cat.cat-progress{background:var(--cream-2);color:var(--ink-2);border-color:var(--cream-3)}

/* year section */
.archive-year{margin-top:64px;scroll-margin-top:90px}
.ay-head{
  display:flex;align-items:flex-end;gap:22px;
  padding-bottom:14px;
  border-bottom:1px dashed var(--cream-3);
  flex-wrap:wrap;
}
.ay-yr{
  font-family:var(--f-disp-en);font-style:italic;font-weight:700;
  font-size:clamp(48px,6vw,68px);color:var(--ink);line-height:.9;letter-spacing:-.01em;
}
.ay-rule{flex:1;display:none}
.ay-note{
  font-family:var(--f-hand-jp);font-size:14.5px;color:var(--rose-2);
  letter-spacing:.02em;line-height:1.7;flex:1;padding-bottom:10px;min-width:240px;
}

/* archive list */
.archive-list{list-style:none;margin:8px 0 0;padding:0}
.archive-row{
  display:grid;
  grid-template-columns:130px 110px 1fr 28px;
  gap:18px;align-items:start;
  padding:18px 4px;
  border-bottom:1px dashed var(--cream-3);
  transition:background .25s,padding-inline .25s;
  position:relative;
}
.archive-row:hover{background:rgba(255,253,247,.6);padding-inline:14px}
.archive-row .archive-date{
  font-family:var(--f-italic);font-style:italic;font-size:15px;
  color:var(--rose-2);letter-spacing:.02em;line-height:1.5;
  padding-top:2px;
}
.archive-row .archive-cat{margin-top:1px;justify-self:start}
.archive-body{display:flex;flex-direction:column;gap:4px;min-width:0}
.archive-title{
  font-family:var(--f-disp-jp);font-size:16.5px;color:var(--ink);
  font-weight:400;line-height:1.55;margin:0;letter-spacing:.02em;
}
.archive-meta{
  font-family:var(--f-jp);font-weight:400;font-size:13px;color:var(--ink-2);
  line-height:1.7;letter-spacing:.02em;margin:0;
}
.archive-note{
  font-family:var(--f-italic);font-style:italic;font-size:13px;
  color:var(--ink-3);line-height:1.7;letter-spacing:.02em;margin:2px 0 0;
}
.archive-row .archive-link{
  width:20px;height:20px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-disp-en);font-size:13px;
  padding:0;align-self:center;
}
.archive-row span.archive-link[aria-hidden]{
  opacity:0;pointer-events:none;
}
.archive-row a.archive-link{
  color:var(--rose-2);opacity:.35;
  transition:opacity .2s;
  transform:none;
}
/* カード用 .archive-link:hover の transform がここに干渉しないよう上書き */
.archive-row a.archive-link:hover{
  transform:none;
  box-shadow:none;
  background:none;
  border-color:transparent;
}
/* stretched link — a::after が archive-row 全体を覆う */
.archive-row a.archive-link::after{
  content:'';
  position:absolute;inset:0;
  cursor:pointer;
}
.archive-row:hover a.archive-link{opacity:1}

@media(max-width:760px){
  .archive-row{
    grid-template-columns:auto auto 1fr 22px;
    grid-template-areas:
      "date cat . link"
      "body body body body";
    gap:6px 12px;padding:16px 2px;
  }
  .archive-row .archive-date{grid-area:date;font-size:13.5px;padding-top:0}
  .archive-row .archive-cat{grid-area:cat;justify-self:start;font-size:9.5px;padding:2px 8px}
  .archive-body{grid-area:body;padding-left:0;margin-top:4px}
  .archive-row .archive-link{grid-area:link;padding:0;justify-self:end;align-self:center}
  .archive-title{font-size:15.5px}
}

.archive-postscript{
  margin-top:48px;padding:26px 32px;
  background:var(--butter-pale);border-radius:6px;
  font-family:var(--f-jp);font-weight:400;font-size:14px;
  color:var(--ink-2);line-height:1.95;
  border:1px dashed rgba(155,122,18,.32);
  position:relative;text-align:center;
}
.archive-postscript .ps-mark{
  display:inline-block;color:#9B7A12;font-size:18px;margin-right:6px;
}
.archive-postscript a{
  color:var(--rose-2);border-bottom:1px solid var(--rose);padding-bottom:1px;
}
.archive-postscript a:hover{color:var(--rose-2);background:var(--rose-pale)}

/* ============================================================
   07 PARTNERS — 4-col logo grid (event variant: 4×2)
   ============================================================ */
.partners-section{position:relative}
.backers-grid-event{
  grid-template-columns:repeat(4,1fr);gap:24px;
}
@media(max-width:920px){.backers-grid-event{grid-template-columns:1fr 1fr;gap:28px}}
@media(max-width:520px){.backers-grid-event{grid-template-columns:1fr}}
.backers-grid-event .backer-logo{
  background:var(--cream-2);
  height:88px;border-radius:4px;
}
.logo-text{
  font-family:var(--f-disp-jp);font-weight:400;font-size:22px;color:var(--ink);
  letter-spacing:.04em;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:2px;
  position:relative;z-index:1;line-height:1.3;
}
.logo-text small{
  font-family:var(--f-italic);font-style:italic;font-size:11.5px;color:var(--rose-2);
  letter-spacing:.06em;font-weight:400;
}
.partners-foot{
  margin-top:36px;padding:22px 32px;
  font-family:var(--f-jp);font-weight:400;font-size:13.5px;color:var(--ink-2);
  line-height:1.95;letter-spacing:.02em;text-align:center;
  background:rgba(255,253,247,.7);border-radius:6px;border:1px dashed var(--cream-3);
}

/* ============================================================
   08 COMMISSION
   ============================================================ */
.commission-section{position:relative}
.commission-card{padding:38px 32px 30px}
.commission-card .commission-lede{
  font-family:var(--f-disp-jp);font-size:15.5px;color:var(--ink);
  line-height:1.85;margin:0 0 18px;letter-spacing:.02em;
}
.commission-card ul{margin-bottom:24px}
.commission-card li b{color:var(--ink);font-weight:700;margin-right:4px;letter-spacing:.04em}

.inquiry-block{
  margin-top:48px;padding:36px 40px;
  background:#fff;border-radius:8px;
  border:1px solid var(--cream-3);
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 18px 36px -22px rgba(42,39,48,.18);
  position:relative;
}
.inquiry-block::before{
  content:"";position:absolute;left:0;right:0;top:0;height:4px;
  background:repeating-linear-gradient(90deg, transparent 0 11px, rgba(216,207,182,.5) 11px 12px);
  pointer-events:none;border-radius:8px 8px 0 0;
}
.inquiry-title{
  font-family:var(--f-disp-jp);font-weight:400;font-size:20px;color:var(--ink);
  margin-bottom:22px;letter-spacing:.04em;
}
.inquiry-list{list-style:none;display:flex;flex-direction:column;gap:18px;padding:0;margin:0}
.inquiry-list li{
  display:grid;grid-template-columns:80px 1fr;gap:6px 20px;align-items:baseline;
  padding-bottom:16px;border-bottom:1px dashed var(--cream-3);
}
.inquiry-list li:last-child{border-bottom:0;padding-bottom:0}
.inq-label{
  font-family:var(--f-italic);font-style:italic;font-size:14.5px;
  color:var(--rose-2);letter-spacing:.04em;
}
.inquiry-list a{
  font-family:var(--f-disp-jp);font-size:17px;color:var(--ink);
  letter-spacing:.02em;border-bottom:1px solid var(--ink);padding-bottom:1px;
  transition:color .2s,border-color .2s;
}
.inquiry-list a:hover{color:var(--rose-2);border-bottom-color:var(--rose-2)}
.inq-note{
  grid-column:2;font-family:var(--f-jp);font-weight:400;font-size:13px;
  color:var(--ink-3);line-height:1.85;letter-spacing:.02em;
}
@media(max-width:600px){
  .inquiry-block{padding:28px 24px}
  .inquiry-list li{grid-template-columns:1fr;gap:4px}
  .inq-note{grid-column:1}
}

/* ============================================================
   SECTION: モデルケース年間タイムライン
   ============================================================ */
.yr-section{ background:var(--cream-2); }

.yr-outer{
  margin-top:60px;
  overflow-x:auto;
  padding-bottom:16px;
  scrollbar-width:thin;
  scrollbar-color:var(--shade) transparent;
}

.yr-items{
  display:flex;
  gap:0;
  min-width:fit-content;
  position:relative;
}
.yr-items::before{
  content:"";
  position:absolute;
  top:40px;
  left:6.25%;
  right:6.25%;
  height:2px;
  background-image:radial-gradient(circle,var(--rose) 0 1.5px,transparent 1.5px);
  background-size:14px 2px;
  background-position:center;
  background-repeat:repeat-x;
  z-index:0;
}

.yr-item{
  flex:1;
  min-width:172px;
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:0 10px;
}

.yr-head{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  margin-bottom:14px;
  position:relative;
  z-index:2;
}

.yr-month{
  font-family:var(--f-hand-jp);
  font-size:13px;
  color:var(--rose-2);
  background:var(--butter-pale);
  border:1.5px solid var(--butter);
  padding:2px 10px;
  border-radius:999px;
  letter-spacing:.04em;
  white-space:nowrap;
  line-height:1.5;
}

.yr-dot{
  width:14px;
  height:14px;
  border-radius:50%;
  background:var(--butter);
  border:2.5px solid var(--rose);
  flex-shrink:0;
}

.yr-card{
  background:#fff;
  border-radius:6px;
  padding:16px 14px 18px;
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 10px 22px -12px rgba(42,39,48,.15);
  width:100%;
  text-align:center;
  position:relative;
  border-top:3px solid var(--rose);
  transition:transform .3s,box-shadow .3s;
}
.yr-card.c-rose{ border-top-color:var(--rose); }
.yr-card.c-sage{ border-top-color:var(--sage); }
.yr-card.c-butter{ border-top-color:var(--butter); }
.yr-card.c-mauve{ border-top-color:var(--mauve); }

.yr-card .washi{
  top:-8px;left:50%;
  transform:translateX(-50%) rotate(-2deg);
  width:60px;height:16px;
}

.yr-item:nth-child(odd) .yr-card{ transform:rotate(-.5deg); }
.yr-item:nth-child(even) .yr-card{ transform:rotate(.5deg) translateY(4px); }
.yr-item:nth-child(odd) .yr-card:hover{ transform:rotate(0) translateY(-3px);box-shadow:0 14px 30px -10px rgba(42,39,48,.2); }
.yr-item:nth-child(even) .yr-card:hover{ transform:rotate(0) translateY(-3px);box-shadow:0 14px 30px -10px rgba(42,39,48,.2); }

.yr-title{
  display:block;
  font-family:var(--f-jp);
  font-weight:700;
  font-size:13.5px;
  color:var(--ink);
  margin-bottom:8px;
  line-height:1.55;
  letter-spacing:.02em;
}

.yr-desc{
  font-family:var(--f-jp);
  font-weight:400;
  font-size:12px;
  color:var(--ink-2);
  line-height:1.85;
  letter-spacing:.01em;
}

@media(max-width:760px){
  .yr-outer{ overflow-x:visible; }
  .yr-items{
    flex-direction:column;
    min-width:auto;
    gap:20px;
  }
  .yr-items::before{ display:none; }
  .yr-item{
    flex-direction:row;
    align-items:flex-start;
    gap:14px;
    min-width:auto;
    padding:0;
  }
  .yr-head{
    flex-direction:column;
    align-items:center;
    flex-shrink:0;
    gap:4px;
    margin-bottom:0;
    margin-top:2px;
    min-width:64px;
  }
  .yr-dot{ display:none; }
  .yr-card{ text-align:left;flex:1; }
  .yr-card .washi{ display:none; }
  .yr-item:nth-child(odd) .yr-card,
  .yr-item:nth-child(even) .yr-card{ transform:none; }
  .yr-item:nth-child(odd) .yr-card:hover,
  .yr-item:nth-child(even) .yr-card:hover{ transform:translateY(-2px); }
}

/* ========== MODAL: 応募フォーム ========== */
.modal-overlay{
  position:fixed;inset:0;z-index:200;
  background:rgba(42,39,48,.55);
  backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  opacity:0;pointer-events:none;
  transition:opacity .3s cubic-bezier(.2,.8,.2,1);
}
.modal-overlay[hidden]{display:flex;}
.modal-overlay:not([hidden]){opacity:1;pointer-events:auto;}

.modal-card{
  position:relative;
  background:var(--cream);
  border:1px dashed rgba(42,39,48,.18);
  border-radius:10px;
  box-shadow:0 8px 40px rgba(42,39,48,.22);
  width:100%;max-width:560px;
  max-height:90vh;overflow-y:auto;
  padding:48px 44px 40px;
  transform:translateY(24px) scale(.97);
  transition:transform .35s cubic-bezier(.2,.8,.2,1);
}
.modal-overlay:not([hidden]) .modal-card{transform:translateY(0) scale(1);}

.modal-header{margin-bottom:28px;}
.modal-title{font-family:var(--f-disp-jp);font-size:clamp(1.4rem,3vw,1.9rem);color:var(--ink);margin-bottom:8px;}
.modal-lead{font-size:.93rem;color:var(--ink-3);line-height:1.7;}

.modal-flow{
  display:flex;align-items:center;flex-wrap:wrap;gap:6px 4px;
  list-style:none;margin-top:16px;
  padding:14px 16px;
  background:var(--cream-2);
  border-radius:8px;
  border:1px dashed rgba(42,39,48,.12);
}
.modal-flow-step{
  display:flex;align-items:center;gap:6px;
}
.mf-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:20px;height:20px;flex-shrink:0;
  background:var(--rose);color:#fff;
  border-radius:50%;font-size:.7rem;font-weight:700;font-family:var(--f-en);
}
.mf-goal .mf-num{background:var(--sage);}
.mf-label{font-size:.78rem;font-weight:700;color:var(--ink-2);line-height:1.3;}
.mf-label small{display:block;font-size:.7rem;font-weight:500;color:var(--ink-4);}
.modal-flow-arrow{font-size:.8rem;color:var(--ink-4);padding:0 2px;}

.modal-form{display:flex;flex-direction:column;gap:18px;}

.field-group{display:flex;flex-direction:column;gap:6px;}
.field-group>label{font-size:.88rem;font-weight:700;color:var(--ink-2);}
.req{font-size:.72rem;color:var(--rose-2);background:var(--rose-pale);padding:1px 5px;border-radius:3px;margin-left:4px;}

.field-group input,
.field-group select,
.field-group textarea{
  font-family:var(--f-jp);font-size:.95rem;
  background:#fff;color:var(--ink);
  border:1.5px solid var(--cream-3);
  border-radius:6px;
  padding:10px 13px;
  transition:border-color .2s,box-shadow .2s;
  outline:none;
  width:100%;
}
.field-group input:focus,
.field-group select:focus,
.field-group textarea:focus{
  border-color:var(--rose);
  box-shadow:0 0 0 3px rgba(215,122,149,.15);
}
.field-group textarea{resize:vertical;min-height:72px;}

.name-split{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.name-part{display:flex;flex-direction:column;gap:4px;}
.name-part-label{font-size:.78rem;font-weight:600;color:var(--ink-3);}
@media (max-width:480px){
  .name-split{grid-template-columns:1fr;}
}

.radio-group{display:flex;gap:16px;flex-wrap:wrap;}
.radio-label{display:flex;align-items:center;gap:6px;font-size:.9rem;font-weight:500;cursor:pointer;}
.radio-label input[type="radio"]{accent-color:var(--rose);width:16px;height:16px;}

.consent-toggle{
  margin-top:4px;
  padding:14px 16px;
  background:rgba(251,232,238,.4);
  border:1px dashed rgba(180,84,111,.4);
  border-radius:8px;
}
.consent-toggle-row{
  display:flex;
  align-items:flex-start;
  gap:14px;
  cursor:pointer;
  margin:0;
}
.consent-toggle-row input[type="checkbox"]{
  position:absolute;
  opacity:0;
  pointer-events:none;
  width:0;
  height:0;
}
.consent-switch{
  flex:none;
  display:inline-block;
  width:44px;
  height:24px;
  background:var(--cream-3);
  border-radius:999px;
  position:relative;
  transition:background .2s ease;
  margin-top:1px;
}
.consent-switch-knob{
  position:absolute;
  top:2px;
  left:2px;
  width:20px;
  height:20px;
  background:#fff;
  border-radius:50%;
  box-shadow:0 1px 3px rgba(42,39,48,.25);
  transition:transform .25s cubic-bezier(.4,.0,.2,1);
}
.consent-toggle-row input:checked + .consent-switch{
  background:var(--rose);
}
.consent-toggle-row input:checked + .consent-switch .consent-switch-knob{
  transform:translateX(20px);
}
.consent-toggle-row input:focus-visible + .consent-switch{
  outline:2px solid var(--rose);
  outline-offset:2px;
}
.consent-text{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.consent-title{
  font-size:.92rem;
  font-weight:700;
  color:var(--ink-2);
  display:inline-flex;
  align-items:center;
  flex-wrap:wrap;
}
.consent-desc{
  font-size:.78rem;
  color:var(--ink-3);
  line-height:1.7;
}

.modal-actions{display:flex;gap:12px;margin-top:8px;flex-wrap:wrap;}
.modal-actions .btn[disabled]{
  opacity:.45;
  cursor:not-allowed;
  pointer-events:none;
}

.modal-close{
  position:absolute;top:16px;right:18px;
  font-size:1.1rem;color:var(--ink-3);
  background:var(--cream-2);border-radius:50%;
  width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  transition:background .2s,color .2s;
}
.modal-close:hover{background:var(--rose-pale);color:var(--rose-2);}

.modal-success{text-align:center;padding:24px 0;}
.modal-success h3{font-family:var(--f-disp-jp);font-size:1.5rem;margin:16px 0 8px;}
.modal-success p{color:var(--ink-2);line-height:1.8;}

.modal-line-alt{margin-top:24px;text-align:center;}
.modal-divider{
  display:flex;align-items:center;gap:10px;
  color:var(--ink-4);font-size:.78rem;
  margin-bottom:16px;
}
.modal-divider::before,.modal-divider::after{
  content:'';flex:1;height:1px;background:var(--cream-3);
}
.line-apply-btn{
  display:inline-flex;align-items:center;gap:9px;
  background:#06C755;color:#fff;
  font-family:var(--f-jp);font-weight:700;font-size:.93rem;
  padding:11px 26px;border-radius:999px;
  transition:filter .2s,transform .2s;
}
.line-apply-btn:hover{filter:brightness(1.08);transform:translateY(-1px);}
.line-note{margin-top:10px;font-size:.78rem;color:var(--ink-4);line-height:1.6;}

@media(max-width:600px){
  .modal-card{padding:36px 22px 28px;}
  .modal-actions{flex-direction:column;}
  .modal-actions .btn{width:100%;justify-content:center;}
  .line-apply-btn{width:100%;justify-content:center;}
}

/* ============================================================
   BREADCRUMB — モバイル(≤760px)のみ表示。デスクトップは nav で十分。
   手描き矢印トレイル。サイトの .hl 波線・各ページアクセント色を踏襲。
   ============================================================ */
.breadcrumb{display:none}

@media(max-width:760px){
  .breadcrumb{
    display:block;position:relative;
    background:linear-gradient(to bottom, rgba(242,235,217,.92), rgba(250,246,235,.92));
    border-top:1px dashed var(--cream-3);
    border-bottom:1px dashed var(--cream-3);
    /* nav (sticky top:0) の直下に配置。breadcrumb 自身は sticky にせず、
       スクロールで自然に流れる(nav と重ならないため)。 */
  }
  .breadcrumb-trail{
    list-style:none;margin:0;padding:9px var(--pad);
    display:flex;align-items:center;gap:8px;
    overflow-x:auto;
    scrollbar-width:none;
    -ms-overflow-style:none;
    -webkit-overflow-scrolling:touch;
    white-space:nowrap;
    font-family:var(--f-disp-jp);font-size:13.5px;
    color:var(--ink-2);
  }
  .breadcrumb-trail::-webkit-scrollbar{display:none}

  .bc-item{display:inline-flex;align-items:center;flex:0 0 auto}
  .bc-item a{
    color:var(--ink-2);
    display:inline-flex;align-items:center;gap:5px;
    padding:2px 0;
    transition:color .25s ease;
  }
  .bc-item a:hover,.bc-item a:active{color:var(--rose-2)}
  .bc-item a:focus-visible{
    outline:2px solid var(--rose);outline-offset:3px;border-radius:3px;
  }

  .bc-home-item .bc-home{
    width:14px;height:14px;
    fill:none;stroke:currentColor;stroke-width:1.4;
    stroke-linejoin:round;stroke-linecap:round;
    opacity:.85;
  }

  /* セパレータ手描き矢印 */
  .bc-sep{
    display:inline-flex;align-items:center;flex:0 0 auto;
    color:var(--ink-4);
  }
  .bc-arrow{
    width:24px;height:11px;
    fill:none;stroke:currentColor;stroke-width:1.3;
    stroke-linecap:round;stroke-linejoin:round;
    opacity:.75;
  }

  /* 現在ページ — 各ページのアクセント色 + 手描き波線 */
  .bc-current-item{flex:0 1 auto;min-width:0}
  .bc-current{
    position:relative;display:inline-block;
    font-weight:500;
    padding-bottom:.18em;
    /* テキストが長くなった場合は省略せず流して横スクロール可能にする */
  }
  .bc-current.c-rose  {color:var(--rose-2)}
  .bc-current.c-sage  {color:#5C7E68}
  .bc-current.c-mauve {color:#7E68A6}
  .bc-current.c-butter{color:#9B7A12}
  .bc-current.c-sky   {color:#4F7C9A}
  .bc-current.c-ink   {color:var(--ink)}

  .bc-wave{
    position:absolute;left:-2%;right:-2%;bottom:-.05em;
    width:104%;height:.42em;overflow:visible;
    pointer-events:none;
  }
  .bc-wave path{
    fill:none;stroke-width:2.5;
    stroke-linecap:round;stroke-linejoin:round;
  }
  .bc-current.c-rose   .bc-wave path{stroke:var(--rose)}
  .bc-current.c-sage   .bc-wave path{stroke:var(--sage)}
  .bc-current.c-mauve  .bc-wave path{stroke:var(--mauve)}
  .bc-current.c-butter .bc-wave path{stroke:var(--butter);stroke-width:4}
  .bc-current.c-sky    .bc-wave path{stroke:var(--sky)}
  .bc-current.c-ink    .bc-wave path{stroke:var(--ink-3)}

  /* スクロール端のフェード(横スクロールヒント) */
  .breadcrumb::after{
    content:"";position:absolute;top:0;right:0;bottom:0;
    width:28px;pointer-events:none;
    background:linear-gradient(to right, transparent, rgba(250,246,235,.9));
  }
}

@media(max-width:380px){
  .breadcrumb-trail{font-size:12.5px;gap:6px;padding:8px var(--pad)}
  .bc-arrow{width:20px}
}
