/* =========================================================
   시애틀 시온장로교회 — 공용 스타일 (v11 디자인 이식)
   색: 태평양 북서부 틸(teal) + 따뜻한 오렌지 강조
   폰트: 제목 Nanum Myeongjo / 본문 Pretendard
   모든 페이지(index·worship·staff·pastor·404)가 공유
   ========================================================= */

:root{
  --night:#0F3A40; --night-2:#16545C; --mid:#1C7681; --soft:#5E7E7C;
  --teal:#2492A0; --teal-2:#2BA9B7; --teal-d:#1C7682; --mint:#86CDD4;
  --gold:#E87A2C; --gold-l:#F59B4E;
  --ivory:#F1F4F2; --paper:#E3EAE7; --ink:#143230;
  --line:rgba(20,50,48,.12); --line-2:rgba(20,50,48,.2);
  --serif:'Nanum Myeongjo',serif;
  --sans:'Pretendard','Pretendard Variable',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --wrap:1100px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--ivory);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;word-break:keep-all;overflow-wrap:break-word}
img{max-width:100%;display:block}
a{color:inherit}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 30px}

.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--teal-d);margin-bottom:18px}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--gold)}

/* reveal: JS가 켜져 있을 때만 숨겼다가 등장 (no-JS면 항상 보임) */
.reveal{opacity:1;transform:none;transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
html.js .reveal{opacity:0;transform:translateY(24px)}
html.js .reveal.in{opacity:1;transform:none}

h2.t{font-family:var(--serif);font-weight:800;font-size:clamp(28px,4.4vw,44px);line-height:1.2;letter-spacing:-.015em}
.intro{font-size:16px;opacity:.74;margin-top:14px;max-width:540px}

@keyframes riseIn{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes floatOrb{0%,100%{transform:translate(0,0)}50%{transform:translate(-18px,22px)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fall{0%{transform:translateY(-3px);opacity:.3}50%{opacity:1}100%{transform:translateY(5px);opacity:.2}}
@keyframes gust{0%,100%{transform:translateX(-2px)}50%{transform:translateX(3px)}}
@keyframes drift{0%,100%{transform:translateX(-2px)}50%{transform:translateX(2px)}}
@keyframes orbFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

.slot{position:relative;background:repeating-linear-gradient(135deg,#DBE8E9,#DBE8E9 16px,#E2EDEE 16px,#E2EDEE 32px);border:1px solid var(--line-2);border-radius:18px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;color:var(--soft);overflow:hidden}
.slot svg{width:38px;height:38px;opacity:.85}.slot span{font-size:12.5px}
.slot.dark{background:repeating-linear-gradient(135deg,#123E44,#123E44 16px,#16484F 16px,#16484F 32px);border-color:rgba(255,255,255,.12);color:var(--mint)}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:40;background:rgba(15,58,64,.93);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.08)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{font-family:var(--serif);font-weight:700;font-size:18px;letter-spacing:.02em;color:var(--ivory);text-decoration:none}
.nav-links{display:flex;align-items:center;gap:26px;font-size:14.5px;color:#C8DEDF}
.nav-links a{text-decoration:none;opacity:.8;position:relative;transition:opacity .2s}
.nav-links a:not(.nav-give)::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--gold);transition:width .25s}
.nav-links a:not(.nav-give):hover{opacity:1}.nav-links a:not(.nav-give):hover::after{width:100%}
.nav-links a[aria-current="page"]:not(.nav-give){opacity:1}
.nav-links a[aria-current="page"]:not(.nav-give)::after{width:100%}
.nav-give{color:var(--night)!important;opacity:1!important;font-weight:600;background:var(--gold);padding:8px 17px;border-radius:999px;transition:transform .2s,background .2s}
.nav-give:hover{background:var(--gold-l);transform:translateY(-1px)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--ivory)}

/* ---------- hero ---------- */
.hero{background:var(--night);color:var(--ivory);padding:74px 0 82px;position:relative;overflow:hidden}
.hero-orb{position:absolute;width:440px;height:440px;border-radius:50%;background:radial-gradient(circle at 40% 40%,rgba(43,169,183,.45),rgba(149,158,37,.2) 55%,transparent 72%);top:-110px;right:-60px;filter:blur(8px);animation:floatOrb 12s ease-in-out infinite;pointer-events:none}
.hero .grid{display:grid;grid-template-columns:1.08fr .92fr;gap:54px;align-items:center;position:relative;z-index:1}
.hero h1{font-family:var(--serif);font-weight:800;font-size:clamp(38px,6.4vw,64px);line-height:1.14;letter-spacing:-.02em}
.hero h1 span{display:block;opacity:0;animation:riseIn .85s cubic-bezier(.2,.7,.2,1) forwards}
.hero h1 span:nth-child(1){animation-delay:.1s}.hero h1 span:nth-child(2){animation-delay:.26s}.hero h1 span:nth-child(3){animation-delay:.42s}
.hero h1 em{font-style:normal;color:var(--gold-l)}
.hero .eyebrow{color:#A6DBE0}
.hero .lead{font-size:17px;color:#B6D2D2;margin-top:26px;max-width:430px;line-height:1.65;opacity:0;animation:riseIn .8s ease .6s forwards}
.cta-row{display:flex;flex-wrap:wrap;gap:13px;margin-top:34px;opacity:0;animation:riseIn .8s ease .78s forwards}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-size:15px;font-weight:600;text-decoration:none;padding:14px 26px;border-radius:999px;cursor:pointer;transition:transform .18s,background .2s,border-color .2s;border:1px solid transparent}
.btn .ar{transition:transform .2s}.btn:hover .ar{transform:translateX(4px)}
.btn-teal{background:var(--teal);color:#fff}.btn-teal:hover{background:var(--teal-2);transform:translateY(-2px)}
.btn-line{background:transparent;border-color:rgba(255,255,255,.28);color:var(--ivory)}.btn-line:hover{background:rgba(255,255,255,.08);transform:translateY(-2px)}
.btn-dark{background:var(--night);color:var(--ivory)}.btn-dark:hover{background:var(--night-2);transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:var(--night)}.btn-gold:hover{background:var(--gold-l);transform:translateY(-2px)}
.badge{margin-top:30px;display:inline-flex;align-items:center;gap:9px;font-size:13.5px;color:#98C0C0;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);padding:9px 15px;border-radius:999px;opacity:0;animation:riseIn .8s ease .95s forwards}
.badge b{color:var(--gold-l);font-weight:600}
.hero .slot{aspect-ratio:4/5;min-height:360px;opacity:0;animation:riseIn .9s ease .5s forwards}

/* 인물 사진 클러스터 */
.photo-cluster{position:relative;height:430px;z-index:1;opacity:0;animation:riseIn .9s ease .5s forwards}
.pcard{position:absolute;cursor:pointer}
.pcard .pin{width:100%;height:100%;border-radius:50%;overflow:hidden;border:3px solid rgba(255,255,255,.5);box-shadow:0 14px 34px rgba(15,58,64,.4);background:repeating-linear-gradient(135deg,#16484F,#16484F 14px,#1A535A 14px,#1A535A 28px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--mint);transition:transform .25s}
.pcard .pin img{width:100%;height:100%;object-fit:cover}
.pcard .pin svg{width:30px;height:30px;opacity:.85}.pcard .pin span{font-size:11px}
.pcard:hover{z-index:6}.pcard:hover .pin{transform:translateY(-8px) scale(1.05);border-color:var(--gold-l)}
.bubble{position:absolute;left:50%;bottom:100%;transform:translate(-50%,6px);background:#fff;color:var(--ink);font-size:13px;font-weight:500;padding:8px 14px;border-radius:14px;white-space:nowrap;box-shadow:0 8px 20px rgba(15,58,64,.25);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;margin-bottom:12px;z-index:7}
.bubble::after{content:"";position:absolute;left:50%;top:100%;transform:translateX(-50%);border:7px solid transparent;border-top-color:#fff}
.pcard:hover .bubble{opacity:1;transform:translate(-50%,0)}
.pc1{width:152px;height:152px;top:18px;left:0;animation:floatA 5s ease-in-out infinite}
.pc2{width:188px;height:188px;top:118px;right:6px;animation:floatB 6.2s ease-in-out infinite}
.pc3{width:138px;height:138px;bottom:4px;left:64px;animation:floatC 5.5s ease-in-out infinite}
@keyframes floatA{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes floatB{0%,100%{transform:translateY(0)}50%{transform:translateY(13px)}}
@keyframes floatC{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* 히어로 사진 갤러리 (성도 사진 cross-fade) */
.hero-gallery{position:relative;height:440px;z-index:1;opacity:0;animation:riseIn .9s ease .5s forwards}
.gframe{position:absolute;border-radius:24px;overflow:hidden;box-shadow:0 30px 60px rgba(8,40,45,.5);border:1px solid rgba(255,255,255,.16)}
.gframe::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(8,40,45,.35));pointer-events:none}
.gframe img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.07);transition:opacity 1.3s ease,transform 7s ease}
.gframe img.active{opacity:1;transform:scale(1)}
.gframe-a{width:312px;height:392px;top:6px;right:0;animation:floatB 6.6s ease-in-out infinite}
.gframe-b{width:212px;height:176px;left:6px;bottom:8px;animation:floatA 5.4s ease-in-out infinite}

.block{padding:78px 0}
.light{background:var(--ivory)}
.two{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start}
.steps{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.step{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:20px;transition:transform .22s,box-shadow .22s}
.step:hover{transform:translateY(-5px);box-shadow:0 14px 30px rgba(20,50,48,.1)}
.step .n{font-family:var(--serif);font-weight:800;font-size:19px;color:var(--gold);margin-bottom:9px;display:inline-block;transition:transform .25s}
.step:hover .n{transform:scale(1.25) rotate(-6deg)}
.step h3{font-size:16px;font-weight:600;margin-bottom:6px}
.step p{font-size:13.5px;opacity:.66;line-height:1.5}
.step-inner{display:contents}
.info-card{background:var(--night);color:var(--ivory);border-radius:18px;padding:28px;font-size:14.5px}
.info-card h3{font-size:16px;font-weight:600;margin-bottom:16px;color:var(--gold-l)}
.info-row{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.info-row:last-of-type{border-bottom:none}.info-row span:first-child{color:#98C0C0}
.info-addr{margin-top:16px;font-size:14px;color:#B6D2D2;line-height:1.55}
.info-addr a{color:var(--gold-l);text-decoration:underline;text-underline-offset:3px}

/* ---------- giving band ---------- */
.give{background:#D86E1F}
.give .wrap{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;padding:46px 30px}
.give .gt{max-width:560px}
.give .ge{color:#7A3A10}.give .ge::before{background:var(--night)}
.give h2{font-family:var(--serif);font-weight:800;font-size:clamp(26px,3.6vw,36px);color:#fff;line-height:1.2}
.give p{font-size:14.5px;color:#FFF1E4;margin-top:12px;max-width:480px}
.give .note{font-size:12.5px;color:#FFE6D2;margin-top:12px;max-width:520px;opacity:.92}

/* ---------- 마음 날씨 ---------- */
.weather{background:var(--mid);color:var(--ivory)}
.weather .head{text-align:center;max-width:820px;margin:0 auto}
.liveweather{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:9px 17px;margin-bottom:20px;font-size:14px;color:var(--ivory)}
.liveweather svg{width:20px;height:20px;color:var(--gold-l)}
.liveweather b{font-weight:600;color:var(--gold-l)}
.liveweather .wx-load{opacity:.7}
.weather .eyebrow{color:var(--gold-l);justify-content:center}.weather .eyebrow::before{background:var(--gold-l)}
.weather h2{color:var(--ivory)}.weather .intro{color:#C4E1E1;margin:14px auto 0}
.moods{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin-top:42px}
.mood{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15);border-radius:18px;width:118px;height:118px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:11px;cursor:pointer;color:var(--ivory);font-family:var(--sans);font-size:14.5px;font-weight:500;transition:transform .2s,background .2s,border-color .2s}
.mood:hover{transform:translateY(-5px);background:rgba(255,255,255,.12)}
.mood.active{background:var(--gold);color:var(--night);border-color:var(--gold)}
/* 건드리지 않아도 가볍게 통통 튀는 idle 모션 (데스크톱) */
@keyframes moodBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@media(min-width:561px){
  .moods .mood{animation:moodBob 2.6s ease-in-out infinite}
  .moods .mood:nth-child(2){animation-delay:.16s}
  .moods .mood:nth-child(3){animation-delay:.32s}
  .moods .mood:nth-child(4){animation-delay:.48s}
  .moods .mood:nth-child(5){animation-delay:.64s}
  .mood:hover{animation:none}
}
.mood.active{animation:none}
.mood svg{width:34px;height:34px;transform-box:fill-box;transform-origin:center}
.mood[data-w="sun"]:hover svg,.mood[data-w="sun"].active svg{animation:spin 7s linear infinite}
.mood[data-w="cloud"]:hover svg,.mood[data-w="cloud"].active svg{animation:drift 3s ease-in-out infinite}
.mood[data-w="rain"]:hover .drops,.mood[data-w="rain"].active .drops{animation:fall 1s ease-in-out infinite}
.mood[data-w="fog"]:hover svg,.mood[data-w="fog"].active svg{animation:drift 2.6s ease-in-out infinite}
.mood[data-w="wind"]:hover .gust,.mood[data-w="wind"].active .gust{animation:gust 1.8s ease-in-out infinite}
.w-result{max-width:620px;margin:36px auto 0;background:var(--night);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:36px;text-align:center;opacity:0;transform:translateY(16px);transition:.45s cubic-bezier(.2,.7,.2,1);display:none}
.w-result.show{display:block;opacity:1;transform:none}
.w-result .verse{font-family:var(--serif);font-weight:700;font-size:clamp(21px,3vw,28px);line-height:1.5;color:var(--ivory);max-width:18em;margin:0 auto;word-break:keep-all;overflow-wrap:break-word;text-wrap:balance}
.w-result .ref{font-size:14px;color:var(--gold-l);margin-top:14px}
.w-result .more{margin-top:24px;display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:600;color:var(--ivory);text-decoration:none;border-bottom:1px solid var(--gold);padding-bottom:3px;transition:color .2s}
.w-result .more:hover{color:var(--gold-l)}

/* ---------- Google 리뷰 (가로 자동 스크롤 마퀴) ---------- */
.voices{background:#E4F0F1;padding:44px 0 48px;overflow:hidden}
.vhead{display:flex;align-items:center;justify-content:center;gap:11px}
.stars{color:#F2A03C;letter-spacing:3px;font-size:21px;line-height:1}
.stars.sm{font-size:14px;letter-spacing:2px;display:block;margin-bottom:9px}
.vlabel{font-size:14px;color:var(--soft);font-weight:600}
.marquee{margin-top:14px;padding:12px 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.marquee-track{display:flex;gap:16px;width:max-content;animation:marquee 44s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee .quote{flex:0 0 auto;width:336px;background:#fff;border:none;border-radius:20px;margin:0;padding:26px 26px 22px;box-shadow:none;transform:none;opacity:1;position:relative;overflow:hidden;transition:transform .25s}
.marquee .quote::before{content:"\201C";position:absolute;top:6px;right:20px;font-family:var(--serif);font-weight:700;font-size:60px;line-height:1;color:var(--teal);opacity:.1;pointer-events:none}
.marquee .quote:hover{transform:translateY(-5px)}
.marquee .quote .stars.sm{margin-bottom:13px}
.marquee .quote p{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;position:relative;color:var(--ink)}
.marquee .quote .who{margin-top:14px;color:var(--teal-d);font-weight:600}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(max-width:560px){.marquee .quote{width:280px}}
@media(prefers-reduced-motion:reduce){.marquee{overflow-x:auto}.marquee-track{animation:none}}

/* ---------- 설교 ---------- */
.sc-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start;margin-top:34px}
.sermon-embed{aspect-ratio:16/9;border-radius:16px;overflow:hidden;border:1px solid var(--line);background:#000;box-shadow:0 16px 40px rgba(15,58,64,.18)}
.sermon-embed iframe{width:100%;height:100%;border:0;display:block}
.sermon-date{font-size:13px;color:var(--teal-d);font-weight:500;margin-top:14px}
.sermon-title{font-family:var(--serif);font-size:18px;font-weight:700;margin-top:5px;line-height:1.4}
.more-card{display:flex;flex-direction:column;justify-content:center;gap:14px}
.more-card h3{font-family:var(--serif);font-weight:700;font-size:22px}
.more-card p{font-size:14.5px;opacity:.72;line-height:1.6}
.more-card .btn{align-self:flex-start}
.quote{background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:0 12px 12px 0;padding:16px 18px;transition:transform .2s}
.quote:hover{transform:translateX(5px)}
.quote p{font-size:14.5px;line-height:1.62}.quote .who{font-size:13px;color:var(--soft);margin-top:9px;font-weight:500}

/* ---------- eBook ---------- */
.ebook{display:grid;grid-template-columns:230px 1fr;gap:44px;align-items:center;margin-top:34px}
.ebook .cover{border-radius:12px;overflow:hidden;box-shadow:0 18px 40px rgba(15,58,64,.22);background:var(--paper);aspect-ratio:793/1024}
.ebook .cover img{width:100%;height:100%;object-fit:cover}
.ebook h3{font-family:var(--serif);font-size:24px;font-weight:800;margin-bottom:8px}
.ebook .sub{color:var(--soft);font-size:14.5px;margin-bottom:20px;line-height:1.6}
.ebook .howto{font-size:13px;color:var(--soft);line-height:1.7;margin-top:20px;background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:16px 18px}
.ebook .howto strong{color:var(--ink)}

/* ---------- 서브 페이지 헤더 ---------- */
.page-head{background:var(--night);color:var(--ivory);padding:70px 0 64px;position:relative;overflow:hidden}
.page-head .hero-orb{top:-140px;right:-80px}
.page-head .wrap{position:relative;z-index:1}
.page-head .eyebrow{color:var(--gold-l)}.page-head .eyebrow::before{background:var(--gold-l)}
.page-head h1{font-family:var(--serif);font-weight:800;font-size:clamp(30px,5vw,46px);letter-spacing:-.02em;line-height:1.2}
.page-head p{color:#B6D2D2;font-size:15.5px;margin-top:14px;max-width:560px}

/* ---------- 예배안내 (타임라인) ---------- */
.worship-schedule{max-width:720px;margin:0 auto;position:relative}
.ws-row{position:relative;display:grid;grid-template-columns:38px 1fr;align-items:center;padding:26px 4px;border-bottom:1px solid var(--line)}
.ws-row:last-child{border-bottom:none}
.ws-row::before{content:"";position:absolute;left:18px;top:0;bottom:0;width:2px;background:var(--line)}
.ws-row:first-child::before{top:50%}
.ws-row:last-child::before{bottom:50%}
.ws-dot{position:relative;z-index:1;justify-self:center;width:13px;height:13px;border-radius:50%;background:var(--ivory);border:2px solid var(--teal);transition:transform .35s cubic-bezier(.2,.7,.2,1),background .3s,border-color .3s,box-shadow .35s;animation:dotGlow 6.5s ease-in-out infinite}
.ws-row:nth-child(1) .ws-dot{animation-delay:0s}
.ws-row:nth-child(2) .ws-dot{animation-delay:.45s}
.ws-row:nth-child(3) .ws-dot{animation-delay:.9s}
.ws-row:nth-child(4) .ws-dot{animation-delay:1.35s}
.ws-row:hover .ws-dot{animation:none;background:var(--gold);border-color:var(--gold);transform:scale(1.35);box-shadow:0 0 0 7px rgba(232,122,44,.14)}
@keyframes dotGlow{0%,70%,100%{background:var(--ivory);border-color:var(--teal);box-shadow:0 0 0 0 rgba(232,122,44,0)}7%,20%{background:var(--gold);border-color:var(--gold);box-shadow:0 0 0 6px rgba(232,122,44,.16)}}
.ws-main{display:flex;align-items:baseline;justify-content:space-between;gap:14px;flex-wrap:wrap;transition:transform .35s cubic-bezier(.2,.7,.2,1)}
.ws-row:hover .ws-main{transform:translateX(6px)}
.ws-name{font-family:var(--serif);font-weight:800;font-size:21px;color:var(--ink);letter-spacing:-.01em}
.ws-meta{display:flex;align-items:baseline;gap:12px}
.ws-time{font-size:15px;color:var(--ink);font-weight:500}
.ws-place{font-size:12.5px;color:var(--soft);border:1px solid var(--line);padding:3px 11px;border-radius:999px}
/* 고급 staggered 등장 */
html.js .worship-schedule.reveal{opacity:0;transform:none}
html.js .worship-schedule.reveal.in{opacity:1}
html.js .worship-schedule .ws-row{opacity:0;transform:translateX(-24px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
html.js .worship-schedule.in .ws-row{opacity:1;transform:none}
.worship-schedule .ws-row:nth-child(1){transition-delay:.05s}
.worship-schedule .ws-row:nth-child(2){transition-delay:.18s}
.worship-schedule .ws-row:nth-child(3){transition-delay:.31s}
.worship-schedule .ws-row:nth-child(4){transition-delay:.44s}
@media(prefers-reduced-motion:reduce){html.js .worship-schedule .ws-row{opacity:1;transform:none;transition:none}}
.map-frame{width:100%;max-width:820px;margin:24px auto 0;aspect-ratio:16/9;border-radius:16px;overflow:hidden;border:1px solid var(--line);box-shadow:0 16px 40px rgba(15,58,64,.12)}
.map-frame iframe{width:100%;height:100%;border:0}

/* 줄바꿈 유틸 (모바일 전용) */
.br-m{display:none}

/* 대중교통 토글 (예배안내) */
.transit-toggle{max-width:820px;margin:44px auto 0}
.transit-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--night);border:1px solid var(--night);border-radius:14px;padding:17px 20px;cursor:pointer;font-family:var(--sans);font-size:15.5px;font-weight:600;color:var(--ivory);text-align:left;transition:background .2s,box-shadow .2s}
.transit-btn:hover{background:var(--night-2);box-shadow:0 12px 28px rgba(15,58,64,.22)}
.transit-q{line-height:1.35}
.transit-lead{display:inline-flex;align-items:center;gap:12px;min-width:0}
.transit-q svg{color:var(--ivory);flex:0 0 auto}
.transit-chevron{color:var(--ivory);flex:0 0 auto;display:inline-flex;transition:transform .35s cubic-bezier(.2,.7,.2,1)}
.transit-veh{display:inline-grid;align-items:center;flex:0 0 auto}
.transit-bus,.transit-rail{grid-area:1/1;display:inline-flex;color:var(--ivory);animation:vehiclePass 7s linear infinite}
.transit-bus svg,.transit-rail svg{display:block}
@keyframes vehiclePass{0%{transform:translateX(0);opacity:0}3%{opacity:1}44%{opacity:1}50%{transform:translateX(var(--bus-travel,48px));opacity:0}100%{transform:translateX(var(--bus-travel,48px));opacity:0}}
.transit-toggle.open .transit-btn{background:var(--night);border-bottom-left-radius:0;border-bottom-right-radius:0}
.transit-toggle.open .transit-chevron{transform:rotate(180deg)}
.transit-panel{max-height:0;overflow:hidden;transition:max-height .45s cubic-bezier(.2,.7,.2,1);background:#fff;border-radius:0 0 14px 14px}
.transit-toggle.open .transit-panel{max-height:680px;border:1px solid var(--line);border-top:none}
.transit-inner{padding:0 18px}
.transit-inner p,.transit-inner ul{margin:14px 0 0;font-size:14.5px;line-height:1.65;color:var(--ink)}
.transit-inner ul{list-style:none;display:flex;flex-direction:column;gap:10px;padding:0}
.transit-inner li{position:relative;padding-left:16px}
.transit-inner li::before{content:"";position:absolute;left:0;top:.6em;width:6px;height:6px;border-radius:50%;background:var(--gold)}
.transit-inner .transit-note{color:var(--soft);font-size:13.5px}
.transit-inner .btn{margin:16px 0 20px}

/* ---------- 프로필 (섬기는 이들) ---------- */
.profile{max-width:760px;margin:0 auto}
.profile-top{display:grid;grid-template-columns:220px 1fr;gap:40px;align-items:center}
.profile-photo{border-radius:16px;overflow:hidden;aspect-ratio:4/5;background:var(--paper);box-shadow:0 16px 40px rgba(15,58,64,.18)}
.profile-photo img{width:100%;height:100%;object-fit:cover}
.profile h2{font-family:var(--serif);font-size:26px;font-weight:800;color:var(--ink)}
.profile .role{color:var(--soft);margin:6px 0 20px;font-size:15px}
.cv{list-style:none;display:flex;flex-direction:column;gap:9px}
.cv li{padding-left:20px;position:relative;color:var(--ink);font-size:15px;line-height:1.55}
.cv li::before{content:"";position:absolute;left:0;top:.62em;width:7px;height:7px;border-radius:50%;background:var(--gold)}
.staff-team{max-width:760px;margin:56px auto 0;padding-top:48px;border-top:1px solid var(--line);text-align:center}
.staff-team h2{font-family:var(--serif);font-weight:800;font-size:26px;color:var(--ink);margin-bottom:26px}
.staff-photo{max-width:520px;margin:0 auto}
.staff-photo img{width:100%;height:auto;display:block}

/* ---------- 담임목사 인사말 ---------- */
.message{max-width:720px;margin:0 auto}
.message p{margin-bottom:1.05em;font-size:17px;line-height:1.8}
.message .accent{font-family:var(--serif);font-weight:700;color:var(--teal-d);font-size:18px}
.message .sign{text-align:right;font-family:var(--serif);font-weight:700;color:var(--ink);font-size:19px;margin-top:30px}
.message-photo{border-radius:18px;overflow:hidden;margin:0 auto 44px;max-width:560px;box-shadow:0 18px 44px rgba(15,58,64,.2)}

/* ---------- footer ---------- */
footer.site-footer{background:var(--night);color:#B6D2D2;padding:60px 0 38px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
.fb-name{font-family:var(--serif);font-weight:700;font-size:20px;color:var(--ivory)}
.foot-brand p{font-size:13.5px;opacity:.62;margin-top:11px;max-width:280px;line-height:1.6}
.socials{display:flex;gap:12px;margin-top:18px}
.socials a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(182,210,210,.22);display:flex;align-items:center;justify-content:center;opacity:.74;transition:.2s}
.socials a:hover{opacity:1;background:rgba(36,146,160,.18);border-color:var(--teal);transform:translateY(-2px)}.socials svg{width:18px;height:18px}
.foot-col h4{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-l);margin-bottom:14px;font-weight:600}
.foot-col a,.foot-col p{display:block;font-size:13.5px;opacity:.8;text-decoration:none;margin-bottom:9px;line-height:1.5}
.foot-col a:hover{opacity:1}
.foot-base{border-top:1px solid rgba(182,210,210,.14);margin-top:42px;padding-top:24px;font-size:12px;opacity:.5;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
.foot-base .copy span:not(:first-child)::before{content:" · ";opacity:.6}

/* ---------- AI 안내자 오브 ---------- */
.orb{position:fixed;right:24px;bottom:24px;z-index:50;width:60px;height:60px;border-radius:50%;background:var(--teal);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 10px 30px rgba(15,58,64,.45);animation:orbFloat 4.5s ease-in-out infinite}
.orb:hover{background:var(--teal-2)}.orb svg{width:25px;height:25px}
.toast{position:fixed;right:24px;bottom:94px;z-index:51;background:var(--ivory);border:1px solid var(--line);border-radius:14px;padding:13px 16px;font-size:13px;max-width:235px;box-shadow:0 12px 28px rgba(15,58,64,.22);opacity:0;transform:translateY(8px);transition:.3s;pointer-events:none}
.toast.show{opacity:1;transform:none}.toast b{color:var(--teal-d)}

/* ---------- 문의 상담창 (처음 오시나요?) ---------- */
.chat-panel{position:fixed;right:24px;bottom:96px;z-index:60;width:362px;max-width:calc(100vw - 32px);height:544px;max-height:calc(100vh - 130px);background:var(--ivory);border:1px solid var(--line);border-radius:20px;box-shadow:0 24px 64px rgba(8,40,45,.34);display:flex;flex-direction:column;overflow:hidden;opacity:0;transform:translateY(16px) scale(.98);pointer-events:none;transition:opacity .28s,transform .28s}
.chat-panel.open{opacity:1;transform:none;pointer-events:auto}
.chat-head{background:var(--night);color:var(--ivory);padding:18px 20px;position:relative;flex-shrink:0}
.chat-head h2{font-family:var(--serif);font-weight:700;font-size:18px}
.chat-head p{font-size:12.5px;color:#B6D2D2;margin-top:3px}
.chat-close{position:absolute;top:14px;right:14px;background:rgba(255,255,255,.14);border:none;color:#fff;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:17px;line-height:1}
.chat-close:hover{background:rgba(255,255,255,.26)}
.chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;scroll-behavior:smooth}
.cmsg{max-width:88%;padding:11px 14px;font-size:14px;line-height:1.6;border-radius:16px;word-break:break-word}
.cmsg a{color:var(--teal-d);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.cmsg.bot{align-self:flex-start;background:#fff;border:1px solid var(--line);color:var(--ink);border-bottom-left-radius:5px}
.cmsg.user{align-self:flex-end;background:var(--teal);color:#fff;border-bottom-right-radius:5px}
.chat-chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:4px}
.chat-chip{background:#fff;border:1px solid var(--line-2);color:var(--teal-d);font-family:var(--sans);font-size:12.5px;padding:7px 12px;border-radius:999px;cursor:pointer;transition:background .15s,border-color .15s;text-align:left}
.chat-chip:hover{background:var(--paper);border-color:var(--teal)}
.chat-foot{border-top:1px solid var(--line);padding:10px 12px;display:flex;gap:8px;align-items:flex-end;background:var(--ivory);flex-shrink:0}
.chat-foot textarea{flex:1;resize:none;border:1px solid var(--line-2);border-radius:13px;padding:9px 12px;font-family:var(--sans);font-size:14px;color:var(--ink);background:#fff;max-height:80px;line-height:1.4;outline:none}
.chat-foot textarea:focus{border-color:var(--teal)}
.chat-send{background:var(--teal);border:none;width:40px;height:40px;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;transition:background .2s}
.chat-send:hover{background:var(--teal-2)}.chat-send svg{width:18px;height:18px}
.chat-disclaimer{font-size:10.5px;color:var(--soft);text-align:center;padding:0 12px 9px}
@media(max-width:560px){.chat-panel{right:10px;left:10px;width:auto;bottom:88px;height:72vh}}

/* ---------- 반응형 ---------- */
@media (max-width:840px){
  .hero .grid,.two,.sc-grid,.profile-top,.ebook{grid-template-columns:1fr;gap:30px}
  .hero .slot{aspect-ratio:16/10;min-height:0}
  .photo-cluster{height:auto;display:flex;justify-content:center;gap:14px;flex-wrap:wrap;padding:8px 0}
  .pcard{position:static!important;animation:none}
  .pc1,.pc2,.pc3{width:120px;height:120px}
  .hero-gallery{height:auto;display:flex;justify-content:center;padding:6px 0}
  .gframe{position:static;animation:none}
  .gframe-a{width:100%;max-width:420px;height:clamp(220px,56vw,300px)}
  .gframe-b{display:none}
  .ebook{justify-items:center;text-align:center}
  .ebook .cover{max-width:210px}
  .ebook .howto{text-align:left}
  .profile-top{justify-items:center;text-align:center}
  .profile-photo{max-width:220px}.cv li{text-align:left}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .nav-links{position:absolute;top:66px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--night);border-bottom:1px solid rgba(255,255,255,.08);padding:8px 0;display:none}
  .nav-links.open{display:flex}
  .nav-links a{padding:13px 30px}
  .nav-links a:not(.nav-give)::after{display:none}
  .nav-give{margin:8px 30px 4px;text-align:center}
  .nav-toggle{display:block}
  .block,.hero{padding:54px 0}
  /* 처음 오시는 분 4단계 — 모바일: 2×2 정사각 플립 카드 (탭하면 뒤집힘) */
  .steps{grid-template-columns:1fr 1fr;gap:11px}
  .step{background:transparent;border:none;padding:0;aspect-ratio:7/5;perspective:900px;cursor:pointer}
  .step:hover{transform:none;box-shadow:none}
  .step-inner{display:block;position:relative;width:100%;height:100%;transition:transform .55s cubic-bezier(.2,.7,.2,1);transform-style:preserve-3d}
  .step.flipped .step-inner{transform:rotateY(180deg)}
  .step-front,.step-back{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:7px;padding:14px;border-radius:16px;-webkit-backface-visibility:hidden;backface-visibility:hidden}
  .step-front{background:var(--paper);border:1px solid var(--line)}
  .step-front .n{margin:0;font-size:27px}
  .step-front h3{margin:0;font-size:15.5px}
  .step:hover .n{transform:none}
  .step-back{background:var(--night);border:1px solid var(--night);transform:rotateY(180deg)}
  .step-back p{margin:0;color:#DCEBE9;opacity:1;font-size:12.5px;line-height:1.55}
  .step-front::after{content:"↻";position:absolute;bottom:8px;right:10px;font-size:12px;color:var(--soft);opacity:.55}
  /* 예배시간 카드 — 라벨/값 세로로 쌓아 안정적으로 */
  .info-row{flex-direction:column;align-items:flex-start;gap:2px}
  .info-row span:first-child{font-size:13px}
  /* 예배안내 타임라인 — 이름/시간을 세로로 */
  .ws-main{flex-direction:column;align-items:flex-start;gap:6px}
  /* 마음 날씨 아이콘 — 모바일: 한 줄 가로 스크롤(드래그/스와이프) + 자동 흐름 */
  .moods{flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;overflow-y:hidden;gap:10px;margin-top:18px;padding:12px 2px 10px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .moods::-webkit-scrollbar{display:none}
  .mood{width:94px;height:94px;flex:0 0 auto}
  .foot-grid{grid-template-columns:1fr}
  .give .wrap{padding:40px 24px}
  .br-m{display:inline}
  /* 모바일: 히어로 햇빛 효과 축소해 'SEATTLE · SHORELINE' 가독성 확보 */
  .hero-orb{width:240px;height:240px;top:-100px;right:-90px;opacity:.55}
  /* 모바일: 저작권 가운데 정렬 3줄 */
  .foot-base{justify-content:center;text-align:center}
  .foot-base .copy span{display:block}
  .foot-base .copy span:not(:first-child)::before{content:none}
}

/* ---------- 접근성 ---------- */
a:focus-visible,.btn:focus-visible,button:focus-visible{outline:3px solid var(--gold-l);outline-offset:3px;border-radius:8px}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important}
  .reveal,html.js .reveal{transition:none;opacity:1;transform:none}
  .hero h1 span,.hero .lead,.cta-row,.badge,.hero .slot,.photo-cluster{opacity:1}
}
