/* ============================================================
   cms/top.css - トップページテンプレート用
   ヒーロー・ユーザーナビ・ニュース・ストレングス
   施設紹介・暮らしプレビュー・コンテンツナビ・トピックス
   ============================================================ */

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;padding:var(--sp-3xl) 0 calc(var(--sp-4xl) + 40px);
  margin-top:0;overflow:hidden;min-height:520px;
}
.hero__slideshow{position:absolute;inset:0;z-index:0}
.hero__slide{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.8s ease-in-out;
  will-change:opacity;
  filter:saturate(1.3) contrast(1.05) brightness(1.02);
}
.hero__slide.is-active{opacity:1}
.hero__slideshow-overlay{display:none}

.hero__inner{position:relative;z-index:2;display:flex;flex-direction:column;gap:var(--sp-xl)}

.hero__content{max-width:560px}
.hero__title{
  font-family:var(--f-head);font-weight:700;color:var(--c-white);
  line-height:1.35;margin-bottom:var(--sp-md);
  text-shadow:0 2px 16px rgba(0,0,0,.35), 0 1px 4px rgba(0,0,0,.2);
}
.hero__title-line{display:block;font-size:1.75rem}
.hero__subtitle{font-size:.95rem;color:rgba(255,255,255,.85);line-height:1.9;margin-bottom:var(--sp-md);text-shadow:0 2px 12px rgba(0,0,0,.3), 0 1px 3px rgba(0,0,0,.15)}

.hero__circle-cta{
  --cta-tq:#FF9F43;--cta-tq-d:#E8872E;--cta-tq-rgb:255,159,67;
  position:absolute;z-index:3;
  right:var(--sp-lg);top:calc(50% - 80px);
  display:flex;justify-content:center;align-items:center;
  width:160px;aspect-ratio:1;border-radius:50%;
  color:var(--c-white);text-decoration:none;transition:scale var(--t-base);
}
.hero__circle-cta::before{
  content:'';position:absolute;z-index:-1;inset:0;
  display:block;width:82%;aspect-ratio:1;margin:auto;border-radius:50%;
  background:radial-gradient(50% 50% at 50% 50%, var(--cta-tq) 20%, var(--cta-tq-d) 100%);
  box-shadow:0 8px 32px rgba(var(--cta-tq-rgb),.4);transition:box-shadow var(--t-base);
}
.hero__circle-cta:hover{scale:1.08}
.hero__circle-cta:hover::before{box-shadow:0 12px 40px rgba(var(--cta-tq-rgb),.55)}
.hero__circle-cta:hover .hero__circle-vec{animation-duration:12s}

.hero__circle-vec{position:absolute;inset:0;width:100%;aspect-ratio:1;margin:auto;animation:circleRotate 25s linear infinite}
.hero__circle-ring{width:100%;height:100%}
.hero__circle-ring circle{stroke:rgba(255,255,255,.85)}

.hero__circle-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center}
.hero__circle-icon{font-size:1.7rem;margin-top:4px;opacity:.8}
.hero__circle-label{font-size:1.8rem;font-weight:700;letter-spacing:.04em;line-height:1.3}
.hero__circle-tel{font-family:var(--f-head);font-size:1.15rem;font-weight:700;letter-spacing:.03em;line-height:1.2}

.hero__news-banner{
  position:relative;z-index:3;margin:var(--sp-lg) var(--sp-lg) 0;max-width:100%;
  background:var(--c-white);border-radius:var(--r-lg);border:1px solid var(--c-border);
  box-shadow:var(--sh-md);overflow:hidden;
}
.hero__news-banner__head{
  margin:0;padding:var(--sp-sm) var(--sp-lg);
  font-family:var(--f-head);font-size:1.2rem;font-weight:700;
  color:var(--c-white);letter-spacing:.04em;background:var(--c-accent);line-height:1.45;
}
.hero__news-banner__head-stat{font-size:1.12em;font-weight:700;letter-spacing:.02em}
.hero__news-banner__body{padding:var(--sp-md) var(--sp-lg)}
.hero__news-banner__link{display:inline-block;font-weight:700;font-size:.88rem;color:var(--c-accent);text-decoration:underline;text-underline-offset:3px}
.hero__news-banner__link:hover{color:var(--c-accent-d)}

