/* ═══════════════════════════════════════════════
   TOKENS
═══════════════════════════════════════════════ */
:root{
  --pink:       #F07BA0; --pink-deep: #C85880; --pink-mid: #F4AABF;
  --pink-soft:  #FCE8F1; --pink-pale: #FEF4F8;
  --green:      #7AC043; --green-deep:#5A9430;
  --green-soft: #DAEFC4; --green-pale:#F2FAE7;
  --blue:       #3BAEC8; --blue-deep: #2A8CAF;
  --blue-soft:  #BDE6F3; --blue-pale: #E8F6FC;
  --yellow:     #F5C030; --yellow-soft:#FDEFC0;
  --brown:      #5C3820;
  --ink:        #1A2840; --ink-mid:   #3C4F68;
  --ink-light:  #7A8FA6; --ink-faint: #BAC8D8;
  --white:      #FFFFFF; --off-white: #FAFCFE;
  --border:     #E2EBF4; --bg-soft:   #F5F9FD;
  --r-sm:12px; --r-md:18px; --r-lg:26px; --r-xl:40px; --r-full:9999px;
  --sh-xs:0 1px 6px rgba(26,40,64,.05);
  --sh-sm:0 3px 16px rgba(26,40,64,.08);
  --sh-md:0 6px 30px rgba(26,40,64,.10);
  --sh-lg:0 14px 52px rgba(26,40,64,.12);
  --sh-pk: 0 6px 26px rgba(240,123,160,.26);
  --sh-gn: 0 6px 26px rgba(122,192,67,.22);
  --serif:'Noto Serif JP',serif; --sans:'Noto Sans JP',sans-serif;
}

/* ═══════════════════════════════════════════════
   RESET
═══════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);font-size:16px;background:var(--white);color:var(--ink);line-height:1.88;overflow-x:hidden}
a{color:inherit;text-decoration:none}
ul{list-style:none}
img{max-width:100%;height:auto;display:block}
.brand-img{object-fit:contain}

/* ═══════════════════════════════════════════════
   LAYOUT
═══════════════════════════════════════════════ */
.wrap{max-width:980px;margin:0 auto;padding:0 28px}
.wrap-narrow{max-width:700px;margin:0 auto;padding:0 28px}
.sec{padding:82px 0}
.tc{text-align:center}

/* ═══════════════════════════════════════════════
   TYPOGRAPHY
═══════════════════════════════════════════════ */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.73rem;font-weight:700;letter-spacing:.18em;
  color:var(--pink);margin-bottom:18px;
}
.eyebrow::before,.eyebrow::after{
  content:'';flex-shrink:0;width:20px;height:1px;
  background:currentColor;opacity:.45;
}
.eyebrow.blue{color:var(--blue-deep)}
.eyebrow.green{color:var(--green-deep)}

.h2{
  font-family:var(--serif);
  font-size:clamp(1.5rem,3.8vw,2.1rem);
  font-weight:700;line-height:1.52;letter-spacing:.015em;color:var(--ink);
}
.lead{font-size:.98rem;color:var(--ink-mid);line-height:2.05}
.note{font-size:.84rem;color:var(--ink-light);line-height:1.85}

/* ═══════════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--sans);font-weight:700;font-size:.95rem;
  cursor:pointer;border:none;border-radius:var(--r-full);
  padding:15px 30px;letter-spacing:.03em;white-space:nowrap;
  text-decoration:none;position:relative;overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease, background .15s;
}
.btn::after{display:none;content:none}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0);opacity:.9}
.btn:disabled{cursor:not-allowed;opacity:.62;transform:none;box-shadow:none}

.btn-pink{background:var(--pink);color:#fff;box-shadow:var(--sh-pk)}
.btn-pink:hover{background:var(--pink-deep);box-shadow:0 8px 30px rgba(240,123,160,.36)}
.btn-green{background:var(--green);color:#fff;box-shadow:var(--sh-gn)}
.btn-green:hover{background:var(--green-deep)}
.btn-outline{
  background:transparent;color:var(--ink-mid);
  border:1.5px solid var(--border);box-shadow:none;
}
.btn-outline::after{display:none}
.btn-outline:hover{border-color:var(--ink-faint);background:var(--bg-soft);transform:none}
.btn-lg{padding:18px 38px;font-size:1.02rem}
.btn-xl{padding:20px 46px;font-size:1.08rem}
.btn-icon{width:20px;height:20px;flex-shrink:0}

/* ═══════════════════════════════════════════════
   HEADER
═══════════════════════════════════════════════ */
.header{
  position:sticky;top:0;z-index:200;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:72px;gap:16px;
}
.header-logo{display:flex;align-items:center;gap:13px;flex-shrink:0}
.header-mark{width:44px;height:44px;flex-shrink:0}
.header-text{display:flex;flex-direction:column;gap:1px}
.header-sub{font-size:.62rem;color:var(--ink-light);letter-spacing:.05em}
.header-name{
  font-family:var(--serif);font-size:.88rem;font-weight:700;
  color:var(--ink);line-height:1.3;
}
.header-name em{color:var(--pink-deep);font-size:1.02rem;font-style:normal}
.header-yui{font-family:var(--serif);font-size:.7rem;color:var(--pink);margin-left:1px}
.header-right{display:flex;align-items:center;gap:10px}
.header-cta{padding:10px 22px;font-size:.84rem}
.header-tel{
  display:flex;align-items:center;gap:7px;
  font-size:.82rem;font-weight:700;color:var(--ink-mid);
  padding:8px 16px;border-radius:var(--r-full);
  border:1.5px solid var(--border);
  transition:border-color .15s,color .15s;
}
.header-tel:hover{border-color:var(--pink-mid);color:var(--pink-deep)}
.header-tel-icon{width:15px;height:15px}

