:root{
  --bg:#F7F7FB; --card:#fff; --ink:#1A1A2E; --muted:#8E8EA8; --line:#EFEFF4;
  --accent:#6C5CE7; --accent2:#FF8FB1;
  --grad:linear-gradient(135deg,#6C5CE7 0%,#FF8FB1 100%);
  --r-card:20px; --r-input:14px; --shadow:0 8px 30px rgba(108,92,231,.08);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);
  font-family:"Pretendard Variable",Pretendard,-apple-system,system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;}
body{display:flex;justify-content:center;min-height:100vh;
  background:
    radial-gradient(1200px 380px at 50% -120px,rgba(108,92,231,.10),transparent 60%),
    radial-gradient(900px 320px at 90% 8%,rgba(255,143,177,.10),transparent 55%),
    var(--bg);}
.app{width:100%;max-width:440px;padding:22px 18px 48px;}

/* header */
.brand{display:flex;align-items:center;gap:8px;font-weight:700;font-size:15px;color:var(--accent);}
.brand .dot{width:8px;height:8px;border-radius:50%;background:var(--grad);}
.hero{margin:18px 2px 22px;}
.hero h1{font-size:27px;line-height:1.28;font-weight:800;letter-spacing:-.5px;}
.hero p{margin-top:8px;color:var(--muted);font-size:14.5px;font-weight:500;}

/* card / form */
.card{background:var(--card);border-radius:var(--r-card);box-shadow:var(--shadow);
  padding:20px 18px;border:1px solid var(--line);}
.label{font-size:13px;font-weight:700;color:var(--ink);margin:0 2px 8px;}
.field+.field{margin-top:16px}
input[type=text],input[type=date],input[type=time]{
  width:100%;height:50px;border:1.5px solid var(--line);border-radius:var(--r-input);
  background:#fff;padding:0 14px;font-size:15px;font-family:inherit;color:var(--ink);
  transition:border-color .15s, box-shadow .15s;}
