/*
Theme Name: gooosca Starry Spa
Theme URI: https://example.com/
Author: gooosca
Description: gooosca. Dry Head Spa & Facial salon WordPress theme. Starry luxury design with responsive bottom navigation.
Version: 1.0.0
Text Domain: gooosca
*/

:root{
  --dark:#070816;
  --ink:#282432;
  --muted:#756f84;
  --cream:#fff8ea;
  --paper:#fffaf4;
  --gold:#d9bd74;
  --violet:#5d4b91;
  --serif:"Yu Mincho","Hiragino Mincho ProN",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Noto Sans JP","Yu Gothic",sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.9;
  letter-spacing:.04em;
  padding-bottom:78px;
}
body.menu-open{overflow:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.header{
  position:fixed;
  z-index:130;
  top:0;left:0;right:0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 5vw;
  color:#fff;
  background:linear-gradient(rgba(5,6,16,.45),transparent);
  transition:.25s ease;
}
.header.scrolled,.menu-open .header{
  background:rgba(7,8,22,.82);
  backdrop-filter:blur(16px);
}
.logo{
  font-family:Georgia,serif;
  font-size:32px;
  letter-spacing:.08em;
  line-height:1;
}
.logo small{
  display:block;
  font-family:var(--sans);
  font-size:10px;
  letter-spacing:.22em;
  opacity:.75;
  margin-top:5px;
}
.nav{display:flex;gap:24px;align-items:center;font-size:13px}
.nav .reserve{
  border:1px solid rgba(217,189,116,.65);
  border-radius:999px;
  padding:9px 16px;
  background:rgba(217,189,116,.14);
}
.hamb{
  display:none;
  width:48px;
  height:48px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.42);
  background:rgba(255,255,255,.1);
  position:relative;
  color:#fff;
  cursor:pointer;
}
.hamb span{position:absolute;left:14px;width:20px;height:1px;background:currentColor;transition:.25s}
.hamb span:nth-child(1){top:17px}.hamb span:nth-child(2){top:24px}.hamb span:nth-child(3){top:31px}
.menu-open .hamb span:nth-child(1){top:24px;transform:rotate(45deg)}
.menu-open .hamb span:nth-child(2){opacity:0}
.menu-open .hamb span:nth-child(3){top:24px;transform:rotate(-45deg)}