/* ═══════════════════════════════════════════════
   HERO — floating orbs + dot decorations
═══════════════════════════════════════════════ */
.hero{
  position:relative;overflow:hidden;
  background:var(--white);padding:72px 0 84px;
}

/* Floating background orbs */
.hero-orb{
  position:absolute;border-radius:50%;pointer-events:none;
}
.orb-1{
  width:520px;height:520px;top:-160px;right:-100px;
  background:radial-gradient(circle,rgba(240,123,160,.09) 0%,transparent 68%);
  animation:orb-float-1 16s ease-in-out infinite;
}
.orb-2{
  width:380px;height:380px;bottom:-100px;left:-80px;
  background:radial-gradient(circle,rgba(59,174,200,.08) 0%,transparent 68%);
  animation:orb-float-2 20s ease-in-out infinite;
}
.orb-3{
  width:240px;height:240px;top:40%;right:30%;
  background:radial-gradient(circle,rgba(122,192,67,.07) 0%,transparent 70%);
  animation:orb-float-3 13s ease-in-out infinite;
}
@keyframes orb-float-1{
  0%,100%{transform:translate(0,0)}
  30%{transform:translate(-14px,20px)}
  60%{transform:translate(8px,-12px)}
}
@keyframes orb-float-2{
  0%,100%{transform:translate(0,0)}
  40%{transform:translate(16px,-18px)}
  70%{transform:translate(-8px,10px)}
}
@keyframes orb-float-3{
  0%,100%{transform:translate(0,0)}
  50%{transform:translate(10px,14px)}
}

.hero-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr;align-items:center;gap:28px;max-width:760px;margin-inline:auto;text-align:center;
}
.hero-text{
  position:relative;
  padding:32px 26px;
}
.hero-text::before{
  content:'';
  position:absolute;
  inset:-18px -28px;
  background:linear-gradient(90deg,rgba(255,255,255,.52),rgba(255,255,255,.28) 62%,rgba(255,255,255,0));
  border-radius:26px;
  z-index:-1;
  pointer-events:none;
}

.hero-badges{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:24px}
.hero-badge{
  display:inline-flex;align-items:center;gap:9px;
  background:var(--pink-pale);border:1px solid var(--pink-mid);
  color:var(--pink-deep);font-size:.73rem;font-weight:700;
  letter-spacing:.07em;padding:7px 18px;border-radius:var(--r-full);
  margin-bottom:0;
}
.hero-badge-blue{background:var(--blue-pale);border-color:var(--blue-soft);color:var(--blue-deep)}
.hero-badge-dot{
  width:7px;height:7px;border-radius:50%;background:var(--pink);
  flex-shrink:0;animation:badge-pulse 2.2s ease infinite;
}
@keyframes badge-pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.5;transform:scale(.8)}
}

.hero-title{
  font-family:var(--serif);
  font-size:clamp(1.9rem,5vw,2.9rem);
  font-weight:700;line-height:1.48;letter-spacing:.01em;
  color:var(--ink);margin-bottom:24px;
}
.hero-title strong{color:var(--pink-deep);font-style:normal}

.hero-sub{
  font-size:.98rem;color:var(--ink-mid);line-height:2.05;
  margin-bottom:38px;
}

.hero-btns{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:30px;justify-content:center}

