*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --sky:#F0F6FF;
  --white:#FFFFFF;
  --mist:#E8F0F8;
  --slate:#8A9AB0;
  --navy:#1A2B3C;
  --blue:#3B7DD8;
  --blue-light:#EBF2FF;
  --border:#D8E4F0;
  --gold:#C9A84C;
  --gold-pale:#FBF5E6;
  --gold-mid:#E8C87A;
}
body{font-family:'Inter',sans-serif;background:var(--navy);color:var(--navy);min-height:100vh;}

.screen{display:none;min-height:100vh;flex-direction:column;max-width:1200px;margin:0 auto;background:var(--white);border-left:1px solid var(--border);border-right:1px solid var(--border);}
.screen.active{display:flex;}

/* NAV */
.home-nav{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:var(--white);border-bottom:1px solid var(--border);}
.logo{font-family:'Cormorant Garamond',serif;font-size:1.7rem;font-weight:600;letter-spacing:0.02em;color:var(--gold);display:flex;align-items:center;}
.nav-tag{font-size:0.65rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);background:var(--gold-pale);border:1px solid var(--gold-mid);padding:4px 12px;border-radius:20px;}

/* HERO */
.home-hero{padding:3rem 2rem 2rem;background:var(--white);border-bottom:1px solid var(--border);position:relative;overflow:hidden;}
.hero-eyebrow{font-size:0.65rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--blue);font-weight:500;margin-bottom:1rem;}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2.4rem,7vw,3.6rem);line-height:1.05;font-weight:600;margin-bottom:0.9rem;color:var(--navy);}
.hero-title .outlined{color:#fff;-webkit-text-stroke:1.5px var(--navy);paint-order:stroke fill;}
.hero-title em{font-style:italic;color:var(--gold);}
.hero-sub{font-size:0.88rem;color:var(--slate);line-height:1.7;max-width:300px;margin-bottom:2rem;font-weight:300;}
.hero-cta{display:inline-flex;align-items:center;gap:8px;background:var(--navy);color:var(--white);padding:0.75rem 1.5rem;border-radius:3px;font-size:0.75rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;border:none;transition:background 0.2s;}
.hero-cta:hover{background:#253d52;}
.hero-plane {
  position: absolute;
  top: 75%;
  left: 20%;
  font-size: 3rem;
  opacity: 0.3;
  animation: fly-once 3.5s ease-out forwards;
}
@keyframes fly-once {
  0% {
    transform: translate(0, 0) rotate(-10deg);
    opacity: 0.3;
  }
  50% {
    transform: translate(200px, -60px) rotate(5deg);
    opacity: 0.4;
  }
  100% {
    transform: translate(500px, -120px) rotate(10deg);
    opacity: 0;
  }
}
.hero-plane {
  offset-rotate: auto;
}
.hero-plane::after {
  content: "";
  position: absolute;
  width: 120px;
  height: 2px;
  left: -120px;
  top: 50%;
  background: repeating-linear-gradient(
    to right,
    rgba(26,43,60,0.3) 0 6px,
    transparent 6px 12px
  );
}
.cloud{position:absolute;right:5%;font-size:2.2rem;opacity:0.12;pointer-events:none;animation:cloud-drift 6s ease-in-out infinite;}
.cloud1{top:8%;animation-delay:0s;}
@keyframes cloud-drift{
  0%{transform:translateX(0);}
  50%{transform:translateX(-6px);}
  100%{transform:translateX(0);}
}

/* MODE CARDS */
.modes-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);}
.mode-card{background:var(--white);padding:0;cursor:pointer;position:relative;overflow:hidden;min-height:140px;display:flex;flex-direction:column;transition:all 0.2s;box-shadow:0 2px 12px rgba(26,43,60,0.08);}
.mode-card:hover{box-shadow:0 6px 24px rgba(26,43,60,0.15);}
.mode-card-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 0.3s;}
.mode-card:hover .mode-card-bg{opacity:1;}
.mode-content{position:relative;z-index:2;padding:1.1rem 1.1rem 0.9rem;flex:1;display:flex;flex-direction:column;justify-content:flex-end;}
.mode-arrow{position:absolute;top:0.9rem;right:0.9rem;font-size:0.68rem;color:var(--slate);transition:color 0.2s,transform 0.2s;}
.mode-card:hover .mode-arrow{color:#fff;transform:translate(2px,-2px);}
.mode-label-box{background:rgba(255,255,255,0.85);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border-radius:6px;padding:0.5rem 0.9rem;display:inline-flex;flex-direction:column;gap:2px;transition:background 0.2s;align-self:flex-start;box-shadow:0 2px 12px rgba(26,43,60,0.25);}
.mode-card:hover .mode-label-box{background:rgba(255,255,255,0.95);}
.mode-label{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:600;color:var(--navy);}
.mode-desc{font-size:0.67rem;color:var(--slate);font-weight:300;}
.mode-card[data-color="blue"]:not(:hover){background:#F0F6FF;}

/* STATS */
.stats-bar{display:flex;gap:2.5rem;padding:1rem 2rem;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--white);}
.stat-num{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:600;color:var(--gold);}
.stat-lbl{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--slate);}

