/* assets/css/app.css — Icebreak · Unified Design System */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,800;0,900;1,700;1,800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300&display=swap');

:root {
  --black:       #0B0B0B;
  --card:        #121212;
  --card2:       #1A1A1A;
  --card3:       #222222;
  --border:      rgba(255,255,255,0.07);
  --border2:     rgba(255,255,255,0.14);
  --orange:      #FF7A00;
  --orange-h:    #FF9A3D;
  --orange-glow: rgba(255,122,0,0.25);
  --orange-soft: rgba(255,122,0,0.08);
  --mag:         #C850C0;
  --grad:        linear-gradient(90deg, #C850C0, #FF7A00);
  --grad135:     linear-gradient(135deg, #C850C0, #FF7A00);
  --text:        #EAEAEA;
  --text2:       #777;
  --text3:       #3a3a3a;
  --green:       #34D399;
  --red:         #F87171;
  --amber:       #FFB800;
  --serif:       'Playfair Display', Georgia, serif;
  --sans:        'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --max:         1140px;
  --r:           16px;
  --r-sm:        10px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{background:var(--black);color:var(--text);font-family:var(--sans);font-weight:300;min-height:100vh;overscroll-behavior:none;-webkit-font-smoothing:antialiased}

body::after{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");opacity:.028;pointer-events:none;z-index:1000}

.app-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--black)}

@media(min-width:900px){
  .app-shell{flex-direction:row;max-width:var(--max);margin:0 auto;min-height:100vh;border-left:1px solid var(--border);border-right:1px solid var(--border)}
  .app-left{flex:0 0 58%;display:flex;flex-direction:column;border-right:1px solid var(--border);position:sticky;top:0;height:100vh;overflow-y:auto;scrollbar-width:none}
  .app-left::-webkit-scrollbar{display:none}
  .app-right{flex:0 0 42%;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:48px 40px;position:sticky;top:0;height:100vh;overflow:hidden;background:var(--card);position:relative}
  .app-right::before{content:'';position:absolute;top:-20%;right:-20%;width:400px;height:400px;background:radial-gradient(circle,rgba(200,80,192,.08) 0%,transparent 65%);pointer-events:none}
  .app-right::after{content:'';position:absolute;bottom:-20%;left:-10%;width:300px;height:300px;background:radial-gradient(circle,rgba(255,122,0,.06) 0%,transparent 65%);pointer-events:none}
}
@media(max-width:899px){.app-left{width:100%}.app-right{display:none}}

/* Status bar */
.status-bar{display:flex;justify-content:space-between;align-items:center;padding:14px 24px 4px;font-size:12px;font-weight:600;color:var(--text3);flex-shrink:0}
@media(min-width:900px){.status-bar{display:none}}

/* Desktop topbar */
.desktop-topbar{display:none}
@media(min-width:900px){
  .desktop-topbar{display:flex;align-items:center;justify-content:space-between;padding:22px 40px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
  .desktop-logo{font-family:var(--serif);font-size:20px;font-weight:700;color:var(--text);letter-spacing:.01em}
  .desktop-logo em{font-style:italic;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
  .desktop-step-label{font-size:11px;color:var(--text2);letter-spacing:.14em;text-transform:uppercase}
}

/* Progress */
.progress-wrap{padding:10px 24px 14px;flex-shrink:0}
@media(min-width:900px){.progress-wrap{padding:20px 40px 14px}}
.progress-track{height:2px;background:var(--card3);border-radius:2px;overflow:visible;position:relative}
.progress-fill{height:2px;background:var(--grad);border-radius:2px;transition:width .6s cubic-bezier(.4,0,.2,1);position:relative}
.progress-fill::after{content:'';position:absolute;right:-1px;top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:var(--mag);box-shadow:0 0 10px rgba(200,80,192,.5)}
.progress-label{font-size:11px;color:var(--text3);margin-top:8px;text-align:right;letter-spacing:.06em;text-transform:uppercase}
.progress-label.accent{color:var(--orange)}

/* Screen */
.screen-wrap{flex:1;display:flex;flex-direction:column}
.screen{flex:1;display:flex;flex-direction:column;padding:30px 24px 36px}
@media(min-width:900px){.screen{padding:44px 40px 52px}}

@keyframes fadeSlideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.animate-in{animation:fadeSlideUp .4s cubic-bezier(.25,.46,.45,.94) both}

/* Typography */
.screen__emoji{font-size:36px;margin-bottom:16px;display:block}
@media(min-width:900px){.screen__emoji{font-size:48px;margin-bottom:20px}}

.screen__label{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--text2);display:flex;align-items:center;gap:10px;margin-bottom:18px}
.screen__label::before{content:'';width:28px;height:1px;background:var(--grad);flex-shrink:0}

.screen__heading{font-family:var(--serif);font-size:clamp(30px,5.5vw,54px);line-height:1.0;letter-spacing:-.025em;color:var(--text);margin-bottom:20px}
.screen__heading .hl{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.screen__heading .hl-orange{color:var(--orange)}
.screen__heading em{font-style:italic}

.screen__sub{font-size:16px;line-height:1.7;color:var(--text2);margin-bottom:28px;font-weight:300}
@media(min-width:900px){.screen__sub{font-size:17px}}
.screen__sub strong{color:var(--text);font-weight:500}
.screen__sub--bottom{margin-top:16px;margin-bottom:20px}

/* CTA */
.screen__cta-wrap{margin-top:auto;padding-top:20px}
.cta-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:18px 28px;background:var(--grad);color:#fff;font-family:var(--sans);font-size:16px;font-weight:600;border:none;border-radius:var(--r);cursor:pointer;transition:opacity .15s,box-shadow .2s,transform .12s;text-decoration:none;text-align:center;-webkit-tap-highlight-color:transparent;user-select:none;letter-spacing:.01em;position:relative}
.cta-btn:hover{opacity:.88;transform:translateY(-2px);box-shadow:0 8px 40px rgba(200,80,192,.35)}
.cta-btn:active{transform:scale(.98)}
.cta-btn--full{width:100%;display:flex}
.cta-btn--grad{background:var(--grad);color:#fff}
.cta-btn--grad:hover{opacity:.88;box-shadow:0 8px 40px rgba(200,80,192,.35)}
.cta-arrow{transition:transform .2s}
.cta-btn:hover .cta-arrow{transform:translateX(4px)}

/* Right panel */
@media(min-width:900px){
  .right-step-visual{text-align:center;margin-bottom:32px;position:relative;z-index:1}
  .right-step-num{font-family:var(--serif);font-size:110px;line-height:1;font-weight:900;display:block;letter-spacing:-.04em;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:.18}
  .right-step-name{font-size:11px;color:var(--text3);letter-spacing:.16em;text-transform:uppercase;margin-top:-14px}
  .right-steps-list{width:100%;max-width:280px;display:flex;flex-direction:column;gap:0;position:relative;z-index:1}
  .right-step-item{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--border);font-size:13px;color:var(--text3);transition:color .2s}
  .right-step-item:first-child{border-top:1px solid var(--border)}
  .right-step-item.done{color:var(--text2)}
  .right-step-item.current{color:var(--text);font-weight:500}
  .right-step-dot{width:7px;height:7px;border-radius:50%;border:1px solid var(--border2);background:transparent;flex-shrink:0;transition:background .2s,box-shadow .2s}
  .right-step-item.done .right-step-dot{background:var(--mag);border-color:var(--mag)}
  .right-step-item.current .right-step-dot{background:var(--mag);border-color:var(--mag);box-shadow:0 0 8px rgba(200,80,192,.5)}
  .right-brand{margin-top:auto;font-family:var(--serif);font-size:16px;font-weight:700;color:var(--text3);letter-spacing:.01em;position:relative;z-index:1}
  .right-brand em{font-style:italic;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
}

/* Insight block in right panel (used via inline styles in PHP — keeping these for override) */
@media(min-width:900px){
  [style*="text-align:center"][style*="max-width:300px"] p:first-of-type{font-family:var(--serif);font-size:17px;font-weight:700;line-height:1.25}
}

/* Flip card */
.flip-card-wrap{flex:1;display:flex;align-items:center;justify-content:center;margin:16px 0}
.flip-card{width:100%;max-width:460px;height:230px;perspective:1200px;cursor:pointer}
.flip-card__inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,.2,.2,1)}
.flip-card.flipped .flip-card__inner{transform:rotateY(180deg)}
.flip-card__front,.flip-card__back{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--r);padding:32px 28px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;border:1px solid var(--border)}
.flip-card__front{background:var(--card)}
.flip-card__back{background:linear-gradient(145deg,#130a18,var(--card));border-color:rgba(200,80,192,.2);transform:rotateY(180deg)}
.tap-hint{font-size:11px;color:var(--text3);margin-bottom:14px;text-transform:uppercase;letter-spacing:.12em}
.flip-card__front p{font-size:15px;color:var(--text2);line-height:1.6}
.reveal-line{font-family:var(--serif);font-size:19px;font-weight:700;font-style:italic;color:var(--text);line-height:1.45;margin-bottom:14px}
.reveal-note{font-size:13px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* Choices */
.choices-list{display:flex;flex-direction:column;gap:10px;margin:16px 0;flex:1}
.choice-btn{width:100%;padding:16px 20px 16px 44px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text2);font-size:15px;font-weight:400;font-family:var(--sans);text-align:left;cursor:pointer;transition:border-color .15s,background .15s,color .15s;-webkit-tap-highlight-color:transparent;line-height:1.45;position:relative}
.choice-btn::before{content:'';position:absolute;left:16px;top:50%;transform:translateY(-50%);width:16px;height:16px;border-radius:50%;border:1px solid var(--border2);transition:border-color .15s,background .15s}
.choice-btn:hover{border-color:var(--border2);color:var(--text);background:var(--card2)}
.choice-btn.selected{border-color:rgba(200,80,192,.5);background:rgba(200,80,192,.07);color:var(--text)}
.choice-btn.selected::before{background:var(--grad);border-color:transparent;box-shadow:0 0 8px rgba(200,80,192,.4)}

/* Steps */
.steps-list{display:flex;flex-direction:column;gap:10px;margin:16px 0;flex:1}
.step-card{display:flex;align-items:flex-start;gap:16px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-sm);padding:18px 20px;animation:fadeSlideUp .4s ease both;transition:border-color .2s}
.step-card:hover{border-color:var(--border2)}
.step-num{width:30px;height:30px;background:var(--grad);color:#fff;font-size:12px;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.step-text{font-size:15px;color:var(--text);line-height:1.55;padding-top:3px}

/* Swipe */
.swipe-deck{position:relative;height:210px;margin:16px 0 14px;user-select:none}
.swipe-card{position:absolute;inset:0;background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:28px 24px;display:flex;flex-direction:column;justify-content:center;gap:12px;cursor:grab;z-index:0}
.swipe-signal{font-family:var(--serif);font-size:17px;font-weight:700;font-style:italic;color:var(--text)}
.swipe-verdict{font-size:15px;color:var(--text2);line-height:1.5}
.swipe-hint{font-size:11px;color:var(--text3);text-align:center;letter-spacing:.06em;text-transform:uppercase}
.swipe-counter{font-size:12px;color:var(--text3);text-align:center;margin-top:6px}

/* Chat */
.screen--chat{padding-bottom:20px}
.chat-window{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding:12px 0;scroll-behavior:smooth;min-height:180px}
.chat-bubble{max-width:78%;padding:11px 16px;border-radius:18px;font-size:15px;line-height:1.45;animation:fadeSlideUp .25s ease both}
.chat-bubble--you{background:var(--grad);color:#fff;align-self:flex-end;border-bottom-right-radius:4px;font-weight:400}
.chat-bubble--her{background:var(--card2);color:var(--text);align-self:flex-start;border-bottom-left-radius:4px;border:1px solid var(--border)}
.chat-typing{display:flex;align-items:center;gap:4px;padding:12px 16px}
.chat-typing span{width:5px;height:5px;background:var(--text3);border-radius:50%;animation:typingDot 1s infinite}
.chat-typing span:nth-child(2){animation-delay:.18s}
.chat-typing span:nth-child(3){animation-delay:.36s}
@keyframes typingDot{0%,80%,100%{transform:scale(1);opacity:.4}40%{transform:scale(1.35);opacity:1}}

/* Email gate */
.email-form{display:flex;flex-direction:column;gap:12px;width:100%;margin-top:10px}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-input{width:100%;padding:15px 18px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);font-size:16px;font-family:var(--sans);font-weight:300;outline:none;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none}
.form-input:focus{border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-soft)}
.form-input.error{border-color:var(--red)}
.form-input::placeholder{color:var(--text3)}
.form-error{font-size:12px;color:var(--red)}
.form-disclaimer{font-size:12px;color:var(--text3);text-align:center;line-height:1.55}

/* Paywall */
.screen--paywall{overflow-y:auto;-webkit-overflow-scrolling:touch}
.paywall-badge{display:inline-flex;align-items:center;gap:8px;padding:5px 14px;border:1px solid rgba(200,80,192,.25);background:rgba(200,80,192,.07);color:var(--mag);font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;border-radius:100px;margin-bottom:18px}
.paywall-badge::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--mag)}
.paywall-headline{font-family:var(--serif);font-size:clamp(30px,5.5vw,52px);line-height:1.0;letter-spacing:-.025em;margin-bottom:10px;color:var(--text)}
.paywall-headline em{font-style:italic;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.paywall-sub{font-size:15px;color:var(--text2);margin-bottom:20px;line-height:1.6;font-weight:300}
.paywall-book{display:flex;justify-content:center;margin:4px 0 20px}
.book-cover{width:112px;height:152px;border-radius:4px 16px 16px 4px;background:linear-gradient(145deg,#1c0820,#0d0814);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;border:1px solid rgba(200,80,192,.2);box-shadow:-6px 6px 0 rgba(0,0,0,.6),inset -3px 0 12px rgba(0,0,0,.4),0 16px 48px rgba(0,0,0,.5);animation:bookFloat 4.5s ease-in-out infinite;position:relative;overflow:hidden}
.book-cover::before{content:'';position:absolute;left:12px;top:0;bottom:0;width:3px;background:rgba(255,255,255,.04);border-radius:2px}
.book-cover::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(200,80,192,.08) 0%,transparent 60%)}
@keyframes bookFloat{0%,100%{transform:rotate(-2deg) translateY(0)}50%{transform:rotate(-2deg) translateY(-8px)}}
.book-title{font-family:var(--serif);font-size:13px;font-weight:800;text-align:center;line-height:1.15;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;z-index:1;padding:0 12px}
.book-icon{font-size:22px;position:relative;z-index:1}
.paywall-bullets{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:22px}
.paywall-bullets li{background:var(--card);border:1px solid var(--border);border-radius:var(--r-sm);padding:13px 16px 13px 44px;font-size:14px;line-height:1.55;color:var(--text);position:relative;transition:border-color .2s}
.paywall-bullets li::before{content:'✓';position:absolute;left:16px;top:14px;font-size:12px;font-weight:700;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.paywall-bullets li:hover{border-color:rgba(200,80,192,.2)}
.paywall-price-wrap{display:flex;align-items:baseline;gap:14px;margin-bottom:10px}
.price-orig{font-size:16px;color:var(--text3);text-decoration:line-through;text-decoration-color:rgba(200,80,192,.4)}
.price-now{font-family:var(--serif);font-size:56px;font-weight:900;color:var(--text);line-height:1}
.price-save{font-size:12px;color:var(--green);background:rgba(52,211,153,.07);padding:4px 10px;border-radius:100px;border:1px solid rgba(52,211,153,.15)}
.paywall-hook{font-family:var(--serif);font-size:15px;font-style:italic;color:var(--text2);margin-bottom:20px;line-height:1.6}
.paywall-guarantee{font-size:12px;color:var(--text3);text-align:center;margin-top:14px;line-height:1.6}
.trust-row{display:flex;justify-content:center;gap:20px;margin-top:14px;flex-wrap:wrap}
.trust-row span{font-size:11px;color:var(--text3)}
.urgency-bar{margin-top:16px;background:rgba(255,184,0,.04);border:1px solid rgba(255,184,0,.14);border-radius:var(--r-sm);padding:11px 16px;font-size:13px;color:var(--amber);text-align:center}
.paywall-sep{height:1px;background:linear-gradient(90deg,transparent,rgba(200,80,192,.3) 40%,rgba(255,122,0,.3) 60%,transparent);margin:20px 0}

/* Checkout */
.checkout-wrap{max-width:560px;margin:0 auto;padding:24px 24px 48px;min-height:100vh}
@media(min-width:900px){.checkout-wrap{max-width:680px;padding:40px 48px 60px}}
.checkout-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}
.checkout-header h2{font-family:var(--serif);font-size:22px;font-weight:800}
.back-link{font-size:14px;color:var(--text2);text-decoration:none}
.checkout-product{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-sm);padding:16px 20px;margin-bottom:28px}
.product-thumb{font-size:28px}.product-name{font-size:15px;font-weight:600}.product-desc{font-size:12px;color:var(--text3)}.product-price{font-family:var(--serif);font-size:22px;font-weight:900;margin-left:auto}.orig-price{font-size:13px;color:var(--text3);text-decoration:line-through;font-weight:300}
.stripe-card-element{background:var(--card);border:1px solid var(--border);border-radius:var(--r-sm);padding:15px 16px;transition:border-color .15s,box-shadow .15s}
.stripe-card-element:focus-within{border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-soft)}
.checkout-disclaimer{font-size:12px;color:var(--text3);text-align:center;margin-top:14px;line-height:1.6}

