/* ========================================
   DREAM ORACLE — style.css
   ======================================== */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --ink: #0d0d1a;
  --paper: #f5f0eb;
  --mist: #c9c0d3;
  --dusk: #6e5f8a;
  --moon: #e8dff5;
  --star: #b8a9d0;
  --glass: rgba(245,240,235,0.06);
}

html { scroll-behavior: smooth; }

body {
  font-family: 'Raleway', sans-serif;
  background: var(--ink);
  color: var(--paper);
  min-height: 100vh;
  overflow-x: hidden;
}

/* ---- COSMOS BACKGROUND ---- */
.cosmos {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background: radial-gradient(ellipse at 30% 20%, #1a0d2e 0%, #0d0d1a 50%, #0a0a18 100%);
  overflow: hidden;
}
.nebula {
  position: absolute; border-radius: 50%;
  filter: blur(80px); opacity: 0.18;
  animation: drift 20s ease-in-out infinite alternate;
}
.nebula-1 { width:600px; height:400px; top:-10%; left:-10%; background:radial-gradient(circle,#6b3fa0,transparent 70%); animation-duration:25s; }
.nebula-2 { width:500px; height:500px; bottom:-10%; right:-5%; background:radial-gradient(circle,#2d5a8e,transparent 70%); animation-duration:30s; animation-delay:-8s; }
.nebula-3 { width:350px; height:350px; top:40%; left:40%; background:radial-gradient(circle,#8e3a6b,transparent 70%); animation-duration:22s; animation-delay:-4s; }
#starCanvas { position:absolute; inset:0; width:100%; height:100%; }

/* ---- KEYFRAMES ---- */
@keyframes drift { 0%{transform:translate(0,0) scale(1)} 100%{transform:translate(40px,25px) scale(1.08)} }
@keyframes fadeUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
@keyframes shimmer { 0%{background-position:-200% center} 100%{background-position:200% center} }
@keyframes pulse-ring { 0%,100%{box-shadow:0 0 0 0 rgba(180,160,220,0.3)} 50%{box-shadow:0 0 0 12px rgba(180,160,220,0)} }
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
@keyframes spin { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }
@keyframes barGrow { from{width:0} to{width:var(--target-width)} }

/* ---- PAGE ---- */
.page {
  position: relative; z-index: 1;
  min-height: 100vh;
  display: flex; flex-direction: column; align-items: center;
  padding: 0 24px 80px;
}

/* ---- ADS ---- */
.ad-banner-top, .ad-banner-bottom {
  width: 100%; max-width: 728px;
  background: rgba(255,255,255,0.04);
  border: 1px dashed rgba(180,160,220,0.2); border-radius: 8px;
  min-height: 90px; display: flex; align-items: center; justify-content: center;
}
.ad-banner-top { margin: 16px auto 0; }
.ad-banner-bottom { margin-top: 32px; }

.ad-placeholder-label {
  color: rgba(180,160,220,0.35); font-size: 11px;
  letter-spacing: 2px; text-transform: uppercase;
}

.ad-sidebar { width: 160px; flex-shrink: 0; display: flex; flex-direction: column; gap: 16px; position: sticky; top: 40px; padding-top: 20px; }
.ad-box { background: rgba(255,255,255,0.03); border: 1px dashed rgba(180,160,220,0.15); border-radius: 12px; display: flex; align-items: center; justify-content: center; text-align: center; padding: 8px; }
.ad-sidebar-main  { min-height: 600px; }
.ad-sidebar-small { min-height: 250px; }

/* ---- HEADER ---- */
.header { text-align: center; padding: 60px 0 40px; animation: fadeUp 1s ease both; }
.moon-icon { font-size: 48px; display: block; margin: 0 auto 20px; animation: float 4s ease-in-out infinite; filter: drop-shadow(0 0 20px rgba(180,160,220,0.6)); }
.title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(48px, 8vw, 88px); font-weight: 300; font-style: italic;
  letter-spacing: -1px; line-height: 0.95;
  background: linear-gradient(135deg,#e8dff5 0%,#b8a9d0 40%,#e8dff5 70%,#c9c0d3 100%);
  background-size: 200% auto; -webkit-background-clip: text;
  -webkit-text-fill-color: transparent; background-clip: text;
  animation: shimmer 6s linear infinite;
}
.subtitle { font-size: 12px; letter-spacing: 5px; text-transform: uppercase; color: var(--star); font-weight: 200; margin-top: 14px; opacity: 0.7; }

/* ---- LAYOUT ---- */
.layout { display: flex; gap: 24px; width: 100%; max-width: 1100px; justify-content: center; align-items: flex-start; }
.main-col { flex: 1; max-width: 720px; display: flex; flex-direction: column; align-items: center; }

/* ---- INPUT CARD ---- */
.card {
  width: 100%; background: var(--glass);
  border: 1px solid rgba(180,160,220,0.15); border-radius: 24px;
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  padding: 40px; animation: fadeUp 1s 0.2s ease both;
  position: relative; overflow: hidden;
}
.card::before { content:''; position:absolute; top:-1px; left:20%; right:20%; height:1px; background:linear-gradient(90deg,transparent,rgba(180,160,220,0.6),transparent); }
.card-label { font-size: 10px; letter-spacing: 4px; text-transform: uppercase; color: var(--star); opacity: 0.6; margin-bottom: 16px; display: block; }

.dream-textarea {
  width: 100%; min-height: 180px;
  background: rgba(13,13,26,0.5); border: 1px solid rgba(180,160,220,0.12);
  border-radius: 16px; color: var(--paper);
  font-family: 'Cormorant Garamond', serif;
  font-size: 20px; font-weight: 300; line-height: 1.7;
  padding: 20px 24px; resize: none; outline: none;
  transition: border-color 0.3s, box-shadow 0.3s;
}
.dream-textarea::placeholder { color: rgba(180,160,220,0.3); font-style: italic; }
.dream-textarea:focus { border-color: rgba(180,160,220,0.4); box-shadow: 0 0 0 4px rgba(110,95,138,0.1), inset 0 0 30px rgba(110,95,138,0.05); }
.char-count { text-align: right; font-size: 11px; color: rgba(180,160,220,0.3); margin-top: 8px; letter-spacing: 1px; }

/* ---- BUTTON ---- */
.interpret-btn {
  width: 100%; margin-top: 24px; padding: 18px 32px;
  background: linear-gradient(135deg,#3d2b5e 0%,#5a3d82 50%,#3d2b5e 100%);
  background-size: 200% auto; border: 1px solid rgba(180,160,220,0.25);
  border-radius: 100px; color: var(--moon);
  font-family: 'Raleway', sans-serif; font-size: 13px; font-weight: 300;
  letter-spacing: 4px; text-transform: uppercase; cursor: pointer;
  transition: all 0.4s; animation: pulse-ring 3s ease-in-out infinite;
}
.interpret-btn:hover:not(:disabled) { background-position: right center; box-shadow: 0 8px 40px rgba(110,95,138,0.5); transform: translateY(-2px); }
.interpret-btn:disabled { opacity: 0.4; cursor: not-allowed; animation: none; }

/* ---- LOADING ---- */
.loading-state { text-align: center; padding: 32px 20px 8px; }
.loading-orb { width: 60px; height: 60px; margin: 0 auto 0; border-radius: 50%; background: radial-gradient(circle,#6e5f8a,#2d1b4e); animation: float 2s ease-in-out infinite; }
.loading-ring { width: 80px; height: 80px; margin: -70px auto 0; border-radius: 50%; border: 1px solid rgba(180,160,220,0.3); border-top-color: rgba(180,160,220,0.8); animation: spin 2s linear infinite; }
.loading-text { font-family: 'Cormorant Garamond', serif; font-size: 20px; font-style: italic; color: var(--star); letter-spacing: 1px; margin-top: 20px; }
.loading-sub { font-size: 11px; letter-spacing: 3px; color: rgba(180,160,220,0.4); margin-top: 8px; text-transform: uppercase; }

.error-msg { text-align: center; color: rgba(200,100,120,0.8); margin-top: 16px; font-size: 14px; font-family: 'Raleway', sans-serif; }

/* ---- RESULT ---- */
.result-card { width: 100%; animation: fadeUp 0.8s ease both; }
.result-section {
  background: var(--glass); border: 1px solid rgba(180,160,220,0.12);
  border-radius: 20px; backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  padding: 32px 36px; margin-bottom: 16px; position: relative; overflow: hidden;
}
.result-section::before { content:''; position:absolute; top:-1px; left:15%; right:15%; height:1px; background:linear-gradient(90deg,transparent,rgba(180,160,220,0.5),transparent); }

.section-tag {
  font-size: 9px; letter-spacing: 5px; text-transform: uppercase;
  color: var(--dusk); opacity: 0.8; display: flex; align-items: center; gap: 8px; margin-bottom: 16px;
}
.section-tag::after { content:''; flex:1; height:1px; background:linear-gradient(90deg,rgba(110,95,138,0.3),transparent); }

.section-title { font-family: 'Cormorant Garamond', serif; font-size: 28px; font-weight: 300; font-style: italic; color: var(--moon); margin-bottom: 16px; }
.section-body { font-family: 'Cormorant Garamond', serif; font-size: 18px; font-weight: 300; line-height: 1.85; color: rgba(245,240,235,0.85); }
.archetype-text { font-family: 'Cormorant Garamond', serif; font-size: 32px; font-style: italic; font-weight: 300; color: var(--moon); }

/* ---- SYMBOLS ---- */
.symbols-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px,1fr)); gap: 12px; margin-top: 4px; }
.symbol-chip { background: rgba(110,95,138,0.12); border: 1px solid rgba(180,160,220,0.15); border-radius: 12px; padding: 14px 16px; }
.symbol-name { font-family: 'Cormorant Garamond', serif; font-size: 17px; font-style: italic; color: var(--moon); margin-bottom: 4px; }
.symbol-meaning { font-size: 12px; font-weight: 300; color: rgba(180,160,220,0.7); line-height: 1.5; }

/* ---- EMOTION BARS ---- */
.emotion-bar-wrap { margin-bottom: 10px; }
.emotion-label { display: flex; justify-content: space-between; margin-bottom: 5px; }
.emotion-name { font-size: 12px; letter-spacing: 2px; text-transform: uppercase; color: var(--star); font-weight: 300; }
.emotion-pct { font-family: 'Cormorant Garamond', serif; font-size: 16px; color: var(--moon); font-style: italic; }
.bar-track { height: 3px; background: rgba(180,160,220,0.1); border-radius: 2px; overflow: hidden; }
.bar-fill { height: 100%; border-radius: 2px; background: linear-gradient(90deg,#6e5f8a,#b8a9d0); width: 0; transition: width 1.5s cubic-bezier(.4,0,.2,1); }

/* ---- GUIDANCE ---- */
.guidance-text { font-family: 'Cormorant Garamond', serif; font-size: 20px; font-style: italic; font-weight: 300; color: var(--moon); line-height: 1.8; text-align: center; padding: 8px 0; }

/* ---- RESET BUTTON ---- */
.reset-btn {
  display: block; margin: 8px auto 0; padding: 12px 32px;
  background: transparent; border: 1px solid rgba(180,160,220,0.2);
  border-radius: 100px; color: rgba(180,160,220,0.5);
  font-family: 'Raleway', sans-serif; font-size: 11px; letter-spacing: 3px;
  text-transform: uppercase; cursor: pointer; transition: all 0.3s;
}
.reset-btn:hover { border-color: rgba(180,160,220,0.5); color: var(--moon); }

/* ---- FOOTER ---- */
.footer { margin-top: 48px; text-align: center; font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: rgba(180,160,220,0.2); }

/* ---- RESPONSIVE ---- */
@media (max-width: 900px) {
  .ad-sidebar { display: none; }
}
@media (max-width: 600px) {
  .card { padding: 24px 20px; }
  .result-section { padding: 24px 20px; }
  .symbols-grid { grid-template-columns: 1fr 1fr; }
  .dream-textarea { font-size: 18px; }
}
