/* =========================================================
   寺田クリニック トップページ  ―  Premium Redesign
   navy × orange × ivory ／ 明朝の品格 + 編集的レイアウト
   ========================================================= */
:root{
  --navy:#1C3A5C; --navy2:#274D74; --navy-deep:#142A40; --blue:#3D77A6;
  --orange:#F0832E; --orange-deep:#D96C16; --orange-soft:#FCE7D2;
  --ink:#22303A; --sub:#5E6B74; --line:#E7E1D6; --line2:#EEEAE2;
  --bg:#FFFFFF; --ivory:#F8F5EF; --navy-soft:#EAF0F5;
  --max:1180px; --pad:40px;
  --serif:"Noto Serif JP",serif;
  --sans:"Noto Sans JP","Hiragino Sans",sans-serif;
  --en:"Cormorant Garamond",serif;
  --num:"Inter",sans-serif;
  --sh1:0 2px 10px rgba(28,58,92,.06);
  --sh2:0 18px 50px rgba(28,58,92,.13);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{font-size:16px;scroll-behavior:smooth;}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.85;
  letter-spacing:.03em;overflow-x:hidden;overflow-wrap:break-word;line-break:strict;-webkit-font-smoothing:antialiased;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}

.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad);}
.sect{padding:120px 0;}
.sect.ivory{background:var(--ivory);}

/* ---- section label (English + Japanese) ---- */
.label{text-align:center;margin-bottom:60px;}
.label .en{display:block;font-family:var(--en);font-style:italic;font-weight:500;
  font-size:1.5rem;letter-spacing:.06em;color:var(--orange);margin-bottom:6px;}
.label .ja{display:block;font-family:var(--serif);font-weight:600;font-size:2rem;
  letter-spacing:.06em;color:var(--navy);line-height:1.4;}
.label .sub{display:block;font-size:1rem;color:var(--sub);margin-top:16px;letter-spacing:.04em;}
.label.left{text-align:left;}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-weight:700;
  font-size:.95rem;letter-spacing:.05em;padding:16px 32px;border-radius:2px;transition:.3s;cursor:pointer;border:none;}