/* Thank you */
.thankyou-steps{margin-top:28px;display:flex;flex-direction:column;gap:10px;text-align:left}
.step-mini{background:var(--card);border:1px solid var(--border);border-radius:var(--r-sm);padding:13px 16px;font-size:14px;color:var(--text)}

/* Desktop bg glow */
@media(min-width:900px){
  body::before{content:'';position:fixed;top:0;left:50%;transform:translateX(-50%);width:var(--max);height:100vh;background:radial-gradient(ellipse at 30% 20%,rgba(200,80,192,.04) 0%,transparent 55%);pointer-events:none;z-index:0}
}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  .animate-in{animation:none}
  .flip-card__inner{transition:none}
  .cta-btn{transition:background .1s}
  .book-cover{animation:none}
}

/* Short screens */
@media(max-height:680px) and (max-width:899px){
  .screen{padding:18px 20px 22px}
  .screen__emoji{font-size:28px;margin-bottom:10px}
  .screen__heading{font-size:clamp(24px,6vw,32px)}
}

/* ════════════════════════════════════
   SCENE IMAGES
════════════════════════════════════ */
.scene-img-wrap {
  width: 100%;
  margin: 20px 0 4px;
  border-radius: var(--r);
  overflow: hidden;
  position: relative;
  flex-shrink: 0;
}
.scene-img-wrap img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  object-position: center 20%;
  display: block;
  border-radius: var(--r);
  filter: brightness(.88) saturate(.9);
}
/* Gradient fade bottom so it blends into dark bg */
.scene-img-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 40%, var(--black) 100%);
  border-radius: var(--r);
  pointer-events: none;
}
/* Caption label over image */
.scene-img-label {
  position: absolute;
  bottom: 14px;
  left: 16px;
  z-index: 1;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(255,255,255,.35);
}
@media (min-width: 900px) {
  .scene-img-wrap img { height: 280px }
}
/* Wider crop for landscape scenes */
.scene-img-wrap--wide img { object-position: center 30% }
.scene-img-wrap--top img  { object-position: center top }

/* ── Real book cover image ── */
.book-cover-wrap {
  position: relative;
  display: inline-block;
  animation: bookFloat 4.5s ease-in-out infinite;
}
.book-cover-img {
  width: 180px;
  height: auto;
  border-radius: 4px 12px 12px 4px;
  display: block;
  box-shadow: -8px 8px 0 rgba(0,0,0,.7), 0 20px 60px rgba(0,0,0,.6);
  transform: rotate(-2deg);
}
/* Spine shadow */
.book-cover-wrap::before {
  content: '';
  position: absolute;
  left: 0; top: 4%; bottom: 4%;
  width: 6px;
  background: linear-gradient(to right, rgba(0,0,0,.5), transparent);
  border-radius: 2px 0 0 2px;
  transform: rotate(-2deg);
}
