/* /public/assets/css/style.css */
@import url('https://fonts.googleapis.com/css2?family=Pretendard:wght@400;500;600;700&display=swap');

:root{
  --bg1:#0a0d14; --bg2:#141926; --panel:#0f1320; --card:#0f1220;
  --text:#f2f4f8; --muted:#c0c6d0; --faint:#8b94a4;
  --primary:#7c5cff; --accent:#25d0b4;
  --border:rgba(255,255,255,0.12); --border-strong:rgba(255,255,255,0.2);
  --panel-tint:rgba(255,255,255,0.03); --badge-bg:rgba(0,0,0,0.5);
}

*{box-sizing:border-box}
html,body{height:100%}

body.bg-deep{
  margin:0;
  background:
    radial-gradient(1200px 600px at 75% -10%, rgba(124,92,255,0.14), transparent 60%),
    radial-gradient(1000px 500px at 10% 110%, rgba(37,208,180,0.10), transparent 60%),
    linear-gradient(180deg, var(--bg1), var(--bg2));
  color:var(--text);
  font-family:'Pretendard',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:16px; line-height:1.6;
}

/* 타이틀/패널 */
.site-title{font-weight:700;letter-spacing:.2px;font-size:1.75rem}
.site-subtitle{color:#c8cfdb;font-size:.98rem} /* 대비↑ */
.card-panel{background:linear-gradient(180deg,var(--panel-tint),rgba(255,255,255,0.02));border:1px solid var(--border);border-radius:16px;backdrop-filter:blur(6px)}

/* 폼/버튼 */
.form-label{color:var(--text);font-weight:600;font-size:.95rem}
.form-text{color:#c8cfdb!important}
.form-control-dark,.form-select.form-control-dark{background:var(--panel);border-color:var(--border);color:var(--text)}
.form-control-dark::placeholder{color:#9aa3b2}
.btn{font-weight:600}
.btn-primary{background:var(--primary);border-color:var(--primary)}
.btn-primary:hover{filter:brightness(1.06)}
.btn-outline-light{color:#e9ecf3;border-color:rgba(255,255,255,0.28)}
.btn-outline-light:hover{color:#fff;border-color:rgba(255,255,255,0.45);background:rgba(255,255,255,0.06)}
.btn-check:checked + .btn-outline-light,
.btn-outline-light.active{background:var(--primary);border-color:var(--primary);color:#fff!important;box-shadow:0 0 0 3px rgba(124,92,255,0.25)}
.btn-outline-secondary{color:var(--muted);border-color:var(--border)}
.btn-glow{box-shadow:0 0 0 rgba(124,92,255,0);transition:box-shadow .2s}
.btn-glow:hover{box-shadow:0 0 24px rgba(124,92,255,0.35)}

/* 섹션 헤더/구분선 */
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}
.section-head .title{font-size:1.1rem;font-weight:700;color:#eef1f7} /* 대비↑ */
.divider{border-top:1px solid var(--border-strong);margin:.5rem 0 1rem}

/* 카드 플립 공통 */
.card-flip{position:relative;width:100%;aspect-ratio:7/11;transform-style:preserve-3d;transition:transform .8s cubic-bezier(.2,.7,.1,1)}
.card-flip.show-front{transform:rotateY(0deg)}
.card-flip.show-back{transform:rotateY(180deg)}
.card-face{position:absolute;inset:0;backface-visibility:hidden;border-radius:12px;overflow:hidden;border:1px solid var(--border);background:#0e1018}
.card-face img{width:100%;height:100%} /* 포머님 규칙 */
.card-face.back{transform:rotateY(180deg);background:#0a0c14}
.card-badge{position:absolute;top:10px;left:10px;background:linear-gradient(180deg,rgba(0,0,0,0.55),rgba(0,0,0,0.35));color:#fff;padding:6px 10px;border-radius:10px;font-size:.85rem;font-weight:600;letter-spacing:.2px;border:1px solid rgba(255,255,255,0.08);text-shadow:0 1px 1px rgba(0,0,0,0.6)}

/* 결과 리스트(카드 + 넓은 해설) */
.results-list{display:flex;flex-direction:column;gap:18px}
.result-item{display:flex;gap:22px;align-items:flex-start;padding:16px;background:rgba(255,255,255,0.03);border:1px solid var(--border);border-radius:14px}
.result-figure{width:clamp(180px,18vw,220px)}
.result-content{flex:1;min-width:0;max-width:1200px}
.result-title{font-weight:700;margin-bottom:8px;color:#eaeef6}
.meaning-panel{background:rgba(255,255,255,0.03);border:1px solid var(--border);border-radius:10px;padding:14px 16px;width:100%;max-width:none}
.meaning{color:var(--muted);line-height:1.78;word-break: keep-all;overflow-wrap: anywhere;}
.meaning.clamp-6{display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}
.meaning.clamp-6.expanded{display:block}
.btn-more{color:var(--muted);text-decoration:underline;font-size:.92rem;margin-top:6px}
.advice-pill{display:inline-block;background:rgba(37,208,180,0.12);border:1px solid rgba(37,208,180,0.25);color:#d8fff6;padding:6px 10px;border-radius:999px;font-size:.86rem;margin-bottom:6px}

/* 상단 해석(간결) */
#interpretation{white-space:pre-line;color:var(--text);background:rgba(255,255,255,0.035);border:1px solid var(--border);border-radius:12px;padding:14px 16px;font-size:1rem;line-height:1.75}

/* 모바일 UX(가독 최적화) */
@media (max-width:576px){
  /* 베이스 가독성 */
  body{font-size:17px; line-height:1.78}
  .btn-group .btn{padding:12px 16px;min-width:92px;border-radius:10px!important}
  .form-control-dark,.form-select.form-control-dark{padding:13px 14px;font-size:16px}

  /* 설정 섹션 간격 */
  .card-panel .row.g-3 > [class*="col-"]{margin-bottom:6px}
  .section-head{margin-bottom:.5rem}
  .divider{margin:.25rem 0 .75rem}

  /* 결과: 카드 위/해설 아래로 스택 */
  .result-item{padding:12px;gap:12px;flex-direction:column}
  .result-figure{width:76vw;max-width:360px;margin:0 auto}
  .result-content{max-width:100%}
  .meaning-panel{padding:14px 14px}
  .meaning{font-size:16.5px; line-height:1.88; word-break: keep-all;overflow-wrap: anywhere;}

  /* 오버레이 컨트롤 */
  .picker-controls{flex-wrap:wrap;gap:8px;justify-content:center}
  .picker-title,.picker-hint{text-align:center}
  .fan-deck{height:min(440px,60vh)}
  .ring-deck{width:min(94vw,860px);height:min(66vh,580px)}
}

/* 푸터/접근성 */
footer{color:var(--faint)}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* 오버레이 공통 */
.picker-overlay{position:fixed;inset:0;z-index:1050;background:radial-gradient(60% 60% at 50% 40%, rgba(15,19,32,0.96), rgba(10,12,20,0.98));display:none}
.picker-inner{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:24px}
.picker-controls{display:flex;gap:10px}
.picker-title{font-size:1.2rem;font-weight:700;color:var(--text)}
.picker-hint{color:var(--muted);font-size:.95rem}

/* 부채꼴(카드 바깥쪽으로만 밀려 나가게) */
.fan-deck{
    position: relative;
    width: min(1100px, 92vw);
    height: min(380px, 52vh);
  }
  
  /* 기본 카드 */
  .fan-card{
    position: absolute;
    top: 50%; left: 50%;
    --angle: 0deg;           /* 각 카드 고유 회전각 */
    --z: 100;                /* 초기 쌓임 순서(hover/선택 시 변경하지 않음) */
    width: clamp(90px, 12vw, 140px);
    aspect-ratio: 7/11;
    transform: translate(-50%, -50%) rotate(var(--angle));  /* 회전만 적용(반경 이동 없음) */
    transform-origin: center 90%;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--border-strong);
    background: #0a0c14;
    box-shadow: 0 10px 30px rgba(0,0,0,0.35);
    cursor: pointer;
    transition: transform .22s ease, box-shadow .22s ease, opacity .22s ease, filter .22s ease;
    z-index: var(--z);        /* hover/선택 시 z-index 그대로 유지 */
    will-change: transform;
  }
  .fan-card img{ width:100%; height:100%; }
  
  /* 오버: 로컬 축 기준 위쪽(=부채 바깥쪽)으로만 살짝 밀어냄 */
  .fan-card.is-target{
    transform: translate(-50%, -50%) rotate(var(--angle)) translateY(-16px) scale(1.03);
    box-shadow: 0 14px 40px rgba(124,92,255,0.35);
    /* z-index 변경 없음 */
  }
  
  /* 선택: 같은 방향으로 조금 더 멀리 밀어냄 */
  .fan-card.is-picked{
    transform: translate(-50%, -50%) rotate(var(--angle)) translateY(-24px) scale(1.06);
    box-shadow: 0 18px 54px rgba(124,92,255,0.55), 0 0 0 1px rgba(255,255,255,0.08);
    /* z-index 변경 없음 */
  }

/* 원형 모드 전환 */
.picker-overlay.mode-circle .fan-deck{display:none!important}
.picker-overlay.mode-circle .ring-deck{display:block!important}

/* 원형 덱 */
.ring-deck{
  position:relative;display:none;width:min(820px,92vw);height:min(520px,72vh);margin:0 auto;border-radius:16px;
  background:radial-gradient(60% 50% at 50% 45%, rgba(255,255,255,0.04), rgba(255,255,255,0.0)), linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.02));
  border:1px solid var(--border);box-shadow:inset 0 0 60px rgba(0,0,0,0.35)
}
.ring-halo{position:absolute;inset:0;pointer-events:none;background:radial-gradient(closest-side, rgba(124,92,255,0.18), rgba(124,92,255,0.02) 55%, transparent 60%), radial-gradient(closest-side, rgba(37,208,180,0.14), rgba(37,208,180,0.02) 45%, transparent 50%);mask-image:radial-gradient(closest-side, rgba(0,0,0,0.9), transparent 65%);opacity:.65}
.ring-pointer{position:absolute;top:50%;left:50%;width:8px;height:8px;margin:-4px 0 0 -4px;background:var(--accent);border-radius:50%;box-shadow:0 0 0 6px rgba(37,208,180,0.15);pointer-events:none}

.ring-card{
  position:absolute;top:50%;left:50%;
  width:clamp(90px,10.8vw,140px);aspect-ratio:7/11;
  --angle:0deg; --radius:200px; --z:100;
  transform:translate(-50%,-50%) rotate(var(--angle)) translate(var(--radius)) rotate(calc(-1 * var(--angle)));
  transform-origin:center center;
  border-radius:12px;overflow:hidden;background:#0a0c14;border:1px solid var(--border-strong);
  box-shadow:0 10px 30px rgba(0,0,0,0.35);transition:transform .25s, box-shadow .25s, opacity .25s, filter .25s;cursor:pointer;z-index:var(--z)
}
.ring-card img{width:100%;height:100%}
.ring-card.is-target{transform:translate(-50%,-50%) rotate(var(--angle)) translate(calc(var(--radius) + 14px)) rotate(calc(-1 * var(--angle))) translateY(-12px) scale(1.06)}
.ring-card.is-picked{transform:translate(-50%,-50%) rotate(var(--angle)) translate(calc(var(--radius) + 24px)) rotate(calc(-1 * var(--angle))) translateY(-14px) scale(1.1);box-shadow:0 18px 54px rgba(124,92,255,0.55),0 0 0 2px rgba(124,92,255,0.45) inset,0 0 0 1px rgba(255,255,255,0.08);z-index:400}
.ring-card.is-dim{opacity:.35;filter:grayscale(.25)}