/* ============================================================
   USER-TYPE NAVIGATION
   ============================================================ */
.user-nav{padding:var(--sp-md) 0 var(--sp-2xl);background:transparent;position:relative;z-index:10;margin-top:-60px}
.user-nav__grid{display:grid;grid-template-columns:1fr;gap:var(--sp-md)}
.user-nav__card{display:flex;align-items:center;gap:var(--sp-lg);padding:var(--sp-lg);cursor:pointer;border-left:4px solid transparent}
.user-nav__card--admin{border-left-color:#3B82F6}
.user-nav__card--family{border-left-color:#10B981}
.user-nav__card--visit{border-left-color:#F59E0B}
.user-nav__card--inquiry{border-left-color:#EF4444}

.user-nav__card-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:var(--r-lg);font-size:1.8rem;transition:all var(--t-base)}
.user-nav__card--admin .user-nav__card-icon{background:#EFF6FF;color:#3B82F6}
.user-nav__card--family .user-nav__card-icon{background:#ECFDF5;color:#10B981}
.user-nav__card--visit .user-nav__card-icon{background:#FFFBEB;color:#F59E0B}
.user-nav__card--inquiry .user-nav__card-icon{background:#FEF2F2;color:#EF4444}
.user-nav__card:hover .user-nav__card-icon{transform:scale(1.08)}

.user-nav__card-label{font-size:.88rem;color:var(--c-text-m);margin-bottom:2px}
.user-nav__card-title{font-family:var(--f-head);font-size:1.15rem;font-weight:700;color:var(--c-primary);margin-bottom:var(--sp-xs)}
.user-nav__card-link{font-size:.92rem;font-weight:700;color:var(--c-accent);display:flex;align-items:center;gap:var(--sp-xs)}
.user-nav__card-link i{font-size:.75rem;transition:transform var(--t-base)}
.user-nav__card:hover .user-nav__card-link i{transform:translateX(4px)}

/* ============================================================
   NEWS
   ============================================================ */
.news{padding:var(--sp-3xl) 0;background:var(--c-bg)}
.news__header{margin-bottom:var(--sp-lg)}
.news__tabs{
  display:flex;gap:var(--sp-xs);margin-bottom:var(--sp-xl);
  border-bottom:2px solid var(--c-border);padding-bottom:0;
  overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;
}
.news__tab{
  padding:var(--sp-sm) var(--sp-lg);font-size:.82rem;font-weight:700;
  color:var(--c-text-m);border:none;background:none;cursor:pointer;
  white-space:nowrap;position:relative;transition:color var(--t-fast);
  border-bottom:3px solid transparent;margin-bottom:-2px;
}
.news__tab:hover{color:var(--c-accent)}
.news__tab.is-active{color:var(--c-accent);border-bottom-color:var(--c-accent)}
.news__list{display:flex;flex-direction:column}
.news__item{
  display:flex;flex-wrap:wrap;align-items:baseline;gap:var(--sp-sm) var(--sp-md);
  padding:var(--sp-md) 0;border-bottom:1px solid var(--c-border);transition:background var(--t-fast);
}
.news__item:first-child{border-top:1px solid var(--c-border)}
.news__item.is-hidden{display:none}
.news__date{font-family:var(--f-accent);font-size:.82rem;color:var(--c-text-m);white-space:nowrap}
.news__text{font-size:.88rem;color:var(--c-text);flex:1 1 100%}

/* ============================================================
   STRENGTHS
   ============================================================ */
.strengths{
  padding:var(--sp-3xl) 0;position:relative;
  background:url('/userfiles/page_contents/strengths.png') center/cover no-repeat;
}
.strengths::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.45)}
.strengths>.container{position:relative;z-index:1}
.strengths .section-header__label{color:rgba(255,255,255,.7)}
.strengths .section-title{color:var(--c-white)}
.strengths .text-accent{color:var(--c-accent-l)}
.strengths__grid{display:grid;grid-template-columns:1fr;gap:var(--sp-lg)}

.strength-card{padding:var(--sp-xl) var(--sp-lg);text-align:center;background:rgba(255,255,255,.85);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.strength-card__icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:64px;height:64px;background:var(--c-accent-l);color:var(--c-accent);
  font-size:1.6rem;border-radius:50%;margin-bottom:var(--sp-md);transition:all var(--t-base);
}
.card:hover .strength-card__icon{background:var(--c-accent);color:var(--c-white)}
.strength-card__badge{font-family:var(--f-accent);font-size:.7rem;font-weight:400;color:var(--c-accent);letter-spacing:.1em;margin-bottom:var(--sp-sm)}
.strength-card__title{font-family:var(--f-head);font-size:1.05rem;font-weight:700;color:var(--c-primary);margin-bottom:var(--sp-xs);line-height:1.5}
.strength-card__subtitle{font-size:.78rem;color:var(--c-accent);font-weight:500;margin-bottom:var(--sp-md)}
.strength-card__text{font-size:.85rem;color:var(--c-text-m);line-height:1.8;margin-bottom:var(--sp-md);text-align:left}
.strength-card__points{text-align:left}
.strength-card__points li{display:flex;align-items:center;gap:var(--sp-sm);font-size:.82rem;color:var(--c-primary);font-weight:500;padding:3px 0}
.strength-card__points i{color:var(--c-ok);font-size:.7rem}

/* ============================================================
   ABOUT BRIEF
   ============================================================ */
.about-brief{padding:var(--sp-3xl) 0;background:var(--c-bg)}
.about-brief__inner{display:flex;flex-direction:column;gap:var(--sp-2xl)}
.about-brief__text{font-size:.95rem;color:var(--c-text);line-height:2;margin-bottom:var(--sp-xl)}
.about-brief__photo-frame{margin:0;width:100%;aspect-ratio:4/3;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-md)}
.about-brief__photo{width:100%;height:100%;object-fit:cover;display:block}

/* ============================================================
   LIFE PREVIEW
   ============================================================ */
.life-preview{padding:var(--sp-3xl) 0;background:var(--c-warm, var(--c-surface))}
.life-preview__grid{display:grid;grid-template-columns:1fr;gap:var(--sp-lg)}
.life-preview__card{display:flex;flex-direction:column;overflow:hidden}
.life-preview__img-area{
  aspect-ratio:3/2;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:var(--sp-sm);
  background:linear-gradient(135deg,var(--c-accent-l),#D6E4FF);
  color:var(--c-accent);font-size:.85rem;transition:all var(--t-base);
}
.life-preview__img-area i{font-size:2.5rem;opacity:.4}
.life-preview__card:hover .life-preview__img-area{background:var(--c-accent);color:var(--c-white)}
.life-preview__card:hover .life-preview__img-area i{opacity:.7}
.life-preview__img-area--photo{padding:0;background:none;position:relative;display:block;overflow:hidden}
.life-preview__img-area--photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.life-preview__card:hover .life-preview__img-area--photo{filter:brightness(1.03)}
.life-preview__card-body{padding:var(--sp-lg)}
.life-preview__card-title{font-family:var(--f-head);font-size:1.05rem;font-weight:700;color:var(--c-primary);margin-bottom:var(--sp-sm)}
.life-preview__card-text{font-size:.85rem;color:var(--c-text-m);line-height:1.8}
.life-preview__action{text-align:center;margin-top:var(--sp-xl)}

/* ============================================================
   CONTENT NAVIGATION
   ============================================================ */
.content-nav{padding:var(--sp-3xl) 0;background:var(--c-surface)}
.content-nav__grid{display:grid;grid-template-columns:1fr;gap:var(--sp-lg)}
.content-nav__card{display:flex;flex-direction:row;align-items:stretch;cursor:pointer;overflow:hidden}
.content-nav__card-img{
  flex:0 0 90px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--c-accent-l),#D6E4FF);
  color:var(--c-accent);font-size:1.5rem;transition:all var(--t-base);
}
.content-nav__card:hover .content-nav__card-img{background:var(--c-accent);color:var(--c-white)}
.content-nav__card-body{padding:var(--sp-md) var(--sp-lg);flex:1;display:flex;flex-direction:column;justify-content:center}
.content-nav__card-title{font-family:var(--f-head);font-size:1rem;font-weight:700;color:var(--c-primary);margin-bottom:var(--sp-xs)}
.content-nav__card-text{font-size:.8rem;color:var(--c-text-m);line-height:1.6;margin-bottom:var(--sp-sm);flex-grow:1}
.content-nav__card-link{font-size:.78rem;font-weight:700;color:var(--c-accent);display:flex;align-items:center;gap:var(--sp-xs)}
.content-nav__card-link i{font-size:.6rem;transition:transform var(--t-base)}
.content-nav__card:hover .content-nav__card-link i{transform:translateX(4px)}

/* ============================================================
   TOPICS
   ============================================================ */
.topics{padding:var(--sp-3xl) 0;background:var(--c-bg)}
.topics__grid{display:grid;grid-template-columns:1fr;gap:var(--sp-lg)}
.topics__card{display:flex;align-items:center;gap:var(--sp-lg);padding:var(--sp-lg) var(--sp-xl);cursor:pointer;border-left:4px solid var(--c-accent)}
.topics__card-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--c-accent-l);color:var(--c-accent);font-size:1.5rem;border-radius:50%;transition:all var(--t-base)}
.topics__card:hover .topics__card-icon{background:var(--c-accent);color:var(--c-white)}
.topics__card-body{flex:1}
.topics__card-title{font-family:var(--f-head);font-size:1.05rem;font-weight:700;color:var(--c-primary);margin-bottom:var(--sp-xs)}
.topics__card-text{font-size:.85rem;color:var(--c-text-m);line-height:1.7;margin-bottom:var(--sp-sm)}
.topics__card-link{display:inline-flex;align-items:center;gap:var(--sp-xs);font-size:.85rem;font-weight:700;color:var(--c-accent)}
.topics__card-link i{color:#E74C3C;font-size:1rem}
.topics__external{margin-top:var(--sp-lg);font-size:.82rem;color:var(--c-text-m);display:flex;align-items:center;gap:var(--sp-sm)}
.topics__external i{font-size:.7rem;color:var(--c-accent)}
.topics__external a{color:var(--c-accent);font-weight:500;transition:opacity var(--t-fast)}
.topics__external a:hover{opacity:.7}

/* ============================================================
   ANIMATIONS (top)
   ============================================================ */
.hero__title-line,.hero__subtitle{opacity:0;transform:translateY(30px)}
.hero__circle-cta{opacity:0;transform:translateY(2rem)}
.hero__news-banner{opacity:0;transform:translateY(18px)}
.news__item{opacity:0;transform:translateX(-16px)}
.about-brief__content{opacity:0;transform:translateX(-24px)}
.about-brief__visual{opacity:0;transform:translateX(24px)}

@keyframes circleRotate{to{transform:rotate(-360deg)}}
@keyframes circleGlow{
  0%,100%{box-shadow:0 8px 32px rgba(255,159,67,.4)}
  50%{box-shadow:0 8px 32px rgba(255,159,67,.4), 0 0 0 14px rgba(255,159,67,.12)}
}
.hero__circle-cta::before{animation:circleGlow 3s ease-in-out infinite}

@keyframes iconPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(88,135,255,.25)}
  50%{box-shadow:0 0 0 10px rgba(88,135,255,0)}
}
.card:hover .strength-card__icon{animation:iconPulse 1.4s ease infinite}

/* ============================================================
   RESPONSIVE (top)
   ============================================================ */
@media(max-width:767px){
  .hero__circle-cta{display:none !important}
}

@media(min-width:768px){
  .hero{padding:var(--sp-3xl) 0 calc(var(--sp-4xl) + 50px);min-height:780px}
  .hero__title-line{font-size:2.25rem}
  .hero__slideshow-overlay{
    background:linear-gradient(120deg,rgba(var(--c-primary-rgb),.5) 0%,rgba(var(--c-primary-rgb),.3) 40%,rgba(var(--c-primary-rgb),.15) 100%);
  }
  .hero__inner{flex-direction:row;align-items:flex-start;gap:var(--sp-2xl)}
  .hero__content{flex:1}
  .hero__circle-cta{width:190px;right:var(--sp-xl);top:calc(50% - 95px)}
  .hero__news-banner{position:absolute;top:490px;right:var(--sp-xl);left:auto;bottom:auto;width:min(360px,42vw);margin:0}
  .hero__circle-label{font-size:.85rem}
  .hero__circle-tel{font-size:1.3rem}

  .user-nav{margin-top:-70px}
  .user-nav__grid{grid-template-columns:1fr 1fr;gap:var(--sp-md)}
  .strengths__grid{grid-template-columns:repeat(3,1fr);gap:var(--sp-lg)}
  .about-brief__inner{flex-direction:row;align-items:center;gap:var(--sp-3xl)}
  .about-brief__content{flex:1}
  .about-brief__visual{flex:0 0 42%}
  .content-nav__grid{grid-template-columns:1fr 1fr;gap:var(--sp-lg)}
  .news__text{flex:1 1 0}
  .life-preview__grid{grid-template-columns:1fr 1fr}
  .topics__grid{grid-template-columns:1fr}
}

@media(min-width:1024px){
  .hero{padding:var(--sp-4xl) 0 calc(var(--sp-4xl) + 60px);min-height:800px}
  .hero__title-line{font-size:2.75rem}
  .hero__slideshow-overlay{
    background:linear-gradient(110deg,rgba(var(--c-primary-rgb),.45) 0%,rgba(var(--c-primary-rgb),.25) 35%,rgba(var(--c-primary-rgb),.1) 100%);
  }
  .hero__circle-cta{width:220px;right:calc((100% - 1200px)/2 + var(--sp-xl));top:calc(50% - 110px)}
  .hero__news-banner{top:490px;right:calc((100% - 1200px)/2 + var(--sp-xl));width:min(380px,36vw)}
  .hero__circle-icon{font-size:1.1rem}
  .hero__circle-label{font-size:.9rem}
  .hero__circle-tel{font-size:1.5rem}

  .user-nav{margin-top:-80px}
  .user-nav__grid{grid-template-columns:repeat(4,1fr)}
  .user-nav__card{flex-direction:column;text-align:center;padding:var(--sp-xl) var(--sp-lg);border-left:none;border-top:4px solid transparent}
  .user-nav__card--admin{border-top-color:#3B82F6;border-left-color:transparent}
  .user-nav__card--family{border-top-color:#10B981;border-left-color:transparent}
  .user-nav__card--visit{border-top-color:#F59E0B;border-left-color:transparent}
  .user-nav__card--inquiry{border-top-color:#EF4444;border-left-color:transparent}
  .user-nav__card-icon{margin-bottom:var(--sp-sm)}
  .user-nav__card-link{justify-content:center}

  .content-nav__grid{grid-template-columns:repeat(4,1fr)}
  .content-nav__card{flex-direction:column}
  .content-nav__card-img{flex:none;height:100px;width:100%}
}

@media(min-width:1280px){
  .hero__title-line{font-size:3rem}
  .hero__circle-cta{width:240px;right:calc((100% - 1200px)/2 + var(--sp-2xl));top:calc(50% - 120px)}
  .hero__news-banner{top:490px;right:calc((100% - 1200px)/2 + var(--sp-2xl));width:min(380px,32vw)}
  .hero__circle-icon{font-size:1.8em}
  .hero__circle-label{font-size:1.8rem}
  .hero__circle-tel{font-size:1.6rem}
}

@media(prefers-reduced-motion:reduce){
  .hero__title-line,.hero__subtitle,
  .hero__circle-cta,.hero__news-banner,
  .news__item,
  .about-brief__content,.about-brief__visual{
    opacity:1 !important;transform:none !important;
  }
}
