:root{--bg:#140d1f;--bg-sub:#1c1428;--surface:#251b35;--surface-hover:#2f2540;--border:#3d2f52;--text:#f7f0e8;--text-sub:#c4b8a8;--text-dim:#8a7d8f;--primary:#d4a574;--primary-lt:#f0cfa3;--primary-bg:#342840;--seal:#b83d3d;--seal-dk:#7a2525;--gold-line:rgba(212,165,116,.55);--pink:#e8a0b8;--pink-bg:#2a1f30;--mint:#5cb89a;--mint-bg:#1a2a26;--max-w:520px;--radius:14px;--font-display:'Gowun Batang',serif;--sh-sm:0 2px 12px rgba(0,0,0,.35);--sh-md:0 10px 32px rgba(0,0,0,.45);--sh-lg:0 16px 48px rgba(0,0,0,.5)}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
/* html에 배경: 모바일(iOS)에서 body 단독 배경이 안 보이는 경우 대비 */
html{min-height:100%;min-height:100dvh;background-color:var(--bg);background-image:url('../images/background.png');background-position:center center;background-repeat:no-repeat;-webkit-background-size:cover;background-size:cover;background-attachment:scroll}
@media (min-width:769px){html{background-attachment:fixed}}
body{font-family:'IBM Plex Sans KR',-apple-system,sans-serif;background:transparent;color:var(--text);min-height:100%;min-height:100dvh;padding-bottom:env(safe-area-inset-bottom,0);position:relative}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;-webkit-transform:translateZ(0);transform:translateZ(0);background:radial-gradient(ellipse 90% 55% at 50% -10%,rgba(75,45,120,.28),transparent 52%),radial-gradient(ellipse 70% 40% at 110% 20%,rgba(184,61,61,.04),transparent 50%),radial-gradient(ellipse 50% 35% at -5% 85%,rgba(212,165,116,.04),transparent 45%),linear-gradient(165deg,rgba(26,16,40,.42) 0%,rgba(20,13,31,.48) 45%,rgba(14,10,22,.52) 100%)}
body::after{content:"";position:fixed;inset:0;pointer-events:none;opacity:.028;z-index:0;-webkit-transform:translateZ(0);transform:translateZ(0);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.app{position:relative;z-index:1}
a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}

/* 헤더 */
.header{position:sticky;top:0;z-index:100;background:rgba(20,13,31,.92);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);height:54px;display:flex;align-items:center;justify-content:center;padding:0 max(12px,env(safe-area-inset-right)) 0 max(12px,env(safe-area-inset-left));box-shadow:0 4px 28px rgba(0,0,0,.4),inset 0 -1px 0 rgba(212,165,116,.2)}
.header-inner{width:100%;max-width:var(--max-w);display:flex;align-items:center;justify-content:space-between}
.header-back{width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--primary-lt);border-radius:10px;transition:background .15s}
.header-back:hover{background:var(--surface-hover)}.header-back.invisible{visibility:hidden}
.logo{font-family:var(--font-display);font-size:20px;font-weight:700;letter-spacing:.12em;color:var(--primary-lt);cursor:pointer;text-shadow:0 0 24px rgba(212,165,116,.25)}
.logo span.seal-mark{color:var(--seal);letter-spacing:0;margin-right:2px;font-size:1.05em}
.header-spacer{width:38px}

.page{display:none}.page.active{display:block}
.main-wrap{max-width:var(--max-w);margin:0 auto;padding:12px max(12px,env(safe-area-inset-left)) 28px max(12px,env(safe-area-inset-right))}