.btn svg{width:1.15em;height:1.15em;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;}
.btn-cta{background:var(--orange);color:#fff;box-shadow:0 10px 26px rgba(240,131,46,.32);}
.btn-cta:hover{background:var(--orange-deep);transform:translateY(-3px);}
.btn-navy{background:var(--navy);color:#fff;}
.btn-navy:hover{background:var(--navy2);transform:translateY(-3px);}
.btn-line{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.6);}
.btn-line:hover{background:rgba(255,255,255,.12);border-color:#fff;}
.btn-ghost{background:#fff;color:var(--navy);border:1.5px solid var(--navy);}
.btn-ghost:hover{background:var(--navy);color:#fff;}
.more{display:inline-flex;align-items:center;gap:10px;font-family:var(--num);font-weight:600;
  font-size:.86rem;letter-spacing:.12em;color:var(--navy);text-transform:uppercase;}
.more::after{content:"";width:30px;height:1px;background:var(--orange);transition:.3s;}
.more:hover::after{width:46px;}

.ico{width:1em;height:1em;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;flex:none;}
/* Health Icons (healthicons.org) ― inline svg, fill via currentColor */
.hi{fill:currentColor;flex:none;}
/* ---- scroll reveal (ふわっと浮かび上がる) ---- */
.reveal{opacity:0;transform:translateY(28px);
  transition:opacity .85s cubic-bezier(.22,.7,.2,1),transform .85s cubic-bezier(.22,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
/* hero load fade-up */
.hero .inner>*{animation:heroUp .95s cubic-bezier(.22,.7,.2,1) both;}
.hero .inner>*:nth-child(1){animation-delay:.05s;}
.hero .inner>*:nth-child(2){animation-delay:.16s;}
.hero .inner>*:nth-child(3){animation-delay:.27s;}
.hero .inner>*:nth-child(4){animation-delay:.38s;}
.hero .inner>*:nth-child(5){animation-delay:.49s;}
@keyframes heroUp{from{opacity:0;transform:translateY(26px);}to{opacity:1;transform:none;}}
@media (prefers-reduced-motion:reduce){
  .reveal,.reveal.in{opacity:1!important;transform:none!important;transition:none!important;}
  .hero .inner>*{animation:none!important;}
}

/* ============ HEADER ============ */
.header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,.94);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line2);transition:.4s;}
.header .inner{max-width:1320px;margin:0 auto;padding:0 36px;height:84px;display:flex;align-items:center;gap:28px;}
.header.scrolled{height:68px;box-shadow:var(--sh1);}
.header.scrolled .inner{height:68px;}
.logo{display:flex;flex-direction:column;line-height:1.1;white-space:nowrap;}
.logo .mk{font-family:var(--serif);font-weight:600;font-size:1.4rem;color:var(--navy);letter-spacing:.06em;}
.gnav{margin-left:auto;display:flex;gap:30px;font-size:.92rem;font-weight:500;}
.gnav a{position:relative;padding:6px 0;white-space:nowrap;transition:.2s;}
.gnav a:hover{color:var(--orange-deep);}
.h-cta{display:flex;align-items:center;gap:18px;}
.h-tel{font-family:var(--num);font-weight:700;color:var(--navy);font-size:1.1rem;display:flex;align-items:center;gap:6px;white-space:nowrap;}
.h-tel .ico{width:1.05em;height:1.05em;}
.h-btn{padding:11px 22px;font-size:.85rem;border-radius:2px;}
.hamb{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;}
.hamb span{width:26px;height:2px;background:var(--navy);border-radius:2px;}

/* ============ HERO ============ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;color:#fff;overflow:hidden;}
.hero .bg{position:absolute;inset:0;background:url("images/hero.png") center/cover no-repeat;}
.hero .bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,rgba(15,32,52,.92) 0%,rgba(20,42,64,.78) 42%,rgba(20,42,64,.30) 100%);}
.hero .inner{position:relative;z-index:2;max-width:var(--max);margin:0 auto;padding:120px var(--pad) 90px;width:100%;}
.hero h1{font-family:var(--serif);font-weight:600;font-size:3.5rem;line-height:1.5;letter-spacing:.04em;margin-bottom:24px;text-shadow:0 2px 20px rgba(0,0,0,.25);}
.hero h1 .em{color:#FFB066;}
.hero .subh{font-family:var(--serif);font-weight:500;font-size:1.32rem;color:#EAF1F8;letter-spacing:.08em;
  margin-bottom:22px;padding-left:18px;border-left:3px solid var(--orange);}
.hero .lead{font-size:1.06rem;line-height:2;max-width:32em;color:#D9E3EE;margin-bottom:18px;font-weight:300;}
.hero .keys{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:34px;}
.hero .keys span{font-size:.85rem;font-weight:500;padding:7px 18px;border:1px solid rgba(255,255,255,.4);border-radius:999px;backdrop-filter:blur(4px);}
.hero .acts{display:flex;gap:16px;flex-wrap:wrap;}
.scrolldown{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;font-family:var(--num);
  font-size:.62rem;letter-spacing:.3em;color:rgba(255,255,255,.7);text-transform:uppercase;writing-mode:vertical-rl;}
.scrolldown::after{content:"";display:block;width:1px;height:40px;background:rgba(255,255,255,.5);margin:10px auto 0;}

/* ============ INFO BAR ============ */
.infobar{background:var(--navy);color:#fff;}
.infobar .inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad);display:flex;flex-wrap:wrap;}
.infobar .it{flex:1;min-width:200px;display:flex;align-items:flex-start;gap:12px;padding:26px 10px;border-left:1px solid rgba(255,255,255,.12);}
.infobar .it .ic{margin-top:2px;}
.infobar .it:first-child{border-left:none;}
.infobar .it .ic{width:26px;height:26px;color:#FFB066;stroke-width:1.4;}
.infobar .it>div{display:flex;flex-direction:column;}
.infobar .it .k{display:block;font-family:var(--en);font-style:italic;font-size:1.3rem;color:#FFC489;letter-spacing:.05em;line-height:1.15;margin-bottom:4px;}
.infobar .it .v{display:block;font-size:1rem;font-weight:500;line-height:1.55;}
.infobar .it .v b{font-family:var(--num);font-weight:700;font-size:1.1rem;}

/* ============ STRENGTH ============ */
.str-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.str{text-align:center;padding:18px 14px;}
.str .ic-c{width:84px;height:84px;border-radius:50%;background:var(--navy-soft);display:flex;align-items:center;justify-content:center;
  margin:0 auto 22px;transition:.35s;}
.str .ic-c .hi{width:40px;height:40px;color:var(--navy);}
.str:hover .ic-c{background:var(--orange);transform:translateY(-6px);}
.str:hover .ic-c .hi{color:#fff;}
.str .n{font-family:var(--en);font-style:italic;font-size:1.05rem;color:var(--orange);display:block;margin-bottom:4px;}
.str h3{font-family:var(--serif);font-weight:600;font-size:1.18rem;color:var(--navy);margin-bottom:12px;letter-spacing:.04em;}
.str p{font-size:1rem;color:var(--sub);line-height:1.8;}

/* ============ SYMPTOMS ============ */
.sym-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.sym{position:relative;background:#fff;border:1px solid var(--line);border-radius:12px;padding:30px 28px 26px;
  transition:.35s;overflow:hidden;display:flex;flex-direction:column;}
.sym::before{content:"\201C";position:absolute;top:2px;right:18px;font-family:var(--en);font-style:italic;
  font-size:5.2rem;line-height:1;color:var(--orange-soft);pointer-events:none;}
.sym:hover{box-shadow:var(--sh2);transform:translateY(-5px);border-color:#F2D9C0;}
.sym .si{width:50px;height:50px;color:var(--orange);margin-bottom:16px;position:relative;z-index:1;}
.sym h3{font-family:var(--serif);font-weight:600;font-size:1.34rem;color:var(--navy);margin-bottom:12px;
  letter-spacing:.02em;line-height:1.55;position:relative;z-index:1;}
.sym p{font-size:1rem;color:var(--sub);line-height:1.8;margin-bottom:20px;flex:1;}
.sym .route{align-self:flex-start;display:inline-flex;align-items:center;gap:9px;font-size:.85rem;font-weight:700;
  color:var(--orange-deep);background:var(--orange-soft);border-radius:999px;padding:8px 18px;transition:.3s;}
.sym .route::before{content:"→";font-family:var(--num);}
.sym:hover .route{background:var(--orange);color:#fff;}

/* ============ SERVICES ============ */
.svc-tag{display:flex;align-items:center;gap:14px;font-family:var(--en);font-style:italic;font-size:1.15rem;
  color:var(--navy);margin:0 0 22px;}
.svc-tag::after{content:"";flex:1;height:1px;background:var(--line);}
.svc-tag .jp{font-family:var(--serif);font-size:1.05rem;font-weight:600;letter-spacing:.06em;color:var(--orange-deep);}
.svc-spec{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px;}
.svc-card{position:relative;background:var(--navy);color:#fff;border-radius:4px;padding:32px 28px;overflow:hidden;transition:.35s;}
.svc-card::after{content:"";position:absolute;right:-30px;top:-30px;width:110px;height:110px;border-radius:50%;background:rgba(255,255,255,.05);}
.svc-card:hover{transform:translateY(-5px);box-shadow:var(--sh2);}
.svc-card .pill{display:inline-block;font-family:var(--en);font-style:italic;font-size:.85rem;color:#FFC489;letter-spacing:.06em;margin-bottom:12px;}
.svc-card h3{font-family:var(--serif);font-weight:600;font-size:1.4rem;margin-bottom:10px;letter-spacing:.03em;}
.svc-card p{font-size:1rem;color:#CBD8E4;line-height:1.8;}
.svc-gen{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.svc-g{background:#fff;border:1px solid var(--line);border-radius:4px;padding:22px 24px;transition:.3s;position:relative;}
.svc-g:hover{border-color:var(--orange);box-shadow:var(--sh1);}
.svc-g h4{font-family:var(--serif);font-weight:600;font-size:1.12rem;color:var(--navy);margin-bottom:4px;}
.svc-g p{font-size:1rem;color:var(--sub);line-height:1.7;}
.svc-g .ar{position:absolute;top:22px;right:22px;color:var(--orange);font-weight:700;}
.svc-jihi{margin-top:24px;text-align:center;font-size:1rem;color:var(--sub);}
.svc-jihi a{color:var(--navy);font-weight:700;border-bottom:1px solid var(--orange);}

/* ============ NIGHT BAND ============ */
.night{position:relative;background:linear-gradient(115deg,var(--navy-deep),var(--navy) 60%,var(--navy2));color:#fff;overflow:hidden;}
.night::before{content:"";position:absolute;right:-80px;top:-80px;width:360px;height:360px;border-radius:50%;background:rgba(240,131,46,.10);}
.night .inner{max-width:var(--max);margin:0 auto;padding:88px var(--pad);position:relative;z-index:2;
  display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;}
.night .en{font-family:var(--en);font-style:italic;font-size:1.4rem;color:#FFC489;letter-spacing:.06em;}
.night h2{font-family:var(--serif);font-weight:600;font-size:2.2rem;line-height:1.5;margin:8px 0 18px;letter-spacing:.04em;}
.night p{color:#D5E0EC;font-size:1rem;line-height:2;font-weight:300;max-width:26em;}
.night .badge{display:inline-flex;align-items:center;gap:8px;background:var(--orange);color:#fff;font-weight:700;
  font-size:.82rem;padding:6px 16px;border-radius:999px;margin-bottom:18px;}
.night .panel{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:6px;padding:32px;}
.night .time{font-family:var(--serif);font-weight:600;font-size:2.7rem;line-height:1.2;letter-spacing:.03em;}
.night .time span{color:#FFB066;margin:0 6px;}
.night .meta{font-size:1rem;color:#D5E0EC;margin:10px 0 20px;line-height:1.7;}
.night .tel{display:flex;align-items:center;gap:10px;background:var(--orange);color:#fff;font-weight:700;font-size:1.05rem;
  padding:14px 22px;border-radius:3px;font-family:var(--num);justify-content:center;transition:.3s;}
.night .tel:hover{background:var(--orange-deep);}
.night .note{font-size:.95rem;color:#A9BBCD;margin-top:14px;}

/* ============ GREETING ============ */
.greet{display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:center;}
.greet-ph{position:relative;}
.greet-ph .main{border-radius:6px;overflow:hidden;box-shadow:var(--sh2);aspect-ratio:4/4.4;}
.greet-ph .main img{width:100%;height:100%;object-fit:cover;object-position:top center;}
.greet-ph .since{position:absolute;right:-22px;bottom:-22px;width:122px;height:122px;border-radius:50%;background:var(--orange);
  color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:var(--sh2);}
.greet-ph .since .e{font-family:var(--en);font-style:italic;font-size:.85rem;}
.greet-ph .since .y{font-family:var(--num);font-weight:700;font-size:1.6rem;line-height:1;}
.greet-ph .since .s{font-size:.62rem;letter-spacing:.08em;margin-top:3px;}
.greet-body .en{font-family:var(--en);font-style:italic;font-size:1.5rem;color:var(--orange);}
.greet-body h2{font-family:var(--serif);font-weight:600;font-size:2.1rem;color:var(--navy);margin:6px 0 26px;letter-spacing:.05em;line-height:1.5;}
.greet-body p{font-family:var(--serif);font-size:1.02rem;line-height:2.15;color:#3a4750;margin-bottom:16px;font-weight:400;}
.greet-body .lineage{font-size:1rem;color:var(--sub);line-height:1.9;padding:18px 22px;background:var(--ivory);border-left:3px solid var(--orange);margin:24px 0;}
.greet-body .sign{font-family:var(--serif);font-size:1.05rem;color:var(--navy);margin-bottom:24px;}
.greet-body .sign b{font-size:1.3rem;margin-left:6px;}

/* ============ FLOW ============ */
.flow{position:relative;}
.flow .script{position:absolute;top:-36px;left:50%;transform:translateX(-50%);font-family:var(--en);font-style:italic;
  font-size:6rem;color:rgba(240,131,46,.12);z-index:0;pointer-events:none;}
.flow-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;position:relative;z-index:1;}
.fstep{text-align:center;position:relative;}
.fstep .num{width:74px;height:74px;border-radius:50%;background:#fff;border:2px solid var(--navy-soft);
  display:flex;align-items:center;justify-content:center;margin:0 auto 18px;position:relative;transition:.3s;}
.fstep .num .hi{width:32px;height:32px;color:var(--navy);}
.fstep .num .n{position:absolute;top:-8px;right:-8px;width:26px;height:26px;border-radius:50%;background:var(--orange);
  color:#fff;font-family:var(--num);font-weight:700;font-size:.8rem;display:flex;align-items:center;justify-content:center;}
.fstep:hover .num{border-color:var(--orange);transform:translateY(-4px);}
.fstep h4{font-family:var(--serif);font-weight:600;font-size:1.05rem;color:var(--navy);margin-bottom:6px;}
.fstep p{font-size:1rem;color:var(--sub);line-height:1.7;}
.flow-arrow{position:absolute;top:30px;right:-13px;color:var(--line);font-size:1.2rem;z-index:2;}

/* ============ COLUMN ============ */
.col-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}
.col{background:#fff;border:1px solid var(--line);border-radius:4px;overflow:hidden;transition:.35s;}
.col:hover{box-shadow:var(--sh2);transform:translateY(-5px);}
.col .th{height:170px;background:linear-gradient(135deg,var(--navy-soft),#fff 70%,var(--orange-soft));
  display:flex;align-items:center;justify-content:center;}
.col .th .ico{width:40px;height:40px;color:#A9BBCD;stroke-width:1.2;}
.col .b{padding:24px;}
.col .cat{font-family:var(--en);font-style:italic;font-size:.95rem;color:var(--orange);}
.col h3{font-family:var(--serif);font-weight:600;font-size:1.08rem;color:var(--navy);line-height:1.6;margin:6px 0 10px;}
.col .date{font-family:var(--num);font-size:.78rem;color:var(--sub);letter-spacing:.06em;}

/* ============ NEWS ============ */
.news-list li{display:flex;gap:20px;align-items:baseline;padding:18px 2px;border-bottom:1px solid var(--line);}
.news-list .d{font-family:var(--num);font-size:.85rem;color:var(--sub);width:90px;flex:none;letter-spacing:.04em;}
.news-list .tg{font-size:.68rem;font-weight:700;padding:3px 10px;border-radius:2px;flex:none;letter-spacing:.04em;}
.tg-r{background:var(--orange-soft);color:var(--orange-deep);}
.tg-i{background:var(--navy-soft);color:var(--navy);}
.news-list .tx{font-size:1rem;}

/* ============ CLINIC INFO ============ */
.ci{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.ci-map{border-radius:6px;overflow:hidden;box-shadow:var(--sh1);}
.ci-map iframe{width:100%;height:520px;border:0;display:block;}
.hours-block{margin-bottom:30px;}
.hours-ttl{font-family:var(--serif);font-weight:600;font-size:1.18rem;color:var(--navy);margin-bottom:6px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.resv-badge{font-size:.78rem;font-weight:700;color:#fff;background:var(--orange);border-radius:999px;padding:3px 13px;letter-spacing:.05em;}
.hours-deps{font-size:1rem;color:var(--sub);margin-bottom:12px;line-height:1.6;}
.hours{width:100%;border-collapse:collapse;font-size:1rem;margin-bottom:14px;}
.hours th,.hours td{border:1px solid var(--line);padding:11px 6px;text-align:center;}
.hours thead th{background:var(--navy);color:#fff;font-weight:600;font-size:.82rem;letter-spacing:.04em;}
.hours .tl{text-align:left;font-family:var(--serif);font-weight:600;color:var(--navy);font-size:1rem;white-space:nowrap;}
.hours td.rest{color:var(--sub);background:var(--ivory);}
.hours .nt{color:var(--orange-deep);font-weight:700;}
.hours small{display:block;font-size:.62rem;color:var(--sub);}
.resv{background:var(--orange-soft);border-left:4px solid var(--orange);border-radius:0 8px 8px 0;padding:20px 24px;margin-bottom:24px;}
.resv-h{font-family:var(--serif);font-weight:600;font-size:1.08rem;color:var(--orange-deep);margin-bottom:10px;display:flex;align-items:center;gap:8px;}
.resv ul li{font-size:1rem;color:var(--ink);line-height:1.8;padding-left:18px;position:relative;margin-bottom:7px;}
.resv ul li:last-child{margin-bottom:0;}
.resv ul li::before{content:"";position:absolute;left:2px;top:.7em;width:7px;height:7px;border-radius:50%;background:var(--orange);}
.resv ul li strong{color:var(--orange-deep);font-weight:700;}
.hours-note{font-size:1rem;color:var(--sub);line-height:1.85;margin-bottom:24px;}
.hours-note strong{color:var(--ink);}
.ci-info{margin-top:28px;}
.ci-info dl{display:grid;grid-template-columns:auto 1fr;gap:0 18px;}
.ci-info dt{font-family:var(--serif);font-weight:600;color:var(--navy);font-size:.85rem;padding:12px 0;border-top:1px solid var(--line);}
.ci-info dd{font-size:1rem;padding:12px 0;border-top:1px solid var(--line);line-height:1.7;}

/* ============ FAQ ============ */
.faq{max-width:860px;margin:0 auto;}
.faq details{background:#fff;border:1px solid var(--line);border-radius:4px;margin-bottom:14px;overflow:hidden;}
.faq summary{list-style:none;cursor:pointer;padding:22px 26px;display:flex;align-items:center;gap:16px;font-weight:600;
  font-size:1rem;color:var(--navy);position:relative;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary .q{font-family:var(--en);font-style:italic;font-size:1.3rem;color:var(--orange);flex:none;}
.faq summary::after{content:"+";margin-left:auto;font-size:1.5rem;color:var(--orange);font-weight:400;transition:.3s;}
.faq details[open] summary::after{transform:rotate(45deg);}
.faq .a{padding:0 26px 24px 64px;font-size:1rem;color:var(--sub);line-height:1.9;}

/* ============ CTA BAND ============ */
.ctab{position:relative;background:url("images/hero.png") center/cover fixed;color:#fff;text-align:center;overflow:hidden;}
.ctab::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(15,30,48,.90),rgba(20,42,64,.90));}
.ctab .inner{position:relative;z-index:2;max-width:var(--max);margin:0 auto;padding:110px var(--pad);}
.ctab .en{font-family:var(--en);font-style:italic;font-size:1.6rem;color:#FFC489;}
.ctab h2{font-family:var(--serif);font-weight:600;font-size:2.6rem;line-height:1.5;margin:10px 0 30px;letter-spacing:.05em;}
.ctab .acts{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;}
.ctab .tel-big{margin-top:30px;font-family:var(--num);font-weight:700;font-size:1.1rem;letter-spacing:.04em;}
.ctab .tel-big b{font-size:2rem;display:block;letter-spacing:.02em;}

/* ============ FOOTER ============ */
.footer{background:var(--navy-deep);color:rgba(255,255,255,.78);padding:80px 0 0;font-size:.9rem;}
.footer .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:48px;padding-bottom:50px;}
.footer .mk{font-family:var(--serif);font-size:1.4rem;color:#fff;margin-bottom:4px;}
.footer .tag{font-family:var(--en);font-style:italic;font-size:.82rem;color:#FFC489;margin-bottom:18px;}
.footer .fi{line-height:1.95;opacity:.82;}
.footer-btns{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px;}
.footer-btn{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:999px;
  border:1px solid rgba(255,255,255,.28);font-size:.9rem;font-weight:600;color:#fff;transition:.25s;}
.footer-btn svg{width:1.15em;height:1.15em;}
.footer-ig:hover{background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF);border-color:transparent;}
.footer-hospita:hover{background:var(--orange);border-color:transparent;}
.footer h4{font-family:var(--en);font-style:italic;font-size:1rem;color:#FFC489;margin-bottom:16px;}
.footer ul li{margin-bottom:10px;}
.footer ul a:hover{color:#fff;}
.footer-b{border-top:1px solid rgba(255,255,255,.12);padding:20px 0;text-align:center;
  font-family:var(--num);font-size:.72rem;letter-spacing:.08em;opacity:.65;}

/* ============ FLOATING CTA (SP) ============ */
.fab{display:none;position:fixed;bottom:0;left:0;right:0;z-index:90;background:#fff;box-shadow:0 -4px 20px rgba(0,0,0,.14);}
.fab a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:15px 0;font-weight:700;font-size:.92rem;}
.fab .t{background:var(--navy);color:#fff;}
.fab .f{background:var(--orange);color:#fff;}
.fab .ico{width:1.1em;height:1.1em;}

/* ============ RESPONSIVE ============ */
@media (max-width:1023px){
  :root{--pad:32px;}
  .sect{padding:90px 0;}
  .str-grid{grid-template-columns:repeat(2,1fr);gap:32px;}
  .sym-grid,.svc-spec,.svc-gen,.col-grid{grid-template-columns:repeat(2,1fr);}
  .flow-grid{grid-template-columns:repeat(3,1fr);gap:28px;}
  .flow-arrow{display:none;}
  .night .inner,.greet,.ci{grid-template-columns:1fr;gap:40px;}
  .hero h1{font-size:2.8rem;}
}
@media (max-width:767px){
  :root{--pad:22px;}
  html{font-size:15px;}
  .sect{padding:64px 0;}
  .gnav,.h-cta{display:none;}
  .hamb{display:flex;margin-left:auto;}
  .header .inner{height:64px;padding:0 20px;}
  .header.scrolled .inner{height:60px;}
  .hero{min-height:88vh;}
  .hero .inner{padding:120px var(--pad) 80px;}
  .hero h1{font-size:1.5rem;line-height:1.6;letter-spacing:.02em;}
  .hero .subh{font-size:.92rem;letter-spacing:.03em;margin-bottom:18px;}
  .hero .lead{font-size:1rem;line-height:1.95;}
  .hero .acts{flex-direction:column;}
  .hero .acts .btn,.ctab .acts .btn{width:100%;}
  .ctab .acts{flex-direction:column;align-items:stretch;}
  .hours th,.hours td{padding:8px 3px;}
  .hours{font-size:.78rem;}
  .hours .tl{font-size:.72rem;}
  .scrolldown{display:none;}
  .infobar .it{flex:1 1 100%;border-left:none;border-top:1px solid rgba(255,255,255,.12);padding:18px 4px;}
  .infobar .it:first-child{border-top:none;}
  .label .ja{font-size:1.6rem;}
  .label .en,.greet-body .en,.night .en,.ctab .en{font-size:1.2rem;}
  .str-grid,.sym-grid,.svc-spec,.svc-gen,.col-grid,.flow-grid{grid-template-columns:1fr;}
  .flow-grid{gap:18px;}
  .greet-ph .since,.greet-ph .since{right:14px;}
  .greet-body h2,.night h2{font-size:1.7rem;}
  .ctab h2{font-size:1.9rem;}
  .ci-map iframe{height:300px;}
  .footer .cols{grid-template-columns:1fr;gap:30px;}
  .ctab{background-attachment:scroll;}
  .fab{display:flex;}
  body{padding-bottom:54px;}
}