.hero-visual::before{
  content:'';position:absolute;inset:12px;border-radius:calc(var(--r-xl) - 10px);
  border:1px dashed rgba(240,123,160,.35);pointer-events:none;
}
.hero-visual::after{
  content:'';position:absolute;width:180px;height:180px;right:-78px;bottom:-78px;
  background:radial-gradient(circle,rgba(122,192,67,.12),transparent 68%);
}
.hero-visual-arc,.hero-visual-dots,.h-dot{display:none}
.hero-logo-svg{
  width:165px;height:auto;position:relative;z-index:1;
  filter:drop-shadow(0 8px 20px rgba(240,123,160,.14));
}
.hero-brand-name{display:none}
.hero-card-copy{
  position:relative;z-index:1;text-align:center;margin-top:18px;
  font-family:var(--serif);font-size:1.08rem;font-weight:700;
  color:var(--brown);line-height:1.9;letter-spacing:.05em;
}
.hero-card-copy strong{color:var(--pink-deep);font-size:1.3em}
.hero-card-points{
  position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;
  gap:8px;margin-top:20px;width:100%;
}
.hero-card-point{
  background:var(--pink-pale);border:1px solid var(--pink-soft);
  border-radius:var(--r-full);padding:8px 10px;text-align:center;
  font-size:.78rem;font-weight:700;color:var(--ink-mid);
}
.hero-card-point:nth-child(2){background:var(--green-pale);border-color:var(--green-soft)}
.hero-card-point:nth-child(3){background:var(--blue-pale);border-color:var(--blue-soft)}
.hero-card-point:nth-child(4){background:var(--yellow-soft);border-color:#F8D976}

/* ═══════════════════════════════════════════════
   SECTION INTRO (common)
═══════════════════════════════════════════════ */
.sec-head{margin-bottom:42px}

/* ═══════════════════════════════════════════════
   WORRIES — numbered badges
═══════════════════════════════════════════════ */
.worries{background:var(--pink-pale)}
.worries-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:12px;margin-top:0;
}
.worry-card{
  display:flex;align-items:flex-start;gap:14px;
  background:var(--white);border-radius:var(--r-md);
  padding:18px 22px;
  box-shadow:var(--sh-xs);
  border:1.5px solid transparent;
  transition:border-color .25s,box-shadow .25s,transform .22s;
}
.worry-card:hover{
  border-color:var(--pink-mid);
  box-shadow:var(--sh-sm);transform:translateY(-3px);
}
.wi-num{
  width:36px;height:36px;border-radius:50%;flex-shrink:0;
  border:1.5px solid var(--pink-mid);
  display:flex;align-items:center;justify-content:center;
  font-size:.72rem;font-weight:700;color:var(--pink-deep);
  font-variant-numeric:tabular-nums;letter-spacing:0;
  background:var(--pink-pale);margin-top:1px;
}
.worry-text{
  font-size:.9rem;font-weight:600;color:var(--ink-mid);
  line-height:1.68;padding-top:4px;
}
.worries-cta{margin-top:34px;text-align:center}
.worries-note{
  font-family:var(--serif);font-size:1.08rem;font-weight:700;
  color:var(--ink-mid);margin-bottom:22px;
}
.worries-note span{color:var(--pink-deep)}

/* ═══════════════════════════════════════════════
   SPECIALIST
═══════════════════════════════════════════════ */
.specialist{background:var(--white)}
.message{background:linear-gradient(145deg,var(--white) 0%,var(--blue-pale) 100%)}
.specialist-inner{
  display:grid;grid-template-columns:auto 1fr;
  align-items:center;gap:50px;
}
.specialist-visual{
  display:flex;flex-direction:column;align-items:center;
  gap:16px;flex-shrink:0;
}
.spec-avatar{
  width:148px;height:148px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue-pale),var(--green-pale));
  border:4px solid var(--white);box-shadow:var(--sh-md);
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.spec-badge{
  background:var(--blue-pale);border:1px solid var(--blue-soft);
  color:var(--blue-deep);font-size:.74rem;font-weight:700;
  padding:6px 16px;border-radius:var(--r-full);letter-spacing:.04em;
}
.profile-card{
  width:260px;
  background:rgba(255,255,255,.92);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:16px;
  box-shadow:var(--sh-md);
}
.profile-photo{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:18px;
  background:var(--bg-soft);
}
.profile-meta{padding:14px 4px 2px;text-align:center}
.profile-role{display:inline-flex;background:var(--green-pale);color:var(--green-deep);border:1px solid var(--green-soft);border-radius:var(--r-full);padding:3px 12px;font-size:.72rem;font-weight:700;margin-bottom:8px}
.profile-name{font-family:var(--serif);font-size:1.18rem;font-weight:700;color:var(--ink);line-height:1.45}
.profile-sub{font-size:.78rem;color:var(--ink-light);line-height:1.7;margin-top:6px}
.message-body{margin-top:14px}
.message-sign{margin-top:20px;font-family:var(--serif);font-weight:700;color:var(--brown);line-height:1.8}
.spec-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.tag{
  display:inline-flex;align-items:center;gap:7px;
  font-size:.78rem;font-weight:600;
  padding:6px 14px;border-radius:var(--r-full);
}
.tag-blue {background:var(--blue-pale); color:var(--blue-deep);  border:1px solid var(--blue-soft)}
.tag-green{background:var(--green-pale);color:var(--green-deep); border:1px solid var(--green-soft)}
.tag-pink {background:var(--pink-pale); color:var(--pink-deep);  border:1px solid var(--pink-mid)}
/* Tag icon: small CSS dot */
.tag::before{
  content:'';width:5px;height:5px;border-radius:50%;flex-shrink:0;
  background:currentColor;opacity:.6;
}