/* 히어로 · 점집 인사 */
.main-hero{text-align:center;padding:18px 4px 14px}
.hero-ornament{display:flex;justify-content:center;margin-bottom:12px}
.hero-seal{width:48px;height:48px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#d64d4d,var(--seal-dk));border:3px solid var(--primary-lt);box-shadow:0 4px 16px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:22px;font-weight:700;color:#fff8e8;text-shadow:0 1px 2px rgba(0,0,0,.4)}
.hero-kicker{font-family:var(--font-display);font-size:12px;color:var(--primary);letter-spacing:.28em;text-indent:.28em;margin-bottom:10px;opacity:.92}
.main-hero h1{font-family:var(--font-display);font-size:clamp(21px,5.4vw,25px);font-weight:700;line-height:1.48;letter-spacing:.04em;color:var(--text);text-shadow:0 2px 20px rgba(0,0,0,.35)}
.main-hero h1 em{font-style:normal;color:var(--primary-lt)}
.main-hero p{color:var(--text-sub);font-size:13px;margin-top:10px;line-height:1.65;padding:0 8px;font-weight:500}

/* 저장된 사주 정보 (메인) */
.saved-profile-wrap{display:none;margin-bottom:8px}
.saved-profile-wrap.has-profile{display:block}
.saved-profile-card{background:linear-gradient(165deg,rgba(46,38,64,.92),rgba(28,22,42,.95));border:1px solid var(--gold-line);border-radius:var(--radius);box-shadow:var(--sh-sm),inset 0 1px 0 rgba(212,165,116,.1);overflow:hidden}
.saved-profile-bar{display:flex;align-items:center;gap:6px;padding:8px 10px 8px 12px;min-height:44px}
.saved-profile-toggle{flex:1;display:flex;align-items:center;gap:10px;background:transparent;border:none;color:var(--text);text-align:left;cursor:pointer;padding:4px 0;touch-action:manipulation;min-width:0}
.saved-profile-chev{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--primary-lt);font-size:10px;line-height:1;transition:transform .22s ease;border-radius:6px;background:rgba(212,165,116,.12)}
.saved-profile-card.is-collapsed .saved-profile-chev{transform:rotate(-90deg)}
.saved-profile-sum{font-size:13px;line-height:1.35;min-width:0}
.saved-profile-sum strong{color:var(--primary-lt);font-weight:700}
.saved-profile-sum-sub{color:var(--text-dim);font-weight:500}
.saved-profile-edit-compact{flex-shrink:0;font-size:12px;font-weight:600;color:var(--text-dim);padding:8px 6px;text-decoration:underline;text-underline-offset:3px;touch-action:manipulation;background:transparent;border:none;cursor:pointer}
.saved-profile-edit-compact:active{color:var(--primary-lt)}
.saved-profile-body{padding:2px 14px 12px 14px;border-top:1px dashed rgba(212,165,116,.18)}
.saved-profile-card.is-collapsed .saved-profile-body{display:none}
.saved-profile-card:not(.is-collapsed) .saved-profile-body{display:block}
.saved-profile-rows{display:flex;flex-direction:column;gap:2px}
.saved-profile-row{display:flex;justify-content:space-between;align-items:baseline;gap:14px;font-size:13px;padding:6px 0;border-bottom:1px solid rgba(61,47,82,.6)}
.saved-profile-row:last-of-type{border-bottom:none}
.saved-profile-row span{color:var(--text-dim);flex-shrink:0}
.saved-profile-row b{color:var(--text);font-weight:600;text-align:right;word-break:break-all}
.saved-profile-foot{font-size:10px;color:var(--text-dim);text-align:center;margin-top:12px;line-height:1.45;opacity:.88}