input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(108,92,231,.10);}
input::placeholder{color:#B9B9C9}
input:disabled{background:#F3F3F7;color:#B9B9C9}

.pills{display:flex;gap:8px}
.pill{flex:1;height:46px;border-radius:999px;border:1.5px solid var(--line);background:#fff;
  font-size:14.5px;font-weight:600;color:var(--muted);cursor:pointer;font-family:inherit;
  transition:.15s;display:flex;align-items:center;justify-content:center;gap:6px}
.pill.on{background:rgba(108,92,231,.08);border-color:var(--accent);color:var(--accent)}

.hint{display:flex;align-items:center;gap:7px;margin-top:10px;color:var(--muted);font-size:13px}
.hint input{width:17px;height:17px;accent-color:var(--accent)}

.cta{width:100%;height:54px;border:none;border-radius:999px;background:var(--grad);color:#fff;
  font-size:16px;font-weight:700;font-family:inherit;cursor:pointer;margin-top:22px;
  box-shadow:0 10px 24px rgba(108,92,231,.28);transition:transform .08s, filter .15s}
.cta:active{transform:translateY(1px)}
.cta:hover{filter:brightness(1.03)}
.cta:disabled{filter:grayscale(.4) opacity(.6);cursor:default}
.foot{text-align:center;color:#B6B6C6;font-size:12px;margin-top:18px}

/* ===== 결과 ===== */
#result{display:none}
.rtop{display:flex;align-items:center;justify-content:space-between;margin:6px 2px 16px}
.rtop h2{font-size:20px;font-weight:800;letter-spacing:-.4px}
.rtop h2 b{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.back{border:1.5px solid var(--line);background:#fff;border-radius:999px;
  height:36px;padding:0 14px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;font-family:inherit}
.section-t{font-size:13px;font-weight:700;color:var(--muted);margin:22px 4px 10px;letter-spacing:.2px}

/* 네 기둥 */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:9px}
.pcol{text-align:center;min-width:0}
.pcap{font-size:11.5px;color:var(--muted);font-weight:600;margin-bottom:6px}
.psip{font-size:11px;font-weight:700;color:var(--accent);margin-bottom:5px;height:14px;overflow:hidden}
.gan,.ji{border-radius:14px;padding:10px 4px;color:#fff;position:relative}
.gan{margin-bottom:7px}
.han{font-size:23px;font-weight:800;line-height:1.1}
.kor{font-size:11.5px;font-weight:600;opacity:.95;margin-top:3px}
.ohx{font-size:10.5px;font-weight:700;opacity:.9;margin-top:1px}
.ji .emoji{font-size:13px;margin-top:2px}
.ji .gm{position:absolute;top:5px;right:5px;background:rgba(0,0,0,.28);border-radius:6px;
  font-size:9px;font-weight:700;padding:1px 4px}
.psub{font-size:10.5px;color:var(--muted);font-weight:600;margin-top:6px;line-height:1.3;
  word-break:keep-all}
.punknown{border-radius:14px;padding:24px 4px;background:#F0F0F5;color:#B9B9C9;
  font-size:12px;font-weight:700;line-height:1.3}

/* 오행 분포 */
.ohaeng{display:flex;flex-direction:column;gap:9px}
.obar{display:flex;align-items:center;gap:10px}
.oname{width:30px;font-size:13px;font-weight:700}
.otrack{flex:1;height:10px;background:#F0F0F5;border-radius:999px;overflow:hidden}
.ofill{height:100%;border-radius:999px;transition:width .4s}
.oval{width:18px;text-align:right;font-size:12px;font-weight:700;color:var(--muted)}

/* 지장간 */
.jjg{display:flex;flex-direction:column;gap:8px}
.jjgrow{display:flex;justify-content:space-between;font-size:13.5px;font-weight:600}
.jjgcap{color:var(--muted)}
.jjgval{color:var(--ink);letter-spacing:2px}

/* 대운 */
.daeun{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}
.dchip{flex:0 0 auto;min-width:52px;text-align:center;border:1.5px solid var(--line);
  border-radius:14px;padding:8px 6px}
.dage{font-size:11px;color:var(--muted);font-weight:600;margin-bottom:4px}
.dgz{font-size:15px;font-weight:800}

/* 한 줄 / 칩 */
.oneline{background:linear-gradient(135deg,rgba(108,92,231,.06),rgba(255,143,177,.06));
  border:1px solid var(--line);border-radius:16px;padding:16px;font-size:14.5px;line-height:1.6}
.oneline b{color:var(--accent)}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{background:#fff;border:1.5px solid var(--line);border-radius:999px;padding:8px 13px;
  font-size:13px;font-weight:600}
.chip .v{color:var(--accent);font-weight:700}
.disc{text-align:center;color:#B6B6C6;font-size:12px;margin-top:24px;line-height:1.5}

/* AI 풀이 */
.pulicard{display:flex;flex-direction:column;gap:14px}
.puliintro{font-size:14px;line-height:1.6;color:var(--ink)}
.muted{color:var(--muted);font-size:12.5px}
.pulibtn{margin-top:0}
.puliloading{display:flex;align-items:center;gap:10px;color:var(--accent);font-weight:600;
  font-size:14px;padding:8px 2px}
.spin{width:16px;height:16px;border-radius:50%;border:2.5px solid rgba(108,92,231,.25);
  border-top-color:var(--accent);animation:spin .7s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}
.puliout h4{font-size:14.5px;font-weight:800;color:var(--accent);margin:16px 0 7px;letter-spacing:-.2px}
.puliout h4:first-child{margin-top:2px}
.puliout p{font-size:14.5px;line-height:1.72;margin:0 0 4px;color:var(--ink);word-break:keep-all}
.puliout b{color:var(--accent)}
.pulifallback p{font-size:14px;line-height:1.65;margin-bottom:8px}

/* --- 전문가 분석 --- */
.expert{display:flex;flex-direction:column;gap:11px}
.exline{display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.exk{flex:0 0 64px;font-size:12px;font-weight:700;color:var(--muted)}
.exk2{flex:0 0 64px}
.exv{font-size:14.5px;font-weight:800;color:var(--ink)}
.exv small{font-size:12px;font-weight:700;color:var(--accent);margin-left:2px}
.exsub{font-size:12.5px;color:var(--muted);font-weight:500}
.strbar{flex:1 1 90px;min-width:90px;height:8px;border-radius:999px;background:var(--line);position:relative;overflow:hidden}
.strfill{height:100%;border-radius:999px;background:var(--grad)}
.exnote{font-size:12px;color:var(--muted);line-height:1.5;margin:-3px 0 0 0}
.exgroup{display:flex;flex-direction:column;gap:6px;padding-top:3px;border-top:1px solid var(--line)}
.exglabel{font-size:11.5px;font-weight:700;color:var(--muted)}
.exchips{display:flex;flex-wrap:wrap;gap:6px}
.exchip{font-size:12px;font-weight:600;border-radius:999px;padding:5px 10px;border:1.5px solid var(--line);
  background:#fff;color:var(--ink);display:inline-flex;align-items:center;gap:5px}
.exchip .exwhere{font-size:10px;font-weight:700;color:var(--muted)}
.exchip.cat-hap{border-color:rgba(34,176,125,.4);background:rgba(34,176,125,.07);color:#1B8F66}
.exchip.cat-chung{border-color:rgba(255,107,107,.4);background:rgba(255,107,107,.07);color:#E14B4B}
.exchip.cat-hyeong{border-color:rgba(244,183,64,.5);background:rgba(244,183,64,.10);color:#B5841F}
.exchip.cat-paha{border-color:rgba(142,142,168,.4);background:rgba(142,142,168,.08);color:var(--muted)}
.exchip.good{border-color:rgba(108,92,231,.4);background:rgba(108,92,231,.07);color:var(--accent)}
.exchip.bad{border-color:rgba(255,107,107,.4);background:rgba(255,107,107,.07);color:#E14B4B}

/* --- 기본 풀이 (구버전 클래스, 호환용) --- */
.gibon{display:flex;flex-direction:column;gap:15px}
.gbt{font-size:13.5px;font-weight:800;color:var(--accent);margin-bottom:5px;letter-spacing:-.2px}
.gbb p{font-size:14px;line-height:1.72;margin:0 0 3px;color:var(--ink);word-break:keep-all}
.gbb b{color:var(--accent)}

/* --- 접이식 해설 카드 (맞춤 해설 · 기본 풀이) --- */
.acccards{display:flex;flex-direction:column;gap:10px}
.acc{background:var(--card);border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow);overflow:hidden}
.acc[open]{border-color:rgba(108,92,231,.28)}
.acc-h{list-style:none;cursor:pointer;position:relative;padding:15px 42px 15px 16px;
  font-size:14.5px;font-weight:800;color:var(--ink);line-height:1.5;letter-spacing:-.2px;
  word-break:keep-all;-webkit-tap-highlight-color:transparent}
.acc-h::-webkit-details-marker{display:none}
.acc-h::after{content:"";position:absolute;right:17px;top:18px;width:8px;height:8px;
  border-right:2px solid var(--accent);border-bottom:2px solid var(--accent);
  transform:rotate(45deg);transition:transform .2s}
.acc[open] .acc-h{color:var(--accent)}
.acc[open] .acc-h::after{transform:rotate(-135deg);top:21px}
.acc-b{padding:0 16px 16px;border-top:1px solid var(--line)}
.acc-b p{font-size:14px;line-height:1.78;margin:11px 0 0;color:var(--ink);word-break:keep-all}
.acc-b b{color:var(--accent)}
.acc-b h4{font-size:14px;font-weight:800;color:var(--accent);margin:14px 0 0}

/* 맞춤 해설: 카드 로드되면 바깥 패널 벗기기 */
.pulicard.bare{background:none;border:none;box-shadow:none;padding:0;gap:0}

/* 전문가 분석 접이식 */
.exacc .card.expert{box-shadow:none;border:none;border-top:1px solid var(--line);
  border-radius:0;background:transparent}