/* ═══════════════════════════════════════════════
   VALUES — 3 cards with connection line
═══════════════════════════════════════════════ */
.values{
  background:linear-gradient(155deg,var(--pink-pale) 0%,var(--white) 45%,var(--green-pale) 100%);
}
.values-grid-wrap{position:relative}
.values-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:22px;position:relative;
}
/* Connection line across card icon centers */
.values-line{
  position:absolute;
  top:88px; /* center of icon circle */
  left:calc(16.67% + 11px);
  right:calc(16.67% + 11px);
  height:1px;
  background:linear-gradient(90deg,var(--pink-soft),var(--green-soft),var(--blue-soft));
  transform:scaleX(0);transform-origin:left;
  transition:transform 1.1s cubic-bezier(.4,0,.2,1) .5s;
  pointer-events:none;z-index:0;
}
.values-line.drawn{transform:scaleX(1)}
/* Connection dots at line ends */
.values-line::before,.values-line::after{
  content:'';position:absolute;top:-3px;
  width:7px;height:7px;border-radius:50%;
}
.values-line::before{left:0;background:var(--pink-mid)}
.values-line::after{right:0;background:var(--blue-soft)}

.value-card{
  background:var(--white);border-radius:var(--r-lg);
  padding:42px 26px 36px;text-align:center;
  box-shadow:var(--sh-sm);
  position:relative;overflow:hidden;z-index:1;
  transition:transform .25s,box-shadow .25s;
}
.value-card:hover{transform:translateY(-5px);box-shadow:var(--sh-md)}
.value-card::after{
  content:'';position:absolute;
  bottom:0;left:0;right:0;height:3px;
  border-radius:0 0 var(--r-lg) var(--r-lg);
}
.value-card.vc-pink::after {background:var(--pink)}
.value-card.vc-green::after{background:var(--green)}
.value-card.vc-blue::after {background:var(--blue)}

/* CSS-only icon circles */
.value-icon{
  width:72px;height:72px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 22px;
}
.vc-pink  .value-icon{background:var(--pink-soft)}
.vc-green .value-icon{background:var(--green-soft)}
.vc-blue  .value-icon{background:var(--blue-soft)}
.value-icon svg{width:28px;height:28px}
.vc-pink  .value-icon svg{stroke:var(--pink-deep)}
.vc-green .value-icon svg{stroke:var(--green-deep)}
.vc-blue  .value-icon svg{stroke:var(--blue-deep)}

.value-kana{font-size:.68rem;letter-spacing:.12em;color:var(--ink-faint);margin-bottom:4px}
.value-title{
  font-family:var(--serif);font-size:1.4rem;font-weight:700;margin-bottom:14px;
}
.vc-pink  .value-title{color:var(--pink-deep)}
.vc-green .value-title{color:var(--green-deep)}
.vc-blue  .value-title{color:var(--blue-deep)}
.value-desc{font-size:.87rem;color:var(--ink-mid);line-height:1.95}