/* 카테고리 */
.cat-tabs{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding:0 0 14px;-webkit-overflow-scrolling:touch}
.cat-tabs::-webkit-scrollbar{display:none}
.cat-tab{flex-shrink:0;padding:7px 14px;border-radius:999px;font-size:12px;font-weight:600;background:var(--surface);color:var(--text-sub);border:1px solid var(--border);transition:all .2s;white-space:nowrap;box-shadow:var(--sh-sm)}
.cat-tab.active{background:linear-gradient(180deg,#3d2a28,#2a1f1e);color:var(--primary-lt);border-color:var(--gold-line);box-shadow:0 0 0 1px rgba(184,61,61,.25),0 6px 20px rgba(0,0,0,.35)}

/* 인기 캐러셀 · 부적 프레임 */
.featured-carousel{position:relative;border-radius:calc(var(--radius) + 2px);overflow:hidden;margin-bottom:18px;box-shadow:var(--sh-lg),0 0 0 1px var(--gold-line),0 0 0 4px rgba(30,20,45,.9);aspect-ratio:16/9;width:100%;max-height:min(46vw,292px)}
.featured-carousel::before{content:"";position:absolute;inset:0;z-index:4;pointer-events:none;border-radius:inherit;box-shadow:inset 0 0 40px rgba(0,0,0,.35);border:1px solid rgba(255,248,235,.06)}
.featured-slides{display:flex;height:100%;transition:transform .5s cubic-bezier(.25,.85,.35,1);will-change:transform}
.featured-slide{flex:0 0 100%;width:100%;height:100%;position:relative;cursor:pointer;min-height:0}
.featured-slide .featured-bg{position:absolute;inset:0;font-size:clamp(64px,20vw,100px);display:flex;align-items:center;justify-content:center;opacity:.22;filter:drop-shadow(0 8px 24px rgba(0,0,0,.15))}
.featured-slide .featured-content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:14px 14px 48px;background:linear-gradient(to top,rgba(20,12,40,.72) 0%,rgba(40,30,80,.25) 45%,transparent 72%)}
.featured-slide .featured-badge{display:inline-block;padding:5px 14px;border-radius:4px;font-size:10px;font-weight:800;letter-spacing:.2em;text-indent:.2em;font-family:var(--font-display);background:var(--seal-dk);color:#fde8dc;border:2px solid var(--primary-lt);margin-bottom:8px;width:fit-content;box-shadow:0 2px 14px rgba(0,0,0,.4)}
.featured-slide .featured-title{font-size:clamp(15px,4vw,18px);font-weight:800;color:#fff;line-height:1.35;margin-bottom:4px;text-shadow:0 2px 12px rgba(0,0,0,.25)}
.featured-slide .featured-sub{font-size:12px;color:rgba(255,255,255,.82);font-weight:500}
.featured-nav{position:absolute;right:8px;bottom:8px;display:flex;align-items:center;gap:2px;background:rgba(15,10,30,.5);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:4px 5px 4px 10px;border-radius:999px;z-index:6;border:1px solid rgba(255,255,255,.12)}
.featured-nav.hidden{display:none}
.feat-count{font-size:12px;font-weight:700;color:#fff;min-width:38px;text-align:center;letter-spacing:.02em;padding-right:4px}
.feat-btn{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.18);color:#fff;font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .15s;touch-action:manipulation}
.feat-btn:active{background:rgba(255,255,255,.35);transform:scale(.92)}
@media (hover:hover){.feat-btn:hover{background:rgba(255,255,255,.3)}}
.feat-bg-0{background:linear-gradient(155deg,#2d1f4a,#4a3570 40%,#6b4d8c)}
.feat-bg-1{background:linear-gradient(155deg,#4a2438,#6b3a4f 45%,#8f5568)}
.feat-bg-2{background:linear-gradient(155deg,#1e3050,#2d4a6e 50%,#3d5c7a)}
.feat-bg-3{background:linear-gradient(155deg,#1a3d38,#2a5a52 45%,#3d6b62)}
.feat-bg-4{background:linear-gradient(155deg,#4a3820,#6b5228 50%,#8b6a32)}
.feat-bg-5{background:linear-gradient(155deg,#3d2a50,#5c4080 48%,#7a5598)}
.feat-bg-6{background:linear-gradient(155deg,#2a3548,#3d4a62 50%,#506078)}
.feat-bg-7{background:linear-gradient(155deg,#243a45,#355a62 45%,#4a7568)}
.feat-bg-8{background:linear-gradient(155deg,#4a2828,#6b3835 50%,#8b4840)}

/* 광고 */
.ad-slot{width:100%;min-height:80px;background:linear-gradient(135deg,rgba(45,38,70,.6),rgba(30,26,46,.8));border:1px dashed var(--border);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--text-dim);font-size:12px;margin:16px 0}

.section-title{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--primary-lt);margin-bottom:12px;display:flex;align-items:center;gap:8px;letter-spacing:.08em}

/* 그리드 */
.test-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:24px}
.test-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:var(--sh-sm),inset 0 1px 0 rgba(212,165,116,.08);touch-action:manipulation;-webkit-touch-callout:none;position:relative}
.test-card::before{content:"";position:absolute;top:0;left:12%;right:12%;height:2px;background:linear-gradient(90deg,transparent,var(--primary),transparent);opacity:.65;z-index:0;pointer-events:none}
.test-card-thumb,.test-card-info{position:relative;z-index:1}
.test-card:active{transform:scale(.97)}
@media (hover:hover){.test-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}}
.test-card-thumb{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;font-size:clamp(44px,12vw,52px)}
.test-card-info{padding:10px 10px 12px}
.test-card-cat{font-size:11px;font-weight:600;color:var(--primary-lt);margin-bottom:3px}
.test-card-title{font-size:13px;font-weight:700;line-height:1.4;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.test-card-meta{display:flex;align-items:center;gap:8px;margin-top:6px;font-size:11px;color:var(--text-dim)}

.tc-bg-1{background:linear-gradient(135deg,#ffeef8,#f0eeff)}.tc-bg-2{background:linear-gradient(135deg,#eef6ff,#e8faf5)}.tc-bg-3{background:linear-gradient(135deg,#fff0f6,#ffeef8)}.tc-bg-4{background:linear-gradient(135deg,#e8faf5,#eef6ff)}.tc-bg-5{background:linear-gradient(135deg,#fff8e8,#ffeef8)}.tc-bg-6{background:linear-gradient(135deg,#f0eeff,#eef6ff)}

/* 테스트 페이지 */
.test-wrap{max-width:var(--max-w);margin:0 auto;padding:16px max(12px,env(safe-area-inset-left)) max(24px,env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-right));min-height:calc(100dvh - 54px);display:flex;flex-direction:column}
.test-intro{text-align:center;padding:32px 0 16px}
.test-intro-emoji{font-size:72px;margin-bottom:14px;animation:float 3s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.test-intro h2{font-family:var(--font-display);font-size:21px;font-weight:700;line-height:1.45;color:var(--text);margin-bottom:8px;letter-spacing:.04em}
.test-intro p{color:var(--text-sub);font-size:14px;line-height:1.6;margin-bottom:24px}
.test-meta-row{display:flex;justify-content:center;gap:16px;margin-bottom:28px;font-size:13px;color:var(--text-dim)}
.test-meta-row span{display:flex;align-items:center;gap:4px}

.btn-primary{width:100%;max-width:340px;padding:15px 18px;background:linear-gradient(180deg,#e8c896,#c4945c 45%,#a67c40);border-radius:12px;color:#1a0f0a;font-size:16px;font-weight:700;font-family:var(--font-display);letter-spacing:.12em;text-indent:.12em;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 0 #5c4020,0 8px 24px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.35);margin:0 auto;display:block;border:1px solid rgba(90,50,30,.4)}
.btn-primary:active{transform:scale(.97);box-shadow:0 2px 0 #5c4020,0 4px 16px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.3)}

.progress-wrap{margin-bottom:24px}
.progress-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:13px;color:var(--text-dim)}
.progress-track{width:100%;height:6px;background:var(--border);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,#8b6a3a,var(--primary-lt),#f5e6c8);border-radius:3px;transition:width .4s ease}

.q-area{flex:1;display:flex;flex-direction:column}
.q-text{font-family:var(--font-display);font-size:17px;font-weight:700;line-height:1.55;text-align:center;color:var(--text);margin-bottom:24px;min-height:54px;letter-spacing:.02em}
.opts{display:flex;flex-direction:column;gap:10px}
.opt-btn{width:100%;padding:14px 16px;background:var(--surface);border:1.5px solid var(--border);border-radius:14px;color:var(--text);font-size:14px;text-align:left;line-height:1.4;transition:all .15s;box-shadow:var(--sh-sm)}
.opt-btn:hover{border-color:var(--primary-lt);background:var(--surface-hover)}
.opt-btn:active{transform:translateX(3px)}
.opt-btn.picked{background:var(--primary-bg);border-color:var(--primary-lt)}

.loading-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:300px}
.loader{width:48px;height:48px;border:3.5px solid var(--border);border-top-color:var(--primary-lt);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-wrap p{font-size:16px;font-weight:600;color:var(--text)}
.loading-wrap small{font-size:13px;color:var(--text-dim)}

.result-wrap{padding-top:4px}
.result-card{background:linear-gradient(175deg,#2e2638 0%,#231a2e 50%,#1c1528 100%);border:1px solid var(--gold-line);border-top:3px solid var(--seal);border-radius:var(--radius);padding:28px 20px;text-align:center;box-shadow:var(--sh-md),inset 0 1px 0 rgba(255,245,230,.06);animation:cardIn .5s ease;position:relative}
.result-card::after{content:"";position:absolute;inset:10px;pointer-events:none;z-index:0;border:1px dashed rgba(212,165,116,.15);border-radius:calc(var(--radius) - 6px)}
.result-card .result-emoji,.result-card .result-type-label,.result-card .result-title,.result-card .result-desc,.result-card .result-tags,.result-card .result-compat{position:relative;z-index:1}
@keyframes cardIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
.result-emoji{font-size:60px;margin-bottom:10px}
.result-type-label{display:inline-block;padding:4px 12px;border-radius:8px;font-size:12px;font-weight:700;letter-spacing:1px;background:rgba(201,162,39,.2);color:var(--primary-lt);margin-bottom:8px;border:1px solid rgba(201,162,39,.35)}
.result-title{font-family:var(--font-display);font-size:21px;font-weight:700;line-height:1.38;color:var(--primary-lt);margin-bottom:14px;letter-spacing:.04em}
.result-desc{font-size:14px;color:var(--text-sub);line-height:1.8;text-align:left;margin-bottom:18px;white-space:pre-line}
.result-tags{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;margin-bottom:14px}
.tag{padding:5px 12px;border-radius:14px;font-size:12px;background:rgba(201,162,39,.15);color:var(--primary-lt);font-weight:500;border:1px solid rgba(201,162,39,.25)}
.result-compat{margin-top:14px;padding:14px;background:var(--bg-sub);border-radius:12px;text-align:left}
.result-compat h4{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--primary-lt);margin-bottom:8px;letter-spacing:.06em}
.compat-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:13px;color:var(--text-sub)}
.compat-good{color:var(--mint);font-weight:600}.compat-bad{color:var(--pink);font-weight:600}

.share-section{margin-top:20px}
.share-label{font-size:13px;color:var(--text-dim);margin-bottom:10px;text-align:center}
.share-btns{display:flex;gap:10px;justify-content:center}
.share-btn{padding:10px 18px;border-radius:12px;font-size:13px;font-weight:700;transition:transform .15s}
.share-btn:active{transform:scale(.95)}
.s-kakao{background:#FEE500;color:#191919}.s-x{background:#1DA1F2;color:#fff}.s-copy{background:var(--bg-sub);color:var(--text-sub);border:1px solid var(--border)}

.action-btns{margin-top:14px;display:flex;flex-direction:column;gap:10px}
.btn-outline{width:100%;padding:13px;background:transparent;border:1.5px solid var(--border);border-radius:14px;color:var(--text-sub);font-size:14px;font-weight:600;transition:all .15s}
.btn-outline:hover{border-color:var(--primary-lt);color:var(--primary-lt)}

.footer{max-width:var(--max-w);margin:0 auto;padding:14px max(12px,env(safe-area-inset-left)) max(20px,env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-right));text-align:center;font-size:11px;color:var(--text-dim);border-top:1px solid var(--border)}
.footer a{color:var(--text-sub)}

.toast{position:fixed;bottom:72px;left:50%;transform:translateX(-50%);background:#2a243f;color:var(--text);padding:10px 22px;border-radius:12px;font-size:14px;font-weight:600;z-index:999;opacity:0;pointer-events:none;transition:opacity .25s;box-shadow:var(--sh-lg);border:1px solid var(--border)}
.toast.show{opacity:1}

.fade-in{animation:fadeIn .35s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.mt-12{margin-top:12px}

/* 사주 정보 바텀시트 */
.sheet-backdrop{position:fixed;inset:0;background:rgba(8,4,14,.62);z-index:500;opacity:0;visibility:hidden;transition:opacity .32s ease,visibility .32s ease}
.sheet-backdrop.is-open{opacity:1;visibility:visible}
.sheet-panel{position:fixed;left:0;right:0;bottom:0;max-height:min(94dvh,680px);z-index:501;width:100%;max-width:var(--max-w);margin:0 auto;background:linear-gradient(180deg,#2e2640 0%,#1a1426 100%);border-radius:22px 22px 0 0;border:1px solid var(--gold-line);border-bottom:none;box-shadow:0 -12px 48px rgba(0,0,0,.55);transform:translateY(105%);transition:transform .4s cubic-bezier(.25,.85,.35,1);display:flex;flex-direction:column;padding-bottom:max(12px,env(safe-area-inset-bottom))}
.sheet-panel.is-open{transform:translateY(0)}
.sheet-panel.sheet-tall{max-height:100dvh;border-radius:0;max-width:none}
.sheet-inner{flex:1;overflow-y:auto;padding:16px 18px 20px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.sheet-grab{width:40px;height:5px;background:var(--border);border-radius:3px;margin:10px auto 6px;flex-shrink:0}
.sheet-promo-text{text-align:center;font-family:var(--font-display)}
.sheet-promo-text .t1{font-size:18px;font-weight:700;color:var(--text);margin-bottom:14px;line-height:1.45}
.sheet-promo-text .t2{font-size:14px;color:var(--text-sub);line-height:1.65}
.sheet-promo-sep{color:var(--primary-lt);font-size:11px;letter-spacing:.35em;text-align:center;margin:18px 0 8px;opacity:.85}
.sheet-btn-stack{display:flex;flex-direction:column;gap:11px;align-items:stretch;max-width:320px;margin:20px auto 0}
.sheet-btn-main{width:100%;padding:15px;border-radius:12px;font-size:15px;font-weight:700;font-family:var(--font-display);letter-spacing:.08em;background:linear-gradient(180deg,#e8c896,#c4945c);color:#1a0f0a;border:1px solid rgba(90,50,30,.45);box-shadow:0 4px 0 #5c4020,0 8px 20px rgba(0,0,0,.35)}
.sheet-btn-sub{width:100%;padding:13px;border-radius:12px;font-size:14px;font-weight:600;color:var(--text-sub);border:1.5px solid var(--border);background:transparent}
.wiz-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:8px}
.wiz-step{font-size:12px;color:var(--primary-lt);font-weight:700;white-space:nowrap}
.wiz-back{font-size:14px;color:var(--text-sub);padding:8px 4px;touch-action:manipulation}
.wiz-title{font-family:var(--font-display);font-size:17px;font-weight:700;text-align:center;line-height:1.5;margin-bottom:4px;color:var(--text)}
.wiz-row-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px}
.wiz-row-head .wiz-title{margin:0;text-align:left;flex:1}
.wiz-hint{font-size:10px;color:var(--text-dim);line-height:1.4;max-width:48%;text-align:right;flex-shrink:0}
.wiz-field-label{font-size:12px;color:var(--text-sub);margin-bottom:6px}
.wiz-input{width:100%;padding:14px 16px;background:var(--surface);border:1.5px solid var(--border);border-radius:12px;color:var(--text);font-size:17px}
.wiz-input:focus{outline:none;border-color:var(--primary-lt)}
.wiz-input:disabled{opacity:.45}
.wiz-input-hint{font-size:11px;color:var(--text-dim);margin-top:8px;line-height:1.45}
.gender-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.gender-btn{padding:16px;border-radius:12px;border:1.5px solid var(--border);background:var(--surface);color:var(--text);font-weight:700;font-size:15px;touch-action:manipulation}
.gender-btn.is-on{border-color:var(--primary-lt);background:var(--primary-bg);color:var(--primary-lt)}
.birth-flex{display:flex;gap:8px;align-items:stretch;margin-top:8px}
.birth-flex .wiz-input{flex:1;min-width:0}
.cal-toggle{display:flex;border-radius:10px;overflow:hidden;border:1px solid var(--border);flex-shrink:0}
.cal-toggle button{padding:14px 12px;font-size:11px;font-weight:700;background:var(--bg-sub);color:var(--text-dim);white-space:nowrap;touch-action:manipulation}
.cal-toggle button.is-on{background:var(--primary-bg);color:var(--primary-lt)}
.time-flex{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:10px}
.time-flex .wiz-input{width:140px;max-width:45%}
.chk-row{display:flex;align-items:center;gap:10px;margin-top:14px;font-size:14px;color:var(--text-sub)}
.chk-row input{width:18px;height:18px;accent-color:var(--primary)}
.btn-next{margin-top:20px;width:100%;padding:15px;border-radius:12px;font-weight:700;font-size:15px;border:none;background:linear-gradient(180deg,#4a3f45,#383038);color:var(--text-dim);transition:opacity .2s,transform .15s;box-shadow:none}
.btn-next.is-ready{background:linear-gradient(180deg,#e8c896,#c4945c);color:#1a0f0a;box-shadow:0 4px 0 #5c4020}
.btn-next:disabled{opacity:.5;cursor:not-allowed}
.btn-next:active{transform:scale(.98)}
.wiz-summary{margin-top:18px;padding:14px;background:rgba(0,0,0,.2);border-radius:12px;border:1px dashed rgba(212,165,116,.25)}
.wiz-summary h4{font-family:var(--font-display);font-size:11px;color:var(--primary-lt);letter-spacing:.2em;text-align:center;margin-bottom:10px}
.wiz-sum-item{font-size:13px;padding:7px 0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;gap:12px}
.wiz-sum-item:last-child{border-bottom:none}
.wiz-sum-item span{color:var(--text-dim)}
.wiz-sum-item strong{color:var(--text);font-weight:600;text-align:right}
.sheet-terms-text{font-size:13px;color:var(--text-sub);line-height:1.75;text-align:center;margin:12px 0 20px}
body.sheet-lock{overflow:hidden;touch-action:none}

/* 커스텀 확인·알림 레이어 (네이티브 alert/confirm 대체) */
.app-dlg-backdrop{position:fixed;inset:0;background:rgba(6,2,12,.75);z-index:1100;opacity:0;visibility:hidden;transition:opacity .28s ease,visibility .28s ease}
.app-dlg-backdrop.is-open{opacity:1;visibility:visible}
.app-dlg-panel{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%) scale(.94);z-index:1101;width:min(calc(100% - 40px),340px);max-width:calc(100vw - 40px);background:linear-gradient(180deg,#35304a 0%,#1f1a2e 100%);border:1px solid var(--gold-line);border-radius:18px;padding:22px 20px 18px;box-shadow:0 20px 60px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,248,235,.06);opacity:0;visibility:hidden;transition:opacity .28s ease,visibility .28s ease,transform .28s cubic-bezier(.25,.85,.35,1)}
.app-dlg-panel.is-open{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}
.app-dlg-seal{position:absolute;top:14px;right:16px;font-family:var(--font-display);font-size:22px;color:rgba(212,165,116,.26);pointer-events:none;line-height:1}
.app-dlg-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--primary-lt);margin:0 0 10px;padding-right:28px;line-height:1.4}
.app-dlg-msg{font-size:14px;color:var(--text-sub);line-height:1.65;margin:0 0 18px}
.app-dlg-actions{display:flex;gap:10px;margin-top:4px}
.app-dlg-actions.single .app-dlg-ok{flex:none;width:100%}
.app-dlg-btn{flex:1;padding:13px 14px;border-radius:12px;font-size:14px;font-weight:700;font-family:inherit;touch-action:manipulation;cursor:pointer;transition:transform .12s,opacity .15s}
.app-dlg-btn:active{transform:scale(.98)}
.app-dlg-cancel{background:transparent;border:1.5px solid var(--border);color:var(--text-sub)}
.app-dlg-ok{background:linear-gradient(180deg,#e8c896,#c4945c);color:#1a0f0a;border:1px solid rgba(90,50,30,.45);box-shadow:0 3px 0 #5c4020}
.app-dlg-ok.danger{background:linear-gradient(180deg,#c46a5a,#8f3d38);color:#fff8f0;border-color:rgba(50,20,18,.55);box-shadow:0 3px 0 #4a2520}

/* 사주 요약 · 분석 로딩 (프로필 플로우) */
.test-wrap.saju-flow-mode{padding-bottom:100px}
.saju-sum-page{max-width:100%}
.saju-sum-head{display:grid;grid-template-columns:38px 1fr 78px;align-items:center;margin-bottom:14px;gap:6px}
.saju-sum-head h2{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--primary-lt);letter-spacing:.06em;margin:0;text-align:center}
.saju-sum-head .saju-sum-icons{display:flex;gap:4px}
.saju-sum-icons button{width:36px;height:36px;border-radius:10px;background:var(--surface);border:1px solid var(--border);color:var(--text-sub);font-size:15px;touch-action:manipulation}
.saju-profile-card{background:linear-gradient(165deg,rgba(46,38,64,.95),rgba(26,20,40,.98));border:1px solid var(--gold-line);border-radius:16px;padding:16px 16px 14px;margin-bottom:18px;box-shadow:var(--sh-sm)}
.saju-profile-card .saju-p-line1{font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px}
.saju-profile-card .saju-p-line1 em{font-style:normal;color:var(--primary-lt)}
.saju-profile-card .saju-p-line2{font-size:13px;color:var(--text-sub);line-height:1.5}
.saju-profile-card .saju-change{float:right;margin-top:-4px;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:700;background:linear-gradient(180deg,#e8c896,#c4945c);color:#1a0f0a;border:1px solid rgba(90,50,30,.4);touch-action:manipulation}
.saju-tri{display:flex;justify-content:space-between;gap:8px;margin-bottom:20px}
.saju-tri-item{flex:1;text-align:center;min-width:0}
.saju-tri-cap{font-size:11px;color:var(--text-dim);margin-bottom:8px;font-weight:600}
.saju-tri-circle{width:100%;aspect-ratio:1;max-width:96px;margin:0 auto;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;border:2px solid rgba(212,165,116,.35);box-shadow:0 8px 24px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.08)}
.saju-tri-circle .big{font-family:var(--font-display);font-size:clamp(22px,7vw,28px);font-weight:700;line-height:1;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.4)}
.saju-tri-circle .sub{font-size:11px;font-weight:700;margin-top:2px;opacity:.95}
.saju-tri-circle.tri-earth{background:linear-gradient(145deg,#c9a227,#8b6914);border-color:rgba(255,220,120,.5)}
.saju-tri-circle.tri-wood{background:linear-gradient(145deg,#3d6a9a,#243d5c);border-color:rgba(120,170,220,.45)}
.saju-tri-circle.tri-fire{background:linear-gradient(145deg,#b84d4d,#6b2828);border-color:rgba(255,150,130,.4)}
.saju-tri-circle.tri-metal{background:linear-gradient(145deg,#6a6a78,#3d3d48);border-color:rgba(220,220,235,.35)}
.saju-tri-circle.tri-water{background:linear-gradient(145deg,#2a4a62,#1a3042);border-color:rgba(130,180,220,.4)}
.saju-tri-circle.tri-sipsung{background:linear-gradient(145deg,#353540,#1e1e28);border-color:rgba(212,165,116,.4)}
.saju-animal-emoji{font-size:clamp(28px,9vw,36px);line-height:1}
.saju-grid-card{background:rgba(30,24,45,.9);border:1px solid var(--border);border-radius:16px;padding:14px 10px 12px;margin-bottom:16px}
.saju-grid-title{font-size:12px;color:var(--text-dim);text-align:center;margin-bottom:12px;font-weight:600}
.saju-pillar-row{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;text-align:center}
.saju-pillar-col{display:flex;flex-direction:column;gap:5px}
.saju-pillar-hd{font-size:10px;color:var(--primary-lt);font-weight:700;margin-bottom:2px}
.saju-pcell{border-radius:10px;padding:8px 4px;font-size:11px;font-weight:600;line-height:1.35;border:1px solid rgba(255,255,255,.12)}
.saju-pcell .han{font-family:var(--font-display);font-size:20px;font-weight:700;display:block;margin-bottom:2px}
.saju-pcell .meta{opacity:.88;font-size:9px}
.sp-el-wood{background:linear-gradient(180deg,#355a7a,#243d5a);color:#e8f0ff}
.sp-el-fire{background:linear-gradient(180deg,#8a4040,#5c2828);color:#ffe8e8}
.sp-el-earth{background:linear-gradient(180deg,#9a7b30,#6b5220);color:#fff8e8}
.sp-el-metal{background:linear-gradient(180deg,#5a5a68,#3a3a44);color:#f0f0f8}
.sp-el-water{background:linear-gradient(180deg,#2a4a5c,#1a3040);color:#e0f0ff}
.saju-pfoot{font-size:9px;color:var(--text-dim);margin-top:2px;line-height:1.3}
.saju-manse-btn{width:100%;padding:12px;margin-top:12px;border-radius:12px;font-size:13px;font-weight:600;color:var(--text-sub);background:rgba(0,0,0,.2);border:1px solid var(--border);touch-action:manipulation}
.saju-fixed-bar{position:fixed;left:0;right:0;bottom:0;z-index:90;padding:12px max(12px,env(safe-area-inset-left)) max(14px,env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-right));background:linear-gradient(180deg,transparent,rgba(14,10,22,.92) 28%);pointer-events:none}
.saju-fixed-bar .btn-primary{pointer-events:auto;max-width:100%;margin:0}
.saju-analyze-page{min-height:calc(100dvh - 120px);padding-bottom:120px}
.saju-anlz-title{font-family:var(--font-display);font-size:18px;font-weight:700;text-align:center;line-height:1.55;color:var(--text);margin:20px 0 16px}
.saju-anlz-title em{font-style:normal;color:var(--primary-lt)}
.saju-anlz-social{text-align:center;font-size:14px;font-weight:700;color:var(--primary-lt);margin:16px 0 20px}
.saju-anlz-steps{max-width:340px;margin:0 auto}
.saju-anlz-step{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;margin-bottom:8px;background:var(--surface);border:1px solid var(--border);border-radius:12px;font-size:13px;color:var(--text-sub);opacity:.35;transform:translateX(-6px);transition:opacity .35s ease,transform .35s ease}
.saju-anlz-step.is-on{opacity:1;transform:none;color:var(--text)}
.saju-anlz-step .chk{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;margin-top:1px;font-size:12px;display:flex;align-items:center;justify-content:center;color:transparent}
.saju-anlz-step.is-on .chk{border-color:var(--primary-lt);background:rgba(212,165,116,.2);color:var(--primary-lt);content:'✓'}
.saju-anlz-done{text-align:center;font-size:16px;font-weight:700;color:var(--primary-lt);margin:28px 0 8px;display:none}
.saju-anlz-done.is-show{display:block;animation:fadeIn .5s ease}
.saju-ad-gate .btn-primary{background:linear-gradient(180deg,#2a2438,#1a1520);color:var(--primary-lt);border:1px solid var(--gold-line);box-shadow:0 4px 0 #151018,0 8px 24px rgba(0,0,0,.45)}
.saju-manse-hint{font-size:10px;color:var(--text-dim);margin-top:10px;line-height:1.5;text-align:center}
.saju-grid-title small{display:block;font-weight:500;opacity:.85;margin-top:4px}
/* 만세력 요약 — 메인과 동일한 다크 톤 */
.saju-manse-sheet{background:linear-gradient(180deg,rgba(40,32,58,.97),rgba(22,16,35,.99));padding:4px 10px 24px;margin:0 -4px;border-radius:18px 18px 0 0;min-height:200px;color:var(--text);border:1px solid rgba(212,165,116,.12);border-bottom:none;box-shadow:inset 0 1px 0 rgba(212,165,116,.06)}
.saju-manse-sheet .saju-profile-card{background:linear-gradient(165deg,rgba(46,38,64,.95),rgba(26,20,40,.98));border:1px solid var(--gold-line);box-shadow:var(--sh-sm),inset 0 1px 0 rgba(212,165,116,.08);color:var(--text)}
.saju-manse-sheet .saju-p-line1{color:var(--text)}
.saju-manse-sheet .saju-p-line2{color:var(--text-sub)}
.saju-manse-sheet .saju-change{box-shadow:0 4px 14px rgba(0,0,0,.35)}
.saju-top-summary{margin-bottom:14px}
.saju-top-grid.saj-3card{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:4px}
.saju-top-card-lite{background:var(--surface);border-radius:14px;padding:12px 6px 10px;text-align:center;box-shadow:var(--sh-sm),inset 0 1px 0 rgba(212,165,116,.06);border:1px solid var(--border);min-width:0;color:var(--text)}
.saju-top-circle-el{width:52px;height:52px;border-radius:50%;margin:0 auto 8px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:21px;font-weight:700;color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.2),0 4px 12px rgba(0,0,0,.35)}
.saju-top-circle-el.ce-wood{background:linear-gradient(145deg,#4a7ab0,#2d5080)}
.saju-top-circle-el.ce-fire{background:linear-gradient(145deg,#c44848,#842828)}
.saju-top-circle-el.ce-earth{background:linear-gradient(145deg,#b89838,#7a6820)}
.saju-top-circle-el.ce-metal{background:linear-gradient(145deg,#6a6c78,#454550)}
.saju-top-circle-el.ce-water{background:linear-gradient(145deg,#3d6a8a,#284058)}
.saju-top-circle-sip{width:52px;height:52px;border-radius:50%;margin:0 auto 8px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:13px;font-weight:700;line-height:1.15;color:var(--text);background:linear-gradient(145deg,#454858,#2a2d38);border:1px solid var(--border);box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 4px 12px rgba(0,0,0,.3)}
.saju-top-circle-animal{width:52px;height:52px;border-radius:50%;margin:0 auto 8px;display:flex;align-items:center;justify-content:center;font-size:30px;line-height:1;background:linear-gradient(145deg,#4a3828,#2e2018);border:1px solid rgba(212,165,116,.25);box-shadow:inset 0 1px 0 rgba(212,165,116,.12),0 4px 12px rgba(0,0,0,.35)}
.saju-top-big{font-size:17px;font-weight:800;color:var(--primary-lt);line-height:1.25;word-break:keep-all}
.saju-top-cap{margin-top:6px;font-size:10px;font-weight:600;color:var(--text-dim);letter-spacing:-.02em}
.saju-grid-card.saj-lite-grid{background:rgba(30,24,45,.92);border:1px solid var(--border);box-shadow:var(--sh-sm),inset 0 1px 0 rgba(212,165,116,.05);color:var(--text)}
.saju-grid-card.saj-lite-grid .saju-grid-title{color:var(--text-dim);font-size:11px;margin-bottom:10px}
.saju-tbl-lite{margin-top:4px}
.saju-tbl-row-lite{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;align-items:stretch;margin-bottom:6px}
.saju-tbl-row-lite:last-child{margin-bottom:0}
.saju-tbl-row-lite.hd .saju-tbl-cell-lite{font-size:11px;font-weight:800;color:var(--primary-lt);padding:4px 2px 2px}
.saju-tbl-row-lite.sip .saju-tbl-cell-lite{font-size:11px;font-weight:700;color:var(--text-sub);padding:2px 2px 4px}
.saju-tbl-row-lite.sip.sub .saju-tbl-cell-lite{font-size:10px;color:var(--text-dim)}
.saju-tbl-row-lite.foot .saju-tbl-cell-lite{font-size:10px;font-weight:600;color:var(--text-dim)}
.saju-tbl-cell-lite{text-align:center;min-width:0;color:var(--text-sub)}
.saju-hanja-block{border-radius:10px;padding:8px 4px 7px;font-weight:700;border:1px solid rgba(255,255,255,.08);box-shadow:0 2px 8px rgba(0,0,0,.25)}
.saju-hanja-block .sjb-h{font-family:var(--font-display);font-size:clamp(18px,5.2vw,22px);display:block;line-height:1.15}
.saju-hanja-block .sjb-m{display:block;font-size:9px;font-weight:600;margin-top:4px;opacity:.9;line-height:1.25;word-break:keep-all}
.sjb-wood{background:linear-gradient(180deg,#355a7a,#243d5a);color:#e8f0ff}
.sjb-fire{background:linear-gradient(180deg,#6a3038,#4a2228);color:#ffe8e8}
.sjb-earth{background:linear-gradient(180deg,#6b5228,#4a3818);color:#fff4d8}
.sjb-metal{background:linear-gradient(180deg,#4a4a52,#323238);color:#e8e8f0}
.sjb-water{background:linear-gradient(180deg,#2a4a5c,#1e3545);color:#d0e8f8}
.saju-manse-sheet .saju-manse-btn{background:rgba(0,0,0,.25);color:var(--text-sub);border:1px solid var(--border);margin-top:12px}
.saju-manse-sheet .saju-manse-btn:active{background:rgba(212,165,116,.12);color:var(--primary-lt)}
@media (max-width:360px){.saju-top-grid.saj-3card{grid-template-columns:1fr;gap:8px}}
