:root{--g:#C9A84C;--dk:#0e0b18;--c1:#18142a;--c2:#211c34;--b:rgba(201,168,76,.2);--mu:#9a8fb0;--tx:#e8e0f8;--gr:#3fbfa0;--rd:#e25555;--radius:10px}
*{box-sizing:border-box;margin:0;padding:0}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:"Noto Sans KR",sans-serif;background:var(--dk);color:var(--tx);font-size:15px;min-height:100vh;line-height:1.65;margin:0;padding:0}
.layout{display:block;min-height:100vh}
.sidebar-ad{width:160px;flex-shrink:0;background:rgba(255,255,255,.02);border-right:1px solid var(--b);padding:12px 8px}
.sidebar-ad-right{width:160px;flex-shrink:0;background:rgba(255,255,255,.02);border-left:1px solid var(--b);padding:12px 8px}
.main-area{flex:1;min-width:0;display:flex;flex-direction:column}
.ad-placeholder{background:rgba(255,255,255,.03);border:1px dashed var(--b);border-radius:8px;padding:8px;text-align:center;font-size:11px;color:var(--mu);margin-bottom:10px}

/* 헤더 */
.app-hdr{background:#08060f;border-bottom:1px solid var(--b);padding:16px 22px;display:flex;align-items:center;gap:12px}
.hdr-logo{font-size:20px;color:var(--g);font-weight:700;letter-spacing:.05em}
.hdr-sub{font-size:11px;color:var(--mu);letter-spacing:.06em;margin-top:3px}
.hdr-chips{display:flex;gap:6px;margin-left:auto;flex-wrap:wrap}
.chip{font-size:11px;padding:3px 10px;border-radius:20px;border:1px solid}
.chip-pu{background:rgba(124,92,191,.15);color:#b39ddb;border-color:rgba(124,92,191,.3)}
.chip-gr{background:rgba(63,191,160,.15);color:var(--gr);border-color:rgba(63,191,160,.3)}
.chip-g{background:rgba(201,168,76,.15);color:var(--g);border-color:rgba(201,168,76,.3)}

/* 탭 */
.tabs{display:flex;background:#080613;border-bottom:1px solid var(--b);overflow-x:auto}
.tab{padding:13px 18px;font-size:13px;color:var(--mu);cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;flex-shrink:0;transition:all .2s}
.tab:hover{color:var(--tx)}
.tab.active{color:var(--g);border-bottom-color:var(--g);font-weight:600}
.tab.done::after{content:" ✓";color:var(--gr);font-size:11px}
.tab-pages{flex:1}
.page{display:none;padding:20px;animation:fi .2s ease}
.page.active{display:block}
@keyframes fi{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* 카드 */
.card{background:var(--c1);border:1px solid var(--b);border-radius:var(--radius);padding:18px;margin-bottom:14px}
.sec{font-size:13px;color:var(--g);font-weight:700;margin-bottom:13px;display:flex;align-items:center;gap:6px;letter-spacing:.04em}

/* 폼 */
label{font-size:12px;color:var(--mu);display:block;margin-bottom:5px}
input,select,textarea{background:rgba(255,255,255,.05);border:1px solid var(--b);border-radius:8px;padding:11px 13px;color:var(--tx);font-size:14px;width:100%;transition:border .2s;font-family:inherit;color-scheme:dark}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--g)}
select option{background:#1a1628}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.gf{display:grid;gap:13px}
.required-star{color:var(--rd);margin-left:3px}

/* 달력/시간 */
.date-wrap{position:relative;z-index:9999}
input[type="date"],input[type="time"]{position:relative;z-index:100}
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator{opacity:.7;cursor:pointer;filter:invert(.7)}

/* 음력/양력 탭 */
.cal-tabs{display:flex;gap:7px;margin-bottom:9px}
.cal-tab{flex:1;padding:9px;border-radius:8px;border:1px solid var(--b);text-align:center;cursor:pointer;font-size:13px;color:var(--mu);transition:all .2s;font-weight:500}
.cal-tab.active{background:var(--g);color:#0e0b18;border-color:var(--g);font-weight:700}

/* 시간 가이드 */
.time-guide{font-size:11px;color:var(--mu);margin-top:6px;line-height:1.8;background:rgba(255,255,255,.02);border-radius:6px;padding:7px 10px;border:1px solid rgba(255,255,255,.05)}

/* 운세 멀티 선택 */
.worry-cats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}
.wc-btn{background:rgba(255,255,255,.03);border:1px solid var(--b);border-radius:8px;padding:10px 6px;text-align:center;cursor:pointer;font-size:12px;color:var(--mu);transition:all .2s;line-height:1.5}
.wc-btn:hover{border-color:var(--g);color:var(--tx)}
.wc-btn.active{background:rgba(201,168,76,.15);border-color:var(--g);color:var(--g);font-weight:700}
.wc-emoji{font-size:20px;display:block;margin-bottom:4px}

/* 손금 손 선택 */
.palm-guide{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:13px}
.pg-box{background:rgba(255,255,255,.03);border:1px solid var(--b);border-radius:9px;padding:16px;text-align:center;cursor:pointer;transition:all .2s}
.pg-box:hover,.pg-box.active{border-color:var(--g);background:rgba(201,168,76,.08)}
.pg-icon{font-size:38px;margin-bottom:9px;display:block}
.pg-title{font-size:14px;color:var(--g);font-weight:700}
.pg-desc{font-size:11px;color:var(--mu);margin-top:6px;line-height:1.7}

/* 업로드 존 */
.up-zone{border:2px dashed var(--b);border-radius:10px;padding:30px 16px;text-align:center;cursor:pointer;transition:all .2s}
.up-zone:hover{border-color:var(--g);background:rgba(201,168,76,.04)}
.prev-img{max-width:100%;max-height:200px;border-radius:8px;border:1px solid var(--b);display:block;margin:0 auto 12px}

/* 버튼 */
.gbtn{background:var(--g);color:#0e0b18;border:none;padding:13px 20px;border-radius:9px;font-size:15px;font-weight:700;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:opacity .2s;font-family:inherit}
.gbtn:hover{opacity:.85}
.ghost{background:transparent;color:var(--g);border:1px solid var(--b);border-radius:8px;padding:10px 16px;font-size:13px;cursor:pointer;transition:all .2s;font-family:inherit}
.ghost:hover{background:rgba(201,168,76,.08)}

/* 법적 고지 */
.legal-notice{background:rgba(255,255,255,.02);border:1px solid var(--b);border-radius:8px;padding:13px;margin-top:14px;font-size:11px;color:var(--mu);line-height:2.0}
.legal-notice summary{cursor:pointer;color:var(--mu);font-size:12px;list-style:none;display:flex;align-items:center;gap:6px}
.legal-notice summary::-webkit-details-marker{display:none}
details.legal-notice summary::before{content:"▶ ";font-size:10px}
details.legal-notice[open] summary::before{content:"▼ "}

/* 사주 원국 테이블 */
.pt{width:100%;border-collapse:collapse;margin-bottom:13px}
.pt td{text-align:center;padding:8px 4px;border:1px solid var(--b);font-size:13px}
.pt .pt-hdr{background:#0b0917;font-size:11px;color:var(--mu)}
.hj{font-size:30px;line-height:1.1;color:var(--tx)}
.ph{font-size:11px;color:var(--mu);margin-top:3px}
.e-badge{font-size:11px;border-radius:4px;padding:2px 6px;margin-top:4px;display:inline-block;font-weight:600}
.e0{background:rgba(74,222,128,.12);color:#4ade80}
.e1{background:rgba(248,113,113,.12);color:#f87171}
.e2{background:rgba(251,191,36,.12);color:#fbbf24}
.e3{background:rgba(209,213,219,.12);color:#d1d5db}
.e4{background:rgba(96,165,250,.12);color:#60a5fa}
.day-col{background:rgba(201,168,76,.07)!important}

/* 오행 바 */
.oh-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:7px;margin-bottom:12px}
.oh-box{background:rgba(255,255,255,.03);border:1px solid var(--b);border-radius:8px;padding:11px;text-align:center}
.oh-n{font-size:24px;font-weight:700}
.oh-l{font-size:12px;margin-top:3px;font-weight:600}
.bar-wrap{margin:6px 0}
.bar-lbl{display:flex;justify-content:space-between;font-size:11px;margin-bottom:4px}
.bar-bg{height:7px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden}
.bar-fill{height:100%;border-radius:4px;transition:width 1.4s ease}

/* 태그 */
.tag{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;margin:2px 2px 2px 0;font-weight:600}
.tag-h{background:rgba(63,191,160,.12);color:var(--gr);border:1px solid rgba(63,191,160,.25)}
.tag-c{background:rgba(226,85,85,.12);color:var(--rd);border:1px solid rgba(226,85,85,.25)}
.tag-f{background:rgba(251,191,36,.12);color:#fbbf24;border:1px solid rgba(251,191,36,.25)}
.tag-x{background:rgba(124,92,191,.12);color:#b39ddb;border:1px solid rgba(124,92,191,.25)}
.tag-s{background:rgba(201,168,76,.1);color:var(--g);border:1px solid var(--b)}
.tag-s.on{background:rgba(201,168,76,.22);border-color:var(--g)}

/* 12운성 / 대운 */
.u12g{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:9px}
.u12-box{background:rgba(255,255,255,.03);border:1px solid var(--b);border-radius:8px;padding:11px;text-align:center}
.u12-p{font-size:10px;color:var(--mu);margin-bottom:4px}
.u12-n{font-size:14px;font-weight:600}
.dw-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:5px;margin-top:9px}
.dw-box{min-width:70px;background:rgba(255,255,255,.02);border:1px solid var(--b);border-radius:8px;padding:10px 7px;text-align:center;flex-shrink:0;transition:all .2s}
.dw-box.cur{border-color:var(--g);background:rgba(201,168,76,.09)}
.dw-age{font-size:10px;color:var(--mu)}
.dw-hj{font-size:17px;color:var(--tx);margin:4px 0}
.dw-kr{font-size:10px;color:var(--mu)}

/* 공망 */
.gm-row{display:flex;gap:10px;margin-top:9px}
.gm-box{flex:1;background:rgba(226,85,85,.05);border:1px solid rgba(226,85,85,.2);border-radius:8px;padding:13px;text-align:center}
.gm-hj{font-size:26px}
.gm-kr{font-size:11px;color:var(--mu);margin-top:4px}
.kst-tag{font-size:11px;color:var(--mu);background:rgba(124,92,191,.1);border:1px solid rgba(124,92,191,.2);border-radius:6px;padding:5px 10px;margin-top:9px;display:inline-block}

/* 손금 점수 링 */
.ps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:12px 0}
.ps-box{background:rgba(255,255,255,.03);border:1px solid var(--b);border-radius:9px;padding:15px;text-align:center}
.ps-box.hi{border-color:var(--gr);background:rgba(63,191,160,.06)}
.ring-wrap{width:78px;height:78px;margin:0 auto 8px}
.ring-svg{width:78px;height:78px}
.ps-label{font-size:12px;color:var(--mu);font-weight:600}
.ps-note{font-size:11px;margin-top:6px;line-height:1.6;color:var(--mu)}

/* 융합 점수 */
.fusion-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin:12px 0}
.f-box{background:rgba(255,255,255,.03);border:1px solid var(--b);border-radius:9px;padding:15px}
.f-label{font-size:12px;color:var(--mu);margin-bottom:6px;font-weight:500}
.f-score{font-size:30px;font-weight:700;color:var(--g)}
.f-bar-bg{height:8px;background:rgba(255,255,255,.07);border-radius:4px;overflow:hidden;margin-top:8px}
.f-bar-fill{height:100%;border-radius:4px;transition:width 1.5s ease}

/* AI 해석 */
.ai-sec{background:var(--c2);border:1px solid var(--b);border-radius:9px;padding:15px;margin-bottom:12px}
.ai-t{font-size:13px;color:var(--g);font-weight:700;margin-bottom:9px;letter-spacing:.04em}
.ai-body{font-size:14px;line-height:2.0;color:var(--tx);white-space:pre-wrap}
.ai-note{background:rgba(124,92,191,.08);border:1px solid rgba(124,92,191,.2);border-radius:8px;padding:11px;font-size:12px;color:#b39ddb;margin-bottom:12px}

/* 로딩 */
.loading{text-align:center;padding:50px 20px}
.loading-icon{font-size:46px;margin-bottom:14px;display:inline-block;animation:spin 3s linear infinite}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.loading-txt{color:var(--g);font-size:15px;margin-bottom:13px;font-weight:600}
.loading-sub{color:var(--mu);font-size:12px;margin-top:10px}
.dots span{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--g);margin:0 3px;animation:bn 1.2s infinite}
.dots span:nth-child(2){animation-delay:.2s}
.dots span:nth-child(3){animation-delay:.4s}
@keyframes bn{0%,80%,100%{transform:translateY(0);opacity:.3}40%{transform:translateY(-8px);opacity:1}}

/* 반응형 */
@media(max-width:900px){.sidebar-ad,.sidebar-ad-right{display:none}}
@media(max-width:580px){
  .g2{grid-template-columns:1fr}
  .page{padding:14px}
  .u12g{grid-template-columns:repeat(2,1fr)}
  .ps-grid{grid-template-columns:repeat(2,1fr)}
  .fusion-grid{grid-template-columns:1fr}
  .worry-cats{grid-template-columns:repeat(3,1fr)}
  .oh-grid{gap:5px}
  .oh-n{font-size:20px}
}

/* ═══════════════════════════════════════════
   모바일 전용 UI 개선 (768px 이하)
═══════════════════════════════════════════ */
@media(max-width:768px){

  /* 헤더 간소화 */
  .app-hdr{padding:10px 14px;gap:8px}
  .hdr-logo{font-size:16px}
  .hdr-sub{font-size:10px;display:none}
  .hdr-chips{gap:4px}
  .chip{font-size:10px;padding:2px 7px}

  /* 탭 - 아이콘만 표시 */
  .tabs{-webkit-overflow-scrolling:touch}
  .tab{padding:10px 12px;font-size:12px}

  /* 페이지 패딩 줄이기 */
  .page{padding:10px}

  /* 카드 */
  .card{padding:14px;margin-bottom:10px;border-radius:8px}
  .sec{font-size:12px;margin-bottom:10px}

  /* 입력창 크게 */
  input,select,textarea{
    font-size:16px !important;
    padding:14px 13px !important;
    border-radius:10px;
  }

  /* 날짜+시각 한 줄 배치 */
  .dt-wrap, [style*="grid-template-columns:auto 1fr auto"]{
    display:flex !important;
    flex-wrap:wrap;
    gap:6px;
    align-items:center;
  }

  /* 성별 버튼 크게 */
  #gM, #gF{
    min-width:70px;
    padding:14px 10px !important;
    font-size:15px !important;
  }

  /* 저장/불러오기 버튼 */
  .g2{grid-template-columns:1fr 1fr;gap:8px}

  /* 운세 선택 버튼 - 3열 */
  .worry-cats{
    grid-template-columns:repeat(3,1fr) !important;
    gap:6px;
  }
  .wc-btn{padding:8px 4px;font-size:11px}
  .wc-emoji{font-size:18px}

  /* 손금 선택 */
  .palm-guide{grid-template-columns:1fr 1fr;gap:8px}
  .pg-box{padding:12px 8px}
  .pg-icon{font-size:30px;margin-bottom:6px}
  .pg-title{font-size:13px}
  .pg-desc{font-size:10px}

  /* 하단 버튼 3개 */
  [style*="grid-template-columns:1fr 1fr 2fr"]{
    grid-template-columns:1fr 1fr !important;
    gap:6px !important;
  }
  [style*="grid-template-columns:1fr 1fr 2fr"] button:last-child{
    grid-column:1/-1;
  }

  /* 메인 실행 버튼 */
  .gbtn{
    padding:16px 20px !important;
    font-size:16px !important;
    border-radius:12px;
  }

  /* 오행 바 */
  .oh-grid{grid-template-columns:repeat(5,1fr);gap:4px}
  .oh-box{padding:8px 4px}
  .oh-n{font-size:18px}
  .oh-l{font-size:10px}

  /* 사주 원국 테이블 */
  .pt td{padding:6px 2px;font-size:11px}
  .hj{font-size:22px}
  .ph{font-size:10px}
  .e-badge{font-size:10px;padding:1px 4px}

  /* 대운 가로 스크롤 */
  .dw-row{gap:6px}
  .dw-box{min-width:60px;padding:8px 5px}
  .dw-hj{font-size:15px}

  /* 세운/월운 테이블 */
  table{font-size:12px}
  th,td{padding:6px 4px !important}

  /* AI 해석 */
  .ai-sec{padding:12px;margin-bottom:8px}
  .ai-t{font-size:12px}
  .ai-body{font-size:13px;line-height:1.9}

  /* 손금 링 */
  .ps-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .ring-wrap{width:60px;height:60px}
  .ring-svg{width:60px;height:60px}

  /* 융합 점수 */
  .fusion-grid{grid-template-columns:1fr 1fr}

  /* 로딩 */
  .loading{padding:30px 16px}
  .loading-icon{font-size:36px}
  .loading-txt{font-size:14px}

  /* 법적고지 */
  .legal-notice{font-size:10px;padding:10px}

  /* 스크롤바 숨기기 */
  ::-webkit-scrollbar{width:3px;height:3px}
  ::-webkit-scrollbar-track{background:transparent}
  ::-webkit-scrollbar-thumb{background:rgba(201,168,76,.3);border-radius:3px}
}

/* 아주 작은 화면 (400px 이하) */
@media(max-width:400px){
  .worry-cats{grid-template-columns:repeat(2,1fr) !important}
  .tab{padding:8px 8px;font-size:11px}
  .oh-grid{grid-template-columns:repeat(3,1fr)}
  .ps-grid{grid-template-columns:1fr 1fr}
}