/* ═══════════════════════════════════════════════
   AGES — CSS checkmarks, no emoji
═══════════════════════════════════════════════ */
.ages{background:var(--white)}
.ages-split{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
}
.age-panel{border-radius:var(--r-xl);padding:46px 38px;position:relative;overflow:hidden}
.age-panel.child{
  background:linear-gradient(148deg,var(--pink-pale),#fffafb);
  border:1.5px solid var(--pink-soft);
}
.age-panel.adult{
  background:linear-gradient(148deg,var(--blue-pale),#f4fbff);
  border:1.5px solid var(--blue-soft);
}
/* Decorative arc in corner */
.age-panel::before{
  content:'';position:absolute;top:-30px;right:-30px;
  width:120px;height:120px;border-radius:50%;
  border:1.5px solid currentColor;opacity:.08;
}
.age-panel.child::before{color:var(--pink)}
.age-panel.adult::before{color:var(--blue)}

.age-label{
  display:inline-flex;align-items:center;gap:7px;
  font-size:.72rem;font-weight:700;letter-spacing:.1em;
  padding:5px 14px;border-radius:var(--r-full);margin-bottom:12px;
}
.child .age-label{background:var(--pink-soft);color:var(--pink-deep)}
.adult .age-label{background:var(--blue-soft);color:var(--blue-deep)}
.age-label-dot{width:5px;height:5px;border-radius:50%;background:currentColor}
.age-title{
  font-family:var(--serif);font-size:1.18rem;font-weight:700;
  margin-bottom:20px;color:var(--ink);line-height:1.55;
}
.age-list{display:flex;flex-direction:column;gap:10px}
.age-item{display:flex;align-items:flex-start;gap:10px;font-size:.88rem;color:var(--ink-mid);line-height:1.7}
.age-check{
  width:20px;height:20px;border-radius:50%;flex-shrink:0;
  margin-top:2px;position:relative;
}
.child .age-check{background:var(--pink)}
.adult .age-check{background:var(--blue)}
/* CSS checkmark */
.age-check::after{
  content:'';position:absolute;
  width:8px;height:5px;
  border-left:2px solid #fff;border-bottom:2px solid #fff;
  transform:rotate(-45deg);top:5px;left:5px;
}

/* ═══════════════════════════════════════════════
   SERVICES — thin SVG icons
═══════════════════════════════════════════════ */
.services{background:var(--off-white)}
.services-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:18px;
}
.service-card{
  background:var(--white);border-radius:var(--r-lg);
  padding:32px 28px;box-shadow:var(--sh-xs);
  display:flex;gap:22px;align-items:flex-start;
  border:1.5px solid var(--border);
  transition:border-color .22s,box-shadow .22s,transform .2s;
}
.service-card:hover{border-color:var(--pink-mid);box-shadow:var(--sh-sm);transform:translateY(-3px)}
.svc-icon{
  width:52px;height:52px;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.svc-icon svg{width:24px;height:24px}
.service-card:nth-child(1) .svc-icon{background:var(--pink-soft)}
.service-card:nth-child(1) .svc-icon svg{stroke:var(--pink-deep)}
.service-card:nth-child(2) .svc-icon{background:var(--blue-soft)}
.service-card:nth-child(2) .svc-icon svg{stroke:var(--blue-deep)}
.service-card:nth-child(3) .svc-icon{background:var(--green-soft)}
.service-card:nth-child(3) .svc-icon svg{stroke:var(--green-deep)}
.service-card:nth-child(4) .svc-icon{background:var(--yellow-soft)}
.service-card:nth-child(4) .svc-icon svg{stroke:#B88A00}
.svc-free{
  display:inline-block;
  background:var(--green-pale);color:var(--green-deep);
  font-size:.69rem;font-weight:700;padding:2px 10px;
  border-radius:var(--r-full);margin-bottom:8px;
  border:1px solid var(--green-soft);
}
.svc-title{font-weight:700;font-size:.98rem;margin-bottom:7px;color:var(--ink)}
.svc-desc{font-size:.86rem;color:var(--ink-mid);line-height:1.88}

/* ═══════════════════════════════════════════════
   NETWORK — text-label nodes
═══════════════════════════════════════════════ */
.network{background:var(--white)}
.net-wrap{margin:52px auto 0;max-width:660px}
.net-center{
  width:112px;height:112px;border-radius:50%;
  background:linear-gradient(135deg,var(--pink-soft),var(--pink-pale));
  border:2px solid var(--pink-mid);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  margin:0 auto;box-shadow:var(--sh-md);position:relative;z-index:2;
}
.net-center-logo{width:52px;height:52px}
.net-center-name{
  font-family:var(--serif);font-size:.72rem;font-weight:700;
  color:var(--pink-deep);margin-top:4px;text-align:center;line-height:1.3;
}
.net-ring{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:12px;margin-top:20px;
}
.net-node{
  background:var(--white);border-radius:var(--r-md);
  padding:16px 12px;text-align:center;
  box-shadow:var(--sh-xs);border:1.5px solid var(--border);
  position:relative;
  transition:border-color .2s,box-shadow .2s;
}
.net-node:hover{border-color:var(--blue-soft);box-shadow:var(--sh-sm)}
/* connector indicator */
.net-node::before{
  content:'';position:absolute;top:-17px;left:50%;
  transform:translateX(-50%);
  width:1px;height:16px;
  background:linear-gradient(to bottom,var(--pink-mid),var(--border));
}
.net-label{
  width:48px;height:48px;border-radius:50%;
  background:var(--bg-soft);border:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 8px;
  font-family:var(--serif);font-size:.75rem;font-weight:700;
  color:var(--ink-mid);line-height:1.25;text-align:center;
}
.net-node-name{font-size:.79rem;font-weight:700;color:var(--ink-mid);line-height:1.5}
.net-node-sub{font-size:.7rem;color:var(--ink-light);font-weight:400}
.net-note{
  margin-top:26px;text-align:center;
  font-size:.84rem;color:var(--ink-light);line-height:1.9;
}

/* ═══════════════════════════════════════════════
   FLOW — animated vertical line
═══════════════════════════════════════════════ */
.flow{background:var(--green-pale)}
.flow-steps{
  margin:52px auto 0;max-width:680px;
  display:flex;flex-direction:column;gap:8px;
}
.flow-step{
  display:grid;grid-template-columns:62px 1fr;gap:18px;
  align-items:flex-start;
  background:var(--white);border-radius:var(--r-lg);
  padding:28px 32px 28px 22px;
  box-shadow:var(--sh-xs);border:1.5px solid transparent;
  position:relative;
  transition:border-color .22s,box-shadow .2s,transform .2s;
}
.flow-step:hover{
  border-color:var(--green-soft);box-shadow:var(--sh-sm);
  transform:translateX(4px);
}
/* Animated connector line */
.flow-step:not(:last-child)::after{
  content:'';position:absolute;
  bottom:-9px;left:52px;
  width:1.5px;height:8px;
  background:linear-gradient(to bottom,var(--green),var(--green-soft));
  border-radius:2px;z-index:1;
  transform:scaleY(0);transform-origin:top;
  transition:transform .4s ease .55s;
}
.flow-step.rv.in:not(:last-child)::after{transform:scaleY(1)}

.flow-num{
  width:50px;height:50px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:1.3rem;font-weight:700;
  color:#fff;flex-shrink:0;
}
.flow-step:nth-child(1) .flow-num{background:var(--pink)}
.flow-step:nth-child(2) .flow-num{background:var(--blue)}
.flow-step:nth-child(3) .flow-num{background:var(--green)}
.flow-step:nth-child(4) .flow-num{background:var(--pink)}
.flow-tag{
  display:inline-block;
  background:var(--green-pale);color:var(--green-deep);
  font-size:.68rem;font-weight:700;padding:2px 9px;
  border-radius:var(--r-full);margin-bottom:7px;
  border:1px solid var(--green-soft);
}
.flow-title{font-weight:700;font-size:.97rem;margin-bottom:6px;color:var(--ink)}
.flow-desc{font-size:.86rem;color:var(--ink-mid);line-height:1.92}

/* ═══════════════════════════════════════════════
   FAQ — smooth cubic-bezier expand
═══════════════════════════════════════════════ */
.faq{background:var(--pink-pale)}
.faq-list{margin-top:44px;display:flex;flex-direction:column;gap:10px}
.faq-item{
  background:var(--white);border-radius:var(--r-md);
  box-shadow:var(--sh-xs);overflow:hidden;
  border:1.5px solid transparent;
  transition:border-color .25s,box-shadow .25s;
}
.faq-item.open{border-color:var(--pink-mid);box-shadow:var(--sh-sm)}
.faq-q{
  display:flex;align-items:center;gap:14px;
  width:100%;border:0;background:transparent;text-align:left;
  padding:22px 24px;cursor:pointer;user-select:none;
  transition:background .15s;
  color:inherit;font:inherit;
}
.faq-q:hover{background:var(--pink-pale)}
.faq-q-badge{
  width:32px;height:32px;border-radius:50%;
  background:var(--pink);color:#fff;
  font-weight:700;font-size:.85rem;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.faq-q-text{font-weight:700;font-size:.93rem;flex:1;line-height:1.62}
.faq-toggle{
  width:26px;height:26px;border-radius:50%;
  background:var(--pink-pale);border:1.5px solid var(--pink-mid);
  color:var(--pink-deep);
  display:flex;align-items:center;justify-content:center;
  font-size:.95rem;font-weight:300;
  transition:transform .3s cubic-bezier(.4,0,.2,1),background .2s;flex-shrink:0;
}
.faq-item.open .faq-toggle{
  transform:rotate(45deg);background:var(--pink);color:#fff;border-color:var(--pink);
}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .45s cubic-bezier(.4,0,.2,1),opacity .35s ease;
  opacity:0;
}
.faq-item.open .faq-a{opacity:1}
.faq-a-inner{
  padding:0 24px 22px 70px;
  border-top:1px solid var(--pink-soft);padding-top:16px;
  font-size:.9rem;color:var(--ink-mid);line-height:2;
}

/* ═══════════════════════════════════════════════
   BIG CTA
═══════════════════════════════════════════════ */
.big-cta{
  background:linear-gradient(140deg,#FFF0F7 0%,#FDE8F0 38%,#E8F6FC 100%);
  position:relative;overflow:hidden;
}
.big-cta::before{
  content:'';position:absolute;top:-100px;right:-100px;
  width:360px;height:360px;
  background:radial-gradient(circle,rgba(240,123,160,.1),transparent 70%);
  pointer-events:none;
}
.big-cta::after{
  content:'';position:absolute;bottom:-80px;left:-80px;
  width:300px;height:300px;
  background:radial-gradient(circle,rgba(59,174,200,.09),transparent 70%);
  pointer-events:none;
}
.big-cta-inner{position:relative;z-index:1;text-align:center}
.big-cta-logo{width:76px;height:76px;margin:0 auto 22px}
.cta-title{
  font-family:var(--serif);
  font-size:clamp(1.4rem,4vw,2rem);font-weight:700;
  color:var(--ink);margin-bottom:14px;line-height:1.55;
}
.cta-sub{font-size:.96rem;color:var(--ink-mid);margin-bottom:38px;line-height:2.05}
.cta-btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-bottom:28px}
.cta-info{font-size:.82rem;color:var(--ink-light);line-height:2}
.cta-info strong{color:var(--ink-mid)}

.contact-form,.contact-panel{
  max-width:720px;margin:44px auto 0;text-align:left;
  background:rgba(255,255,255,.88);
  border:1.5px solid var(--pink-soft);
  border-radius:var(--r-xl);
  box-shadow:var(--sh-sm);
  padding:34px;
}
.contact-panel{text-align:center}
.contact-panel-text{font-size:.9rem;color:var(--ink-mid);line-height:1.9;margin:0 auto 22px;max-width:540px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-field{display:flex;flex-direction:column;gap:7px}
.form-field.full{grid-column:1/-1}
.form-label{font-size:.82rem;font-weight:700;color:var(--ink-mid)}
.form-label .req{color:var(--pink-deep);font-size:.72rem;margin-left:6px}
.form-input,.form-select,.form-textarea{
  width:100%;border:1.5px solid var(--border);border-radius:16px;
  background:#fff;color:var(--ink);font-family:var(--sans);font-size:16px;
  padding:13px 15px;outline:none;transition:border-color .18s,box-shadow .18s;
}
.form-textarea{min-height:150px;resize:vertical;line-height:1.8}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  border-color:var(--pink-mid);box-shadow:0 0 0 4px rgba(240,123,160,.12);
}
.form-note{font-size:.78rem;color:var(--ink-light);line-height:1.8;margin-top:14px}
.form-check{display:flex;align-items:flex-start;gap:10px;margin-top:18px;font-size:.84rem;color:var(--ink-mid);line-height:1.75}
.form-check input{margin-top:6px;accent-color:var(--pink)}
.form-status{
  display:none;
  margin-top:18px;
  border-radius:16px;
  padding:12px 14px;
  font-size:.88rem;
  font-weight:700;
  line-height:1.7;
}
.form-status.show{display:block}
.form-status.success{
  background:var(--green-pale);
  color:var(--green-deep);
  border:1px solid var(--green-soft);
}
.form-status.error{
  background:var(--pink-pale);
  color:var(--pink-deep);
  border:1px solid var(--pink-mid);
}
.form-submit{margin-top:24px;text-align:center}

/* ═══════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════ */
.footer{background:var(--brown);color:rgba(255,255,255,.78);padding:64px 0 34px}
.footer-top{
  display:grid;grid-template-columns:1fr 1fr;gap:52px;
  padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:28px;
}
.footer-logo-row{display:flex;align-items:center;gap:13px;margin-bottom:16px}
.footer-logo-svg{width:46px;height:46px;flex-shrink:0}
.footer-brand-name{
  font-family:var(--serif);font-size:.9rem;font-weight:700;
  color:#fff;line-height:1.45;
}
.footer-brand-name small{
  display:block;font-size:.66rem;color:rgba(255,255,255,.45);
  font-weight:400;margin-bottom:2px;
}
.footer-brand-name em{color:var(--pink-mid);font-style:normal;font-size:1.05rem}
.footer-tagline{font-size:.76rem;color:rgba(255,255,255,.38);letter-spacing:.1em;margin-bottom:14px}
.footer-desc{font-size:.82rem;color:rgba(255,255,255,.52);line-height:1.92}
.footer-info-title{
  font-size:.76rem;font-weight:700;color:rgba(255,255,255,.65);
  letter-spacing:.08em;margin-bottom:14px;padding-bottom:8px;
  border-bottom:1px solid rgba(255,255,255,.1);
}
.footer-info-list{display:flex;flex-direction:column;gap:6px}
.footer-info-row{display:flex;gap:10px;font-size:.81rem;color:rgba(255,255,255,.56);line-height:1.75}
.footer-info-row dt{color:rgba(255,255,255,.34);min-width:76px;flex-shrink:0}
.footer-bottom{text-align:center;font-size:.72rem;color:rgba(255,255,255,.25)}

/* ═══════════════════════════════════════════════
   FLOATING BAR (mobile)
═══════════════════════════════════════════════ */
#float-bar{
  position:fixed;bottom:0;left:0;right:0;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-top:1px solid var(--border);
  padding:12px 20px;display:flex;gap:10px;
  z-index:300;
  transform:translateY(100%);transition:transform .38s cubic-bezier(.4,0,.2,1);
}
#float-bar.show{transform:translateY(0)}
#float-bar .btn{flex:1;padding:14px 10px;font-size:.86rem}


/* Strengthened scroll response */
.rv{
  opacity:0;
  transform:translateY(34px) scale(.985);
  transition:opacity .8s cubic-bezier(.22,1,.36,1), transform .8s cubic-bezier(.22,1,.36,1);
  will-change:opacity,transform;
}
.rv.in{opacity:1;transform:translateY(0) scale(1)}

@media(max-width:820px){
  .hero{padding:42px 0 56px}
  .hero-inner{gap:30px}
  .hero-visual{width:100%;max-width:340px;margin-inline:auto;padding:28px 22px 24px}
  .hero-logo-svg{width:142px}
  .hero-card-points{grid-template-columns:1fr 1fr}
}
@media(max-width:520px){
  .wrap,.wrap-narrow{padding:0 20px}
  .header-inner{height:64px}
  .header-mark{width:38px;height:38px}
  .header-name{font-size:.76rem}
  .header-sub{font-size:.55rem}
  .header-right{display:none}
  .header-logo{gap:9px;min-width:0}
  .header-text{min-width:0}
  .header-name,.header-sub{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100vw - 92px)}
  .hero-text{padding:24px 0}
  .hero-text::before{inset:-10px -14px;background:rgba(255,255,255,.34)}
  .hero-badges{justify-content:flex-start}
  .hero-badge{font-size:.68rem;padding:6px 12px}
  .hero-title{font-size:clamp(1.62rem,8vw,2.1rem);line-height:1.5}
  .hero-sub{font-size:.92rem;line-height:1.9;margin-bottom:26px}
  .hero-card-points{gap:7px}
  .hero-card-point{font-size:.74rem;padding:7px 8px}
}

/* ═══════════════════════════════════════════════
   REDUCED MOTION
═══════════════════════════════════════════════ */
@media(prefers-reduced-motion:reduce){
  .hero-orb,.h-dot,.hero-badge-dot{animation:none!important}
  .rv{transition:opacity .01s!important;transform:none!important}
  .values-line{transition:none!important}
  .flow-step:not(:last-child)::after{transition:none!important}
  .faq-a{transition:max-height .01s,opacity .01s!important}
}

/* ═══════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════ */
@media(max-width:820px){
  body{font-size:15px}
  .sec{padding:72px 0}
  .hero{padding:56px 0 72px}
  .hero-inner{grid-template-columns:1fr;gap:32px}
  .hero-visual{margin-inline:auto;padding:28px 22px 24px}
  .hero-logo-svg{width:142px;height:auto}
  .hero::before,.orb-3{display:none}
  .header-tel{display:none}
  .specialist-inner{grid-template-columns:1fr;gap:36px}
  .specialist-visual{flex-direction:row;align-items:center}
  .profile-card{width:min(100%,280px);margin-inline:auto}
  .values-grid{grid-template-columns:1fr;gap:16px}
  .values-line{display:none}
  .ages-split{grid-template-columns:1fr}
  .age-panel{padding:32px 24px}
  .services-grid{grid-template-columns:1fr}
  .net-ring{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr;gap:30px}
  .worries-grid{grid-template-columns:1fr}
  .contact-form,.contact-panel{padding:24px 20px}
  .form-grid{grid-template-columns:1fr}
  .flow-step{grid-template-columns:50px 1fr;padding:22px 18px}
}
@media(min-width:821px){#float-bar{display:none!important}}
@media(max-width:440px){
  .hero-btns{flex-direction:column}
  .hero-btns .btn{width:100%}
  .cta-btns{flex-direction:column;align-items:center}
  .cta-btns .btn{width:100%;max-width:300px}
}
/* ===== HERO BACKGROUND VIDEO - no white mask ===== */
.hero.hero-video-bg{position:relative;overflow:hidden;background:#fff;min-height:600px;display:flex;align-items:center;}
.hero.hero-video-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.22),rgba(255,255,255,.04) 48%,rgba(255,255,255,.16));z-index:1;pointer-events:none}
.hero-bg-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.64;z-index:0;pointer-events:none;transform:scale(1.02);filter:saturate(.96) contrast(1.02) brightness(1.02);}
.hero-video-bg .hero-orb{z-index:1;opacity:.30;}
.hero-video-bg .wrap,.hero-video-bg .hero-inner,.hero-video-bg .hero-text{position:relative;z-index:2;}
.hero-video-bg .hero-text{max-width:700px;text-shadow:0 2px 14px rgba(255,255,255,.78);}
.hero-video-bg .hero-title,.hero-video-bg .hero-sub{filter:drop-shadow(0 2px 8px rgba(255,255,255,.76));}
@media(max-width:820px){.hero.hero-video-bg{min-height:560px;align-items:center;}.hero-bg-video{opacity:.58;}.hero-video-bg .hero-text{max-width:100%;}}