.mobile-menu{
  position:fixed;
  inset:0;
  background:
    radial-gradient(circle at 16% 4%,rgba(144,111,209,.72),transparent 30%),
    radial-gradient(circle at 88% 18%,rgba(217,189,116,.17),transparent 24%),
    linear-gradient(180deg,rgba(7,8,22,.98),rgba(18,16,45,.99));
  z-index:120;
  color:#fff;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:.32s ease;
  overflow:auto;
}
.menu-open .mobile-menu{opacity:1;visibility:visible;pointer-events:auto}
.mobile-menu__inner{position:relative;min-height:100%;padding:106px 22px 118px;display:flex;flex-direction:column}
.mobile-menu__brand{font-family:Georgia,serif;font-size:34px;letter-spacing:.08em;line-height:1;margin-bottom:12px}
.mobile-menu__brand small{display:block;margin-top:7px;font-family:var(--sans);font-size:10px;letter-spacing:.22em;opacity:.68}
.mobile-menu__lead{margin:0 0 24px;color:rgba(255,255,255,.72);font-size:13px;line-height:1.85}
.mobile-menu__links{display:grid;gap:10px}
.mobile-menu__links a{display:flex;align-items:center;gap:13px;padding:14px 16px;border:1px solid rgba(255,255,255,.12);border-radius:19px;background:rgba(255,255,255,.055);box-shadow:inset 0 1px 0 rgba(255,255,255,.08);font-family:var(--serif);font-size:18px;letter-spacing:.055em;transition:.25s ease}
.mobile-menu__links a span{font-family:var(--sans);font-size:10px;color:var(--gold);letter-spacing:.18em;min-width:25px}
.mobile-menu__cta{display:grid;grid-template-columns:1fr;gap:12px;margin-top:24px}
.mobile-menu__cta a{width:100%;padding:0 20px;border-bottom:none;font-family:var(--sans);font-size:17px;line-height:1.2;text-align:center}
.mobile-line,.mobile-instagram{display:flex;align-items:center;justify-content:center;min-height:62px;border-radius:999px;font-weight:800;letter-spacing:.06em}
.mobile-line{background:linear-gradient(135deg,#ebd584,#b29142);color:#18111d;box-shadow:0 16px 36px rgba(217,189,116,.25)}
.mobile-instagram{color:#fff;border:1px solid rgba(255,255,255,.22);background:linear-gradient(135deg,rgba(107,79,199,.46),rgba(208,106,164,.28))}
.mobile-menu__address{margin:auto 0 0;color:rgba(255,255,255,.62);font-size:12px;line-height:1.85;padding-top:28px}

.hero{min-height:100svh;position:relative;color:#fff;background:#070816 url('http://gooosca.com/wp-content/uploads/2026/05/mv.png') center/cover no-repeat;overflow:hidden}
.slides,.slide{position:absolute;inset:0}
.slide{background-size:cover;background-position:center;opacity:0;animation:fade 28s infinite;will-change:opacity,transform}
.slide:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(5,6,16,.56),rgba(12,10,28,.30),rgba(9,8,23,.10)),linear-gradient(180deg,rgba(0,0,0,.04),rgba(7,8,22,.56))}
.s1{background-image:url('http://gooosca.com/wp-content/uploads/2026/05/mv.png')}
.s2{background-image:url('http://gooosca.com/wp-content/uploads/2026/05/ChatGPT-Image-2026年5月1日-04_04_30.png');animation-delay:7s}
.s3{background-image:url('http://gooosca.com/wp-content/uploads/2026/05/DSC_7388-scaled.jpg');animation-delay:14s}
.s4{background-image:url('http://gooosca.com/wp-content/uploads/2026/05/AdobeStock_387298399-scaled.jpeg');animation-delay:21s}
@keyframes fade{0%{opacity:0;transform:scale(1)}6%{opacity:1}28%{opacity:1}38%{opacity:0;transform:scale(1.13)}100%{opacity:0;transform:scale(1.13)}}
.slide.s1.is-first{opacity:1!important;visibility:visible!important;animation:fadeFirstImmediate 28s infinite!important}
@keyframes fadeFirstImmediate{
  0%{opacity:1;transform:scale(1)}
  24%{opacity:1;transform:scale(1.08)}
  36%{opacity:0;transform:scale(1.13)}
  88%{opacity:0;transform:scale(1.13)}
  100%{opacity:1;transform:scale(1)}
}
.hero-inner{position:relative;z-index:3;min-height:100svh;display:flex;align-items:center;max-width:1160px;margin:auto;padding:120px 5vw 0px}
.eyebrow{color:var(--gold);letter-spacing:.26em;font-size:12px;margin-bottom:20px;text-transform:uppercase}
.hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(44px,7vw,88px);line-height:1.18;letter-spacing:.1em;margin:0 0 24px;text-shadow:0 14px 38px rgba(0,0,0,.42)}
.hero h1 span{display:block;opacity:0;filter:blur(8px);transform:translateY(20px);animation:copy 1s forwards}
.hero h1 span:nth-child(2){animation-delay:.32s}.hero h1 span:nth-child(3){animation-delay:.64s}
@keyframes copy{to{opacity:1;filter:blur(0);transform:none}}
.lead{max-width:620px;font-size:16px;color:rgba(255,255,255,.88);margin-bottom:32px;opacity:0;transform:translateY(12px);animation:rise .8s 1s forwards}
@keyframes rise{to{opacity:1;transform:none}}
.actions{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;justify-content:center;align-items:center;min-width:184px;padding:15px 24px;border-radius:999px;font-weight:700;line-height:1.2}
.primary{background:linear-gradient(135deg,#ebd584,#b29142);color:#18111d;box-shadow:0 16px 38px rgba(217,189,116,.25)}
.ghost{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.3);backdrop-filter:blur(8px);color:#fff}
.hero-cards{position:relative;z-index:4;max-width:1160px;margin:0px auto 0;padding:5vw 46px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.info{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(14px);border-radius:20px;color:#fff;padding:18px}
.info b{font-family:var(--serif);font-size:24px;color:var(--gold);font-weight:400;display:block}
.info span{font-size:12px;color:rgba(255,255,255,.75)}
.info.hero-menu-info,.info.campaign-info{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.campaign-link{display:inline-flex;justify-content:center;align-items:center;margin-top:0;padding:8px 14px;border-radius:999px;background:linear-gradient(135deg,#ebd584,#b29142);color:#18111d!important;font-size:11px;font-weight:800;line-height:1.3;white-space:nowrap}

.section{padding:86px 5vw}
.container{max-width:1120px;margin:auto}
.title{text-align:center;margin-bottom:42px}
.en{font-size:12px;letter-spacing:.28em;color:#a88f4f;text-transform:uppercase}
.title h2{font-family:var(--serif);font-weight:400;font-size:clamp(28px,4vw,46px);line-height:1.45;margin:8px 0 0}
.title p{color:var(--muted);max-width:720px;margin:14px auto 0}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.worry,.card,.post{background:#fff;border-radius:26px;box-shadow:0 18px 55px rgba(66,48,90,.08);border:1px solid rgba(90,72,122,.12);overflow:hidden}
.worry{padding:24px}.worry .ico{font-size:27px;color:#a88f4f}.worry p,.card p,.post p{color:var(--muted);font-size:14px}
.photo-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;margin-top:34px;align-items:stretch}
.photo-link{display:block;position:relative;min-height:300px;border-radius:30px;overflow:hidden;color:#fff;box-shadow:0 18px 55px rgba(66,48,90,.12);transition:.35s ease}
.photo-link:hover{transform:translateY(-3px)}
.photo-link .photo{width:100%;height:100%;min-height:300px;border-radius:0;box-shadow:none;overflow:hidden;background:center/cover;transition:transform .35s ease,filter .35s ease}
.photo-link:hover .photo{transform:scale(1.035);filter:brightness(1.03)}
.photo-link .photo:after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(5,6,16,.08) 0%,rgba(5,6,16,.12) 42%,rgba(5,6,16,.74) 100%)}
.photo.p1{background-image:url('https://gooosca.com/wp-content/uploads/2026/05/head02.png')}
.photo.p2{background-image:url('https://gooosca.com/wp-content/uploads/2026/05/257A9626-scaled.jpg')}
.photo-overlay{position:absolute;z-index:3;left:24px;right:24px;bottom:22px;display:flex;align-items:flex-end;justify-content:space-between;gap:18px}
.photo-copy{color:#fff;text-shadow:0 6px 18px rgba(0,0,0,.42)}
.photo-copy .jp{display:block;font-family:var(--serif);font-size:24px;line-height:1.35;letter-spacing:.08em;margin-bottom:5px}
.photo-copy .en{display:block;color:rgba(255,255,255,.78);font-size:11px;letter-spacing:.22em;text-transform:uppercase}
.photo-cta{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:10px 17px;border-radius:999px;border:1px solid rgba(255,255,255,.32);background:rgba(255,255,255,.15);backdrop-filter:blur(10px);color:#fff;font-size:12px;font-weight:800;line-height:1;white-space:nowrap;box-shadow:0 10px 26px rgba(0,0,0,.18)}

.top-news{position:relative;z-index:5;background:var(--cream);padding:30px 5vw 0}
.top-news-box{max-width:1120px;margin:0 auto 0;background:#fff;border:1px solid rgba(90,72,122,.12);box-shadow:0 18px 55px rgba(66,48,90,.08);border-radius:28px;padding:24px 28px;display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:center}
.top-news-head h2{font-family:var(--serif);font-weight:400;font-size:28px;margin:0}
.top-news-more{font-size:13px;color:#a88f4f;font-weight:800}
.top-news-list{display:grid;gap:0}
.top-news-item{display:grid;grid-template-columns:110px 1fr 110px;gap:14px;align-items:center;border-bottom:1px solid rgba(90,72,122,.10);padding:12px 0}
.top-news-item:last-child{border-bottom:0}
.top-news-item time{font-size:12px;color:#a88f4f;font-weight:700}
.top-news-item a{font-weight:700}
.top-news-item span{justify-self:end;font-size:11px;padding:4px 10px;border-radius:999px;background:#f7f0ff;color:#5f536e}

.dark-box{background:linear-gradient(135deg,#11152c,#332150 58%,#64518e);color:#fff;border-radius:34px;padding:36px;display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:center;box-shadow:0 24px 80px rgba(8,8,18,.25)}
.dark-box h3{font-family:var(--serif);font-size:34px;font-weight:400;margin:0 0 8px}
.dark-photo{min-height:270px;border-radius:26px;background:url('https://gooosca.com/wp-content/uploads/2026/05/決定.png') center/cover}
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card-img{height:210px;background:center/cover}
.head{background-image:url('http://gooosca.com/wp-content/uploads/2026/05/ChatGPT-Image-2026年5月1日-04_04_30.png')}
.face{background-image:url('https://gooosca.com/wp-content/uploads/2026/05/DSC_7388-scaled.jpg')}
.set{background-image:url('https://gooosca.com/wp-content/uploads/2026/05/ChatGPT-Image-2026年5月1日-05_00_05.png')}
.card-body{padding:24px}.card h3{font-family:var(--serif);font-size:25px;font-weight:400;margin:0 0 8px}
.price{border-top:1px solid rgba(80,60,110,.12);padding-top:14px;margin-top:16px}.price div{display:flex;justify-content:space-between;gap:10px}.price b{white-space:nowrap;font-size:19px}
.option-box{margin-top:24px;background:#fff;border:1px solid rgba(90,72,122,.12);box-shadow:0 18px 55px rgba(66,48,90,.08);border-radius:26px;padding:26px;display:grid;grid-template-columns:.7fr 1.3fr;gap:20px;align-items:center}
.option-box h3{font-family:var(--serif);font-weight:400;font-size:25px;margin:0}
.option-list{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.option-item{background:linear-gradient(180deg,#fffaf4,#f7f0ff);border:1px solid rgba(90,72,122,.12);border-radius:20px;padding:18px;display:flex;justify-content:space-between;gap:14px;align-items:center}
.option-item b{font-size:20px;color:#a88f4f;white-space:nowrap}
.staff-detail-section{background:linear-gradient(180deg,#fff8ea,#fffaf4)}
.staff-profile-list{display:grid;gap:22px}
.staff-profile{scroll-margin-top:96px;display:grid;grid-template-columns:280px 1fr;gap:28px;align-items:center;background:#fff;border:1px solid rgba(90,72,122,.12);border-radius:30px;padding:24px;box-shadow:0 18px 55px rgba(66,48,90,.08)}
.staff-profile h3{font-family:var(--serif);font-weight:400;font-size:30px;margin:0 0 8px}
.staff-profile-img{min-height:300px;border-radius:24px;background:center/cover}
.owner{background-image:url('https://gooosca.com/wp-content/uploads/2026/05/257A0059.png')}
.expert{background-image:url('https://gooosca.com/wp-content/uploads/2026/05/IMG_1992.png')}
.newbie{background-image:url('https://images.unsplash.com/photo-1507003211169-0a1dd7228f2d?auto=format&fit=crop&w=900&q=80')}
.staff-meta{font-size:12px;color:#a88f4f;letter-spacing:.16em;text-transform:uppercase;margin-bottom:8px;font-weight:700}.staff-menu{color:#5f536e!important;font-weight:700}

.special{background:linear-gradient(180deg,#10142c,#251b43);color:#fff}.special .title p{color:rgba(255,255,255,.7)}
.special-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.special-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:28px;padding:18px;display:grid;grid-template-columns:170px 1fr;gap:20px}
.sp-img{border-radius:22px;background:center/cover;min-height:230px}
.sp1{background-image:url('https://gooosca.com/wp-content/uploads/2026/05/ChatGPT-Image-2026年5月1日-16_11_24.png')}
.sp2{background-image:url('https://gooosca.com/wp-content/uploads/2026/05/0002.png')}
.special-card h3{font-family:var(--serif);font-size:25px;font-weight:400;margin:0}.special-card p{color:rgba(255,255,255,.7);font-size:14px}.sp-price{color:var(--gold);font-family:var(--serif);font-size:22px}
.special-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}.detail-btn{display:inline-flex;justify-content:center;align-items:center;padding:10px 18px;border-radius:999px;border:1px solid rgba(217,189,116,.52);background:rgba(217,189,116,.14);color:#fff;font-size:13px;font-weight:700}.line-btn{display:inline-flex;justify-content:center;align-items:center;padding:10px 18px;border-radius:999px;background:linear-gradient(135deg,#ebd584,#b29142);color:#18111d;font-size:13px;font-weight:800;box-shadow:0 12px 30px rgba(217,189,116,.18)}

.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.post-img{height:170px;background:center/cover}
.n1{background-image:url('https://images.unsplash.com/photo-1540555700478-4be289fbecef?auto=format&fit=crop&w=800&q=80')}
.n2{background-image:url('https://images.unsplash.com/photo-1506126613408-eca07ce68773?auto=format&fit=crop&w=800&q=80')}
.n3{background-image:url('https://images.unsplash.com/photo-1576091160399-112ba8d25d1d?auto=format&fit=crop&w=800&q=80')}
.access{background:linear-gradient(135deg,#11152c,#332150);color:#fff;border-radius:34px;padding:34px;display:grid;grid-template-columns:1fr 1fr;gap:26px}.access-photo{min-height:300px;border-radius:24px;background:url('https://gooosca.com/wp-content/uploads/2026/05/IMG_6010.png') center/cover}

.cta{position:relative;overflow:hidden;isolation:isolate;color:#fff;text-align:center;padding:100px 5vw;background:radial-gradient(circle at 15% 20%, rgba(168,120,255,.22) 0, rgba(168,120,255,0) 28%),radial-gradient(circle at 82% 18%, rgba(114,83,255,.20) 0, rgba(114,83,255,0) 24%),radial-gradient(circle at 70% 70%, rgba(95,56,196,.18) 0, rgba(95,56,196,0) 26%),linear-gradient(180deg,#070b24 0%, #10173b 30%, #1b1d55 65%, #2a1f58 100%)}
.cta:before,.cta:after{content:"";position:absolute;inset:0;pointer-events:none}
.cta:before{z-index:0;background-image:radial-gradient(circle at 2% 10%, rgba(255,255,255,.95) 0 1.1px, transparent 1.8px),radial-gradient(circle at 14% 72%, rgba(255,245,210,.9) 0 1.1px, transparent 1.8px),radial-gradient(circle at 27% 16%, rgba(191,205,255,.95) 0 1.15px, transparent 1.85px),radial-gradient(circle at 39% 32%, rgba(255,245,210,.88) 0 1.05px, transparent 1.75px),radial-gradient(circle at 52% 12%, rgba(196,180,255,.92) 0 1.05px, transparent 1.75px),radial-gradient(circle at 64% 26%, rgba(255,245,210,.9) 0 1.1px, transparent 1.8px),radial-gradient(circle at 76% 8%, rgba(191,205,255,.9) 0 1.1px, transparent 1.8px),radial-gradient(circle at 88% 36%, rgba(255,245,210,.86) 0 1.05px, transparent 1.75px),radial-gradient(circle at 98% 76%, rgba(196,180,255,.88) 0 1.05px, transparent 1.75px);animation:ctaStarsA 7s ease-in-out infinite alternate}
.cta:after{z-index:1;background-image:radial-gradient(circle at 6% 54%, rgba(255,255,255,.9) 0 1.6px, transparent 2.5px),radial-gradient(circle at 29% 48%, rgba(207,216,255,.92) 0 1.7px, transparent 2.7px),radial-gradient(circle at 55% 76%, rgba(255,248,225,.9) 0 1.6px, transparent 2.6px),radial-gradient(circle at 79% 88%, rgba(207,216,255,.92) 0 1.7px, transparent 2.7px),radial-gradient(circle at 92% 44%, rgba(255,255,255,.96) 0 1.9px, transparent 2.9px);animation:ctaStarsB 4.8s ease-in-out infinite alternate}
@keyframes ctaStarsA{0%{opacity:.48;filter:brightness(.85)}30%{opacity:.88;filter:brightness(1.08)}55%{opacity:.58;filter:brightness(.94)}100%{opacity:.96;filter:brightness(1.18)}}
@keyframes ctaStarsB{0%{opacity:.20;transform:scale(1)}35%{opacity:.72;transform:scale(1.01)}60%{opacity:.34;transform:scale(1)}100%{opacity:.84;transform:scale(1.015)}}
.cta .container{position:relative;z-index:2}.cta h2{font-family:var(--serif);font-weight:400;font-size:clamp(30px,4vw,52px)}
.shooting-star{position:absolute;top:72px;left:-18%;width:220px;height:2px;pointer-events:none;z-index:1;transform:rotate(-18deg);opacity:0;animation:shootingStar 11s ease-in-out infinite}
.shooting-star:before{content:"";position:absolute;inset:0;border-radius:999px;background:linear-gradient(90deg,rgba(255,255,255,0) 0%,rgba(210,220,255,.22) 20%,rgba(255,255,255,.82) 72%,rgba(255,255,255,1) 100%);box-shadow:0 0 10px rgba(255,255,255,.28),0 0 18px rgba(177,195,255,.22)}
.shooting-star:after{content:"";position:absolute;right:-4px;top:50%;width:7px;height:7px;border-radius:50%;transform:translateY(-50%);background:radial-gradient(circle, rgba(255,255,255,1) 0%, rgba(216,225,255,.92) 45%, rgba(216,225,255,0) 75%);box-shadow:0 0 8px rgba(255,255,255,.58),0 0 16px rgba(173,187,255,.4)}
@keyframes shootingStar{0%{transform:translate3d(0,0,0) rotate(-18deg);opacity:0}8%{opacity:0}14%{opacity:.9}26%{transform:translate3d(1120px,220px,0) rotate(-18deg);opacity:.92}31%{opacity:0}100%{transform:translate3d(1120px,220px,0) rotate(-18deg);opacity:0}}

.footer{background:#070816;color:rgba(255,255,255,.7);text-align:center;padding:42px 5vw;font-size:12px}
.bottom{display:none;position:fixed;left:0;right:0;bottom:0;z-index:55;background:rgba(255,250,244,.95);backdrop-filter:blur(16px);grid-template-columns:repeat(5,1fr);box-shadow:0 -10px 36px rgba(0,0,0,.14)}
.bottom a,.bottom button{border:0;background:transparent;font:inherit;font-size:10px;padding:8px 2px;display:flex;flex-direction:column;align-items:center;gap:2px;color:#2b2636}.bottom b{font-size:18px}.bottom .insta{background:linear-gradient(135deg,#6b4fc7,#d06aa4);color:#fff}.bottom .res{background:linear-gradient(135deg,#16172e,#5e4b91);color:#fff}

.page-hero{position:relative;min-height:74svh;color:#fff;overflow:hidden;display:flex;align-items:center;background:#070816}
.page-hero:before{content:"";position:absolute;inset:0;background-image:var(--hero-image);background-size:cover;background-position:center;transform:scale(1.04)}
.page-hero:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 18% 10%,rgba(168,120,255,.18),transparent 28%),linear-gradient(90deg,rgba(5,6,16,.82),rgba(12,10,28,.62),rgba(9,8,23,.28)),linear-gradient(180deg,rgba(0,0,0,.08),rgba(7,8,22,.86))}
.page-hero-inner{position:relative;z-index:2;max-width:1120px;margin:auto;padding:140px 5vw 86px;width:100%}
.page-hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(42px,6.5vw,82px);line-height:1.2;letter-spacing:.08em;margin:0 0 24px;text-shadow:0 14px 38px rgba(0,0,0,.42)}
.page-hero p{max-width:660px;color:rgba(255,255,255,.86);font-size:16px;margin:0 0 32px}
.profile-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:32px;align-items:start}
.profile-card,.info-card,.flow-card,.price-card{background:#fff;border:1px solid rgba(90,72,122,.12);border-radius:30px;box-shadow:0 18px 55px rgba(66,48,90,.08);overflow:hidden}
.profile-photo{min-height:520px;background-image:var(--profile-image);background-size:cover;background-position:center}.profile-body{padding:28px}.profile-body h2,.info-card h3,.flow-card h3,.price-card h3{color: #343434; font-family:var(--serif);font-weight:400;font-size:30px;margin:0 0 12px}.profile-body p,.info-card p,.flow-card p,.price-card p,.list li{color:var(--muted)}
.badges{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 0}.badge{display:inline-flex;padding:7px 13px;border-radius:999px;background:linear-gradient(180deg,#fffaf4,#f7f0ff);border:1px solid rgba(90,72,122,.12);color:#5f536e;font-size:12px;font-weight:800}.info-stack{display:grid;gap:20px}.info-card{padding:28px}.list{margin:16px 0 0;padding-left:1.2em}.list li{margin:.35em 0}
.dark{background:linear-gradient(135deg,#11152c,#332150 58%,#64518e);color:#fff}.dark .title p{color:rgba(255,255,255,.72)}
.course-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;align-items:stretch}.price-card{padding:30px;height:100%}.price-main{font-family:var(--serif);color:#a88f4f;font-size:38px;line-height:1.2;margin:10px 0 12px}.price-note{background:rgba(217,189,116,.14);border:1px solid rgba(217,189,116,.36);border-radius:18px;padding:14px 16px;color:#5f536e;font-weight:700;font-size:14px}
.price-photo{width:100%;aspect-ratio:4 / 3;border-radius:22px;background-size:cover;background-position:center;margin:0 0 22px;box-shadow:0 18px 42px rgba(66,48,90,.12);position:relative;overflow:hidden}.price-photo:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,7,20,.04),rgba(8,7,20,.18))}
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.flow-card{padding:24px}.flow-num{color:var(--gold);letter-spacing:.18em;font-size:12px;font-weight:800}

@media(max-width:900px){
  body{padding-bottom:70px}
  .hamb{display:block}.nav{display:none}.header{padding:14px 18px}.logo{font-size:27px}
  .hero{min-height:auto}.hero-inner{min-height:100svh;padding:112px 22px 34px;align-items:center}.hero h1{font-size:clamp(34px,10.4vw,50px);line-height:1.34;letter-spacing:.055em}.lead{font-size:14px;line-height:2}.actions{width:100%}.btn{width:100%;min-width:0}
  .hero-cards{margin:0;padding: 52px 20px 42px;grid-template-columns:1fr;gap:10px}.info{display:flex;align-items:center;justify-content:space-between;padding:15px 18px}.info b{font-size:20px}.info span{text-align:right;font-size:12px}
  .bottom{display:grid}.section{padding:70px 20px}.title{text-align:left}.title p{margin-left:0}.grid4,.photo-grid,.dark-box,.menu-grid,.post-grid,.special-grid,.access,.option-box,.option-list,.course-grid,.profile-grid,.flow{grid-template-columns:1fr}
  .dark-box,.access{padding:26px;border-radius:28px}.special-card,.staff-profile{grid-template-columns:1fr}.sp-img{min-height:220px}.staff-profile{padding:18px;border-radius:24px}.staff-profile-img{min-height:240px}.staff-profile h3{font-size:26px}
  .top-news{padding:24px 20px}.top-news-box{grid-template-columns:1fr;padding:22px 20px;gap:14px;border-radius:22px}.top-news-head h2{font-size:24px}.top-news-item{grid-template-columns:1fr;gap:4px;padding:14px 0}.top-news-item span{width:max-content;justify-self:start}
  .photo-link{min-height:250px}.photo-link .photo{min-height:250px}.photo-overlay{left:18px;right:18px;bottom:18px;align-items:flex-start;flex-direction:column;gap:10px}.photo-copy .jp{font-size:20px}
  .page-hero-inner{padding:124px 22px 70px}.page-hero h1{font-size:clamp(34px,10vw,50px);line-height:1.34}.page-hero p{font-size:14px;line-height:2}.profile-photo{min-height:360px}.profile-body,.info-card,.price-card{padding:24px}
  .shooting-star{top:54px;left:-42%;width:160px;animation-duration:12s}
  @keyframes shootingStar{0%{transform:translate3d(0,0,0) rotate(-18deg);opacity:0}8%{opacity:0}14%{opacity:.9}26%{transform:translate3d(620px,180px,0) rotate(-18deg);opacity:.92}31%{opacity:0}100%{transform:translate3d(620px,180px,0) rotate(-18deg);opacity:0}}
}


/* ---- Fix: medium desktop hero layout ---- */
@media (max-width: 1280px) and (min-width: 901px){
  .hero-inner{
    align-items:flex-start;
    padding-top:136px;
  }
  .hero h1{
    font-size:clamp(54px,6.4vw,82px);
    line-height:1.2;
    margin-bottom:22px;
  }
  .lead{
    max-width:760px;
  }
  .actions{
    position:relative;
    z-index:5;
    margin-top:18px;
  }
  .hero-cards{
    position:relative;
    z-index:6;
    margin-top:-18px;
    gap:14px;
  }
  .info{
    min-height:122px;
  }
  .info.hero-menu-info,
  .info.campaign-info{
    align-items:center;
  }
}

@media (max-width: 1120px) and (min-width: 901px){
  .header{
    padding:14px 26px;
  }
  .nav{
    gap:16px;
    font-size:12px;
  }
  .hero-inner{
  }
  .hero-cards{
    margin-top:0;
    gap:12px;
  }
  .info{
    padding:16px;
  }
  .info b{
    font-size:22px;
  }
  .campaign-link{
    font-size:10px;
    padding:8px 12px;
  }
}


/* ---- Footer/CTA star adjustment: remove shooting star and increase small stars ---- */
.shooting-star{
  display:none!important;
}

.cta::before{
  opacity:.95;
  background-image:
    radial-gradient(circle at 2% 10%, rgba(255,255,255,.95) 0 1px, transparent 1.7px),
    radial-gradient(circle at 6% 34%, rgba(255,255,255,.72) 0 .9px, transparent 1.6px),
    radial-gradient(circle at 10% 78%, rgba(255,245,210,.86) 0 1px, transparent 1.7px),
    radial-gradient(circle at 14% 18%, rgba(196,180,255,.88) 0 .9px, transparent 1.6px),
    radial-gradient(circle at 18% 58%, rgba(255,255,255,.78) 0 1px, transparent 1.7px),
    radial-gradient(circle at 22% 86%, rgba(255,255,255,.68) 0 .9px, transparent 1.6px),
    radial-gradient(circle at 27% 16%, rgba(191,205,255,.92) 0 1px, transparent 1.7px),
    radial-gradient(circle at 31% 42%, rgba(255,245,210,.82) 0 .9px, transparent 1.6px),
    radial-gradient(circle at 35% 72%, rgba(255,255,255,.86) 0 1px, transparent 1.7px),
    radial-gradient(circle at 39% 32%, rgba(255,245,210,.88) 0 1px, transparent 1.7px),
    radial-gradient(circle at 44% 12%, rgba(255,255,255,.72) 0 .9px, transparent 1.6px),
    radial-gradient(circle at 48% 52%, rgba(196,180,255,.86) 0 1px, transparent 1.7px),
    radial-gradient(circle at 52% 82%, rgba(255,255,255,.76) 0 .9px, transparent 1.6px),
    radial-gradient(circle at 56% 26%, rgba(255,245,210,.84) 0 1px, transparent 1.7px),
    radial-gradient(circle at 60% 66%, rgba(255,255,255,.72) 0 .9px, transparent 1.6px),
    radial-gradient(circle at 64% 8%, rgba(191,205,255,.84) 0 1px, transparent 1.7px),
    radial-gradient(circle at 68% 44%, rgba(255,245,210,.78) 0 .9px, transparent 1.6px),
    radial-gradient(circle at 72% 78%, rgba(255,255,255,.88) 0 1px, transparent 1.7px),
    radial-gradient(circle at 76% 22%, rgba(196,180,255,.82) 0 .9px, transparent 1.6px),
    radial-gradient(circle at 80% 58%, rgba(255,255,255,.74) 0 1px, transparent 1.7px),
    radial-gradient(circle at 84% 86%, rgba(255,245,210,.82) 0 .9px, transparent 1.6px),
    radial-gradient(circle at 88% 36%, rgba(255,255,255,.86) 0 1px, transparent 1.7px),
    radial-gradient(circle at 92% 12%, rgba(191,205,255,.82) 0 .9px, transparent 1.6px),
    radial-gradient(circle at 96% 72%, rgba(255,255,255,.72) 0 1px, transparent 1.7px);
  animation:ctaStarsA 6.5s ease-in-out infinite alternate;
}

.cta::after{
  opacity:.72;
  background-image:
    radial-gradient(circle at 5% 52%, rgba(255,255,255,.92) 0 1.35px, transparent 2.2px),
    radial-gradient(circle at 12% 24%, rgba(255,248,225,.86) 0 1.25px, transparent 2.1px),
    radial-gradient(circle at 20% 70%, rgba(207,216,255,.88) 0 1.25px, transparent 2.1px),
    radial-gradient(circle at 28% 46%, rgba(255,255,255,.92) 0 1.35px, transparent 2.2px),
    radial-gradient(circle at 36% 18%, rgba(255,248,225,.86) 0 1.25px, transparent 2.1px),
    radial-gradient(circle at 44% 84%, rgba(255,255,255,.80) 0 1.25px, transparent 2.1px),
    radial-gradient(circle at 52% 38%, rgba(207,216,255,.90) 0 1.35px, transparent 2.2px),
    radial-gradient(circle at 60% 72%, rgba(255,248,225,.86) 0 1.25px, transparent 2.1px),
    radial-gradient(circle at 68% 26%, rgba(255,255,255,.92) 0 1.35px, transparent 2.2px),
    radial-gradient(circle at 76% 88%, rgba(207,216,255,.86) 0 1.25px, transparent 2.1px),
    radial-gradient(circle at 84% 42%, rgba(255,248,225,.88) 0 1.35px, transparent 2.2px),
    radial-gradient(circle at 94% 62%, rgba(255,255,255,.90) 0 1.25px, transparent 2.1px);
  animation:ctaStarsB 4.2s ease-in-out infinite alternate;
}


/* ---- Requested adjustment: top-news margin top ---- */
.top-news{
  margin-top:0px!important;
}
@media (min-width: 901px){
  .top-news{
    margin-top:0px!important;
  }
}
@media (max-width: 1120px) and (min-width: 901px){
  .top-news{
    margin-top:0px!important;
  }
}


/* ---- Blog archive button ---- */
.blog-archive-action{
  display:flex;
  justify-content:center;
  margin-top:32px;
}
.blog-archive-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:220px;
  padding:14px 26px;
  border-radius:999px;
  background:linear-gradient(135deg,#1b1730,#5e4b91);
  color:#fff!important;
  font-weight:800;
  font-size:14px;
  box-shadow:0 16px 38px rgba(66,48,90,.18);
  border:1px solid rgba(255,255,255,.12);
}
.blog-archive-btn::after{
  content:"→";
  margin-left:10px;
  color:#d9bd74;
}
@media(max-width:900px){
  .blog-archive-action{
    justify-content:stretch;
    margin-top:24px;
  }
  .blog-archive-btn{
    width:100%;
  }
}


/* 投稿サムネイル・投稿詳細画像の比率修正 */

/* トップページ・一覧ページの投稿サムネイル */
.post-img{
  width:100%!important;
  height:auto!important;
  aspect-ratio:16 / 10;
  object-fit:cover;
  object-position:center center;
  background-size:cover;
  background-position:center center;
  display:block;
}

/* 投稿詳細ページのメイン画像 */
.single-featured-img{
  width:100%;
  height:auto;
  aspect-ratio:16 / 10;
  object-fit:cover;
  object-position:center center;
  border-radius:24px;
  margin:20px 0 28px;
  box-shadow:0 18px 55px rgba(66,48,90,.10);
}

/* スマホでは少し縦に余裕を持たせる */
@media(max-width:900px){
  .post-img,
  .single-featured-img{
    aspect-ratio:4 / 3;
  }
}

/* お知らせ詳細ページの画像を伸ばさず自然表示 */
.single .wp-post-image,
.single-gooosca_news .wp-post-image,
.single-campaign .wp-post-image{
  width:100%!important;
  height:auto!important;
  object-fit:contain!important;
  border-radius:24px;
  margin:20px 0 28px;
  box-shadow:0 18px 55px rgba(66,48,90,.10);
}

/* =========================================
   gooosca. 記事本文 見出しデザイン
   青紫・都会的・スクロールアニメーション版
========================================= */

.gooosca-article-content {
  color: #37344c;
  line-height: 2;
  font-size: 16px;
  letter-spacing: 0.02em;
}

/* 共通：最初は少し下に隠す */
.gooosca-article-content h2,
.gooosca-article-content h3,
.gooosca-article-content h4 {
  opacity: 0;
  transform: translateY(18px);
  transition:
    opacity 0.75s ease,
    transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
}

.gooosca-article-content h2.is-visible,
.gooosca-article-content h3.is-visible,
.gooosca-article-content h4.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* h2：大見出し */
.gooosca-article-content h2 {
  position: relative;
  margin: 4.2em 0 1.6em;
  padding: 0 0 1em;
  font-size: clamp(1.5rem, 2.8vw, 2.05rem);
  font-weight: 600;
  line-height: 1.55;
  color: #292743;
  letter-spacing: 0.06em;
}

/* h2 小さな英字風アクセント */
.gooosca-article-content h2::before {
  content: "gooosca.";
  display: block;
  width: fit-content;
  margin-bottom: 0.65em;
  padding: 0.28em 0.7em;
  font-size: 0.72rem;
  font-family: var(--serif, serif);
  font-weight: 400;
  letter-spacing: 0.16em;
  color: #6b66c9;
  background: rgba(244, 242, 255, 0.9);
  border: 1px solid rgba(120, 112, 220, 0.16);
  border-radius: 999px;
}

/* h2 下線 */
.gooosca-article-content h2::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  height: 1px;
  border-radius: 999px;
  background: linear-gradient(90deg, #6769df 0%, #ad95ff 45%, rgba(173, 149, 255, 0) 100%);
  transition: width 1s cubic-bezier(0.22, 1, 0.36, 1) 0.2s;
}

.gooosca-article-content h2.is-visible::after {
  width: min(320px, 75%);
}

/* h3：中見出し */
.gooosca-article-content h3 {
  position: relative;
  margin: 3em 0 1.15em;
  padding: 0.95em 1.15em 0.95em 1.35em;
  font-size: clamp(1.16rem, 2vw, 1.42rem);
  font-weight: 600;
  line-height: 1.6;
  color: #34315a;
  letter-spacing: 0.04em;
  background:
    linear-gradient(135deg, rgba(250, 249, 255, 0.96) 0%, rgba(241, 244, 255, 0.84) 100%);
  border: 1px solid rgba(118, 110, 216, 0.13);
  border-radius: 18px;
  box-shadow: 0 14px 34px rgba(76, 73, 138, 0.06);
  overflow: hidden;
}

/* h3 左ライン */
.gooosca-article-content h3::before {
  content: "";
  position: absolute;
  left: 0;
  top: 20%;
  width: 4px;
  height: 60%;
  border-radius: 999px;
  background: linear-gradient(180deg, #686ae1 0%, #b49cff 100%);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 0.75s cubic-bezier(0.22, 1, 0.36, 1) 0.18s;
}

.gooosca-article-content h3.is-visible::before {
  transform: scaleY(1);
}

/* h3 背景にうっすら光 */
.gooosca-article-content h3::after {
  content: "";
  position: absolute;
  right: -40px;
  top: -40px;
  width: 110px;
  height: 110px;
  background: radial-gradient(circle, rgba(180, 156, 255, 0.22), rgba(180, 156, 255, 0));
  pointer-events: none;
}

/* h4：小見出し */
.gooosca-article-content h4 {
  position: relative;
  margin: 2.35em 0 0.85em;
  padding-left: 1.1em;
  font-size: clamp(1.04rem, 1.7vw, 1.18rem);
  font-weight: 600;
  line-height: 1.6;
  color: #514ec0;
  letter-spacing: 0.035em;
}

/* h4 ドット */
.gooosca-article-content h4::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.68em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: linear-gradient(135deg, #696be2, #b49cff);
  box-shadow: 0 0 0 0 rgba(141, 123, 231, 0.18);
  transition: box-shadow 0.7s ease 0.2s;
}

.gooosca-article-content h4.is-visible::before {
  box-shadow: 0 0 0 7px rgba(141, 123, 231, 0.12);
}

/* 本文 */
.gooosca-article-content p {
  margin: 0 0 1.55em;
}

/* リンク */
.gooosca-article-content a {
  color: #5d60d6;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.28em;
}

/* リスト */
.gooosca-article-content ul,
.gooosca-article-content ol {
  margin: 1.2em 0 1.8em;
  padding-left: 1.4em;
}

.gooosca-article-content li {
  margin-bottom: 0.65em;
}

/* 画像 */
.gooosca-article-content img {
  max-width: 100%;
  height: auto;
  border-radius: 18px;
}

/* スマホ */
@media screen and (max-width: 768px) {
  .gooosca-article-content {
    font-size: 15px;
  }

  .gooosca-article-content h2 {
    margin: 3.3em 0 1.35em;
    font-size: clamp(1.34rem, 6vw, 1.7rem);
    letter-spacing: 0.04em;
  }

  .gooosca-article-content h2::before {
    font-size: 0.68rem;
  }

  .gooosca-article-content h3 {
    margin: 2.5em 0 1em;
    padding: 0.85em 1em 0.85em 1.15em;
    border-radius: 15px;
  }

  .gooosca-article-content h4 {
    margin: 2em 0 0.75em;
  }
}

/* 動きを減らす設定の人にはアニメーションを切る */
@media (prefers-reduced-motion: reduce) {
  .gooosca-article-content h2,
  .gooosca-article-content h3,
  .gooosca-article-content h4 {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .gooosca-article-content h2::after {
    width: min(320px, 75%);
    transition: none;
  }

  .gooosca-article-content h3::before {
    transform: scaleY(1);
    transition: none;
  }
}

/* =========================================
   gooosca. ブログ・お知らせ一覧ページ
   index.php用デザイン
========================================= */

.gooosca-archive-page {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 88% 12%, rgba(170, 150, 255, 0.22), transparent 34%),
    radial-gradient(circle at 8% 88%, rgba(108, 114, 230, 0.12), transparent 30%);
}

/* コンテナ */
.gooosca-archive-page .container {
  position: relative;
  z-index: 1;
}

/* タイトルエリア */
.gooosca-archive-page .archive-title {
  margin-bottom: 48px;
  animation: goooscaArchiveFadeUp 0.8s ease both;
}

.gooosca-archive-page .archive-title .en {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
  padding: 0.38em 0.9em;
  font-size: 0.78rem;
  font-family: var(--serif, serif);
  font-weight: 400;
  letter-spacing: 0.18em;
  color: #6865c9;
  background: rgba(246, 244, 255, 0.9);
  border: 1px solid rgba(128, 116, 220, 0.16);
  border-radius: 999px;
}

.gooosca-archive-page .archive-title .en::after {
  content: "";
  display: block;
  width: 38px;
  height: 1px;
  background: linear-gradient(90deg, #7673e6, rgba(118, 115, 230, 0));
}

.gooosca-archive-page .archive-title h2 {
  position: relative;
  margin: 0;
  padding-bottom: 20px;
  font-family: var(--serif, serif);
  font-size: clamp(2.1rem, 5vw, 3.6rem);
  font-weight: 400;
  line-height: 1.25;
  letter-spacing: 0.06em;
  color: #292743;
}

.gooosca-archive-page .archive-title h2::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: min(360px, 72%);
  height: 1px;
  background: linear-gradient(
    90deg,
    #686ae1 0%,
    #b49cff 45%,
    rgba(180, 156, 255, 0) 100%
  );
}

/* 投稿グリッド */
.gooosca-archive-page .post-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 30px;
}

/* 投稿カード */
.gooosca-archive-page .gooosca-archive-card {
  position: relative;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(130, 123, 218, 0.14);
  border-radius: 28px;
  box-shadow: 0 18px 45px rgba(76, 73, 138, 0.08);
  backdrop-filter: blur(10px);
  transition:
    transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.45s ease,
    border-color 0.45s ease;
  animation: goooscaArchiveFadeUp 0.85s ease both;
}

.gooosca-archive-page .gooosca-archive-card:nth-child(2) {
  animation-delay: 0.08s;
}

.gooosca-archive-page .gooosca-archive-card:nth-child(3) {
  animation-delay: 0.16s;
}

.gooosca-archive-page .gooosca-archive-card:nth-child(4) {
  animation-delay: 0.24s;
}

.gooosca-archive-page .gooosca-archive-card:hover {
  transform: translateY(-7px);
  box-shadow: 0 26px 65px rgba(76, 73, 138, 0.14);
  border-color: rgba(130, 123, 218, 0.28);
}

/* サムネイル */
.gooosca-archive-page .archive-thumb-link {
  display: block;
  overflow: hidden;
  border-radius: 28px 28px 0 0;
}

.gooosca-archive-page .post-img {
  display: block;
  width: 100%;
  height: 230px;
  object-fit: cover;
  transition:
    transform 0.85s cubic-bezier(0.22, 1, 0.36, 1),
    filter 0.85s ease;
}

.gooosca-archive-page .gooosca-archive-card:hover .post-img {
  transform: scale(1.05);
  filter: brightness(1.04) saturate(1.04);
}

/* サムネイルなしの場合 */
.gooosca-archive-page .post-img.n1 {
  background:
    linear-gradient(135deg, rgba(105, 107, 226, 0.16), rgba(180, 156, 255, 0.18)),
    linear-gradient(135deg, #f8f7ff, #eef1ff);
}

/* カード本文 */
.gooosca-archive-page .card-body {
  padding: 24px 24px 26px;
}

.gooosca-archive-page .archive-date {
  margin-bottom: 10px;
  font-size: 0.76rem;
  letter-spacing: 0.14em;
  color: #7773aa;
}

/* 投稿タイトル */
.gooosca-archive-page .card-body h3 {
  margin: 0 0 12px;
  padding: 0;
  font-size: clamp(1.08rem, 2vw, 1.28rem);
  font-weight: 600;
  line-height: 1.65;
  letter-spacing: 0.03em;
  color: #302d4f;
  background: none;
  border: none;
  box-shadow: none;
}

.gooosca-archive-page .card-body h3::before,
.gooosca-archive-page .card-body h3::after {
  display: none;
}

.gooosca-archive-page .card-body h3 a {
  color: inherit;
  text-decoration: none;
  transition: color 0.3s ease;
}

.gooosca-archive-page .card-body h3 a:hover {
  color: #6264d8;
}

/* 抜粋 */
.gooosca-archive-page .card-body p {
  margin: 0 0 18px;
  color: #5a5772;
  font-size: 0.94rem;
  line-height: 1.9;
}

/* Read more */
.gooosca-archive-page .archive-readmore {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 0.76rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  color: #6264d8;
  text-decoration: none;
}

.gooosca-archive-page .archive-readmore::after {
  content: "";
  display: block;
  width: 34px;
  height: 1px;
  background: currentColor;
  transition: width 0.35s ease;
}

.gooosca-archive-page .archive-readmore:hover::after {
  width: 54px;
}

/* アニメーション */
@keyframes goooscaArchiveFadeUp {
  from {
    opacity: 0;
    transform: translateY(18px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* タブレット */
@media screen and (max-width: 1024px) {
  .gooosca-archive-page .post-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* スマホ */
@media screen and (max-width: 768px) {
  .gooosca-archive-page {
    padding-top: 110px !important;
  }

  .gooosca-archive-page .archive-title {
    margin-bottom: 32px;
  }

  .gooosca-archive-page .archive-title h2 {
    font-size: clamp(1.9rem, 10vw, 2.6rem);
  }

  .gooosca-archive-page .post-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .gooosca-archive-page .post-img {
    height: 215px;
  }

  .gooosca-archive-page .card-body {
    padding: 22px 20px 24px;
  }
}