/* SHARED HEADER */
.screen-header{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);background:var(--white);}
.back-btn{background:none;border:1px solid var(--border);border-radius:50%;width:34px;height:34px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:0.9rem;color:var(--navy);flex-shrink:0;transition:border-color 0.15s;}
.back-btn:hover{border-color:var(--blue);}
.screen-title{font-family:'Cormorant Garamond',serif;font-size:1.35rem;font-weight:600;color:var(--navy);}

/* VIBE PICKER */
#vibe-picker{background:var(--sky);}
.vibe-grid{display:grid;grid-template-columns:1fr 1fr;gap:0.75rem;padding:1.25rem;flex:1;}
.vibe-chip{border:1.5px solid var(--border);border-radius:6px;padding:0;cursor:pointer;transition:all 0.18s;text-align:center;overflow:hidden;position:relative;min-height:110px;display:flex;flex-direction:column;}
.vibe-chip-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0.7;transition:opacity 0.25s;}
.vibe-chip:hover .vibe-chip-bg,.vibe-chip.selected .vibe-chip-bg{opacity:1;}
.vibe-chip:hover,.vibe-chip.selected{border-color:var(--blue);}
.vibe-chip-inner{position:relative;z-index:1;padding:1rem 0.75rem;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.vibe-label-box{background:rgba(255,255,255,0.85);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border-radius:6px;padding:0.5rem 0.9rem;display:flex;flex-direction:column;align-items:center;gap:2px;transition:background 0.2s;box-shadow:0 2px 12px rgba(26,43,60,0.25);}
.vibe-chip:hover .vibe-label-box,.vibe-chip.selected .vibe-label-box{background:rgba(255,255,255,0.95);}
.vibe-name{font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:600;color:var(--navy);}
.vibe-sub{font-size:0.66rem;color:var(--slate);margin-top:2px;}
.continue-btn{margin:0 1.25rem 1.75rem;background:var(--navy);color:#fff;border:none;padding:0.9rem;font-size:0.75rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;border-radius:3px;width:calc(100% - 2.5rem);opacity:0.35;transition:opacity 0.2s;}
.continue-btn.ready{opacity:1;}

/* SWIPE */
#swipe-mode{background:var(--sky);overflow-y:auto;}
.swipe-arena{position:relative;width:min(300px,88vw);height:420px;display:flex;align-items:center;justify-content:center;overflow:visible;}
.swipe-card{width:min(300px,88vw);background:var(--white);border-radius:10px;border:1px solid var(--border);overflow:hidden;position:absolute;cursor:grab;user-select:none;transition:transform 0.4s cubic-bezier(0.175,0.885,0.32,1.275);}
.swipe-card.top{z-index:3;}.swipe-card.mid{z-index:2;transform:scale(0.96) translateY(10px);}.swipe-card.back{z-index:1;transform:scale(0.92) translateY(20px);}
.swipe-card.exit-left{transform:translateX(-120%) rotate(-12deg) !important;transition:transform 0.32s ease-in;}
.swipe-card.exit-right{transform:translateX(120%) rotate(12deg) !important;transition:transform 0.32s ease-in;}
.card-img{height:260px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--mist);}
.card-region{position:absolute;top:0.75rem;left:0.75rem;background:rgba(255,255,255,0.92);border:1px solid var(--border);font-size:0.58rem;font-weight:500;letter-spacing:0.09em;text-transform:uppercase;color:var(--blue);padding:3px 9px;border-radius:2px;z-index:2;}
.card-info{padding:1rem 1.1rem 1.1rem;border-top:1px solid var(--border);}
.card-name{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:600;margin-bottom:3px;color:var(--navy);}
.card-detail{font-size:0.72rem;color:var(--slate);font-weight:300;}
.swipe-actions{display:flex;gap:1.5rem;padding:0.75rem 0 1.25rem;z-index:10;position:relative;justify-content:center;width:min(300px,88vw);}
.swipe-btn{width:52px;height:52px;border-radius:50%;border:1.5px solid var(--border);background:var(--white);cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:all 0.15s;}
.swipe-btn:hover{transform:scale(1.1);}
.swipe-btn.nope{border-color:#E24B4A;}.swipe-btn.yes{border-color:#1D9E75;}
.swipe-progress{font-size:0.68rem;color:var(--slate);text-align:center;padding-bottom:0.5rem;}

/* SPIN */
#spin-mode{background:var(--sky);}
.spin-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:1.5rem;gap:1.5rem;overflow-y:auto;}
.wheel-wrap{position:relative;width:min(280px,78vw);height:min(280px,78vw);}
#wheel-canvas{display:block;}
.wheel-pointer{position:absolute;top:-10px;left:50%;transform:translateX(-50%);font-size:1.4rem;z-index:10;}
.spin-result{background:var(--white);border:1px solid var(--navy);border-radius:8px;padding:1.1rem 1.5rem;text-align:center;width:min(280px,88vw);min-height:64px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;box-shadow:0 4px 16px rgba(201,168,76,0.18);}
.spin-result-label{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.12em;color:var(--gold);}
.spin-result-name{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:600;color:var(--navy);}
.spin-btn{background:var(--navy);color:#fff;border:none;padding:0.8rem 2.2rem;font-size:0.75rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;border-radius:3px;transition:background 0.2s;}
.spin-btn:hover{background:#253d52;}.spin-btn:disabled{opacity:0.4;cursor:not-allowed;}

/* BRACKET */
#bracket-mode{background:var(--sky);}
.bracket-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;gap:1.5rem;}
.bracket-round{font-size:0.72rem;text-transform:uppercase;letter-spacing:0.13em;color:var(--gold);font-weight:500;text-align:center;}
.bracket-vs{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;width:100%;max-width:480px;}
.bracket-card{background:var(--white);border:1.5px solid var(--border);border-radius:8px;overflow:hidden;cursor:pointer;transition:all 0.18s;}
.bracket-card:hover{border-color:var(--blue);transform:scale(1.02);}
.bracket-card-img{height:160px;overflow:hidden;background:var(--mist);}
.bracket-card-foot{padding:0.75rem 0.5rem;text-align:center;}
.bracket-card-name{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:600;color:var(--navy);}
.vs-divider{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-style:italic;color:var(--slate);}
.bracket-progress{width:100%;max-width:480px;background:var(--border);border-radius:10px;height:3px;overflow:hidden;}
.bracket-bar{height:100%;background:var(--gold);border-radius:10px;transition:width 0.4s;}
.bracket-sub{font-size:0.78rem;color:var(--slate);text-align:center;max-width:480px;}

/* QUIZ */
#ai-mode{background:var(--sky);}
.quiz-container{flex:1;display:flex;flex-direction:column;overflow-y:auto;}

/* DOTS */
.dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:bounce 1.2s infinite;display:inline-block;}
.dot:nth-child(2){animation-delay:0.2s;}.dot:nth-child(3){animation-delay:0.4s;}
@keyframes bounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-7px)}}