/* ═══════════════════════════════════════════════
   NEWS
═══════════════════════════════════════════════ */
.news{background:#F5F7FA}
.news-head{text-align:center;margin-bottom:32px}
.news-h2{font-size:1.25rem;font-weight:700;color:var(--ink);margin-bottom:10px}
.news-lead{font-size:.9rem;color:#6B7A8D;margin:0}
.news-list{list-style:none;padding:0;margin:0 auto;max-width:900px;display:grid;grid-template-columns:1fr;gap:14px}
.news-item{background:#fff;border:1px solid #E2E8F0;border-radius:8px;text-align:left;box-shadow:var(--sh-xs);overflow:hidden;transition:border-color .2s,box-shadow .2s,transform .2s}
.news-item:hover{border-color:var(--blue-soft);box-shadow:var(--sh-sm);transform:translateY(-2px)}
.news-card-body{display:block;height:100%;padding:20px}
.news-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.news-date{font-size:.82rem;color:#6B7A8D;letter-spacing:.03em;white-space:nowrap}
.news-cat{font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:3px;white-space:nowrap}
.news-cat-info{background:#EBF5FB;color:var(--blue-deep);border:1px solid #BDDCEF}
.news-cat-prep{background:#FEF9EC;color:#8A6500;border:1px solid #F5DFA0}
.news-cat-service{background:#EBF7F2;color:#1E7A50;border:1px solid #A8DFC4}
.news-title{font-size:.98rem;font-weight:700;color:var(--ink);line-height:1.6;margin:0}
.news-text{font-size:.84rem;color:var(--ink-mid);line-height:1.85;margin-top:10px}
.news-link{display:inline-flex;margin-top:14px;font-size:.82rem;font-weight:700;color:var(--blue-deep);border-bottom:1px solid currentColor}
@media(min-width:768px){
  .news-list{grid-template-columns:repeat(3,1fr)}
}
