/* assets/css/app.css — Icebreak Premium */
/* #0B0B0B · #121212 · #FF7A00 · #EAEAEA */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&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.13);
  --orange:      #FF7A00;
  --orange-h:    #FF9A3D;
  --orange-glow: rgba(255,122,0,0.22);
  --orange-soft: rgba(255,122,0,0.08);
  --text:        #EAEAEA;
  --text2:       #888888;
  --text3:       #444444;
  --green:       #34D399;
  --red:         #F87171;
  --amber:       #FFB800;
  --font:        'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-d:      'Bebas Neue', sans-serif;
  --max:         1200px;
  --radius:      16px;
  --radius-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(--font);font-weight:300;min-height:100vh;overscroll-behavior:none;-webkit-font-smoothing:antialiased}

/* ── Shell ── */
.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)}
}
@media(max-width:899px){
  .app-left{width:100%}
  .app-right{display:none}
}

/* ── Status bar (mobile) ── */
.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 14px;border-bottom:1px solid var(--border);flex-shrink:0}
  .desktop-logo{font-family:var(--font-d);font-size:20px;letter-spacing:.06em;color:var(--text)}
  .desktop-logo span{color:var(--orange)}
  .desktop-step-label{font-size:11px;color:var(--text3);letter-spacing:.1em;text-transform:uppercase}
}

/* ── Progress ── */
.progress-wrap{padding:8px 24px 14px;flex-shrink:0}
@media(min-width:900px){.progress-wrap{padding:18px 40px 12px}}
.progress-track{height:2px;background:var(--card3);border-radius:2px;overflow:hidden}
.progress-fill{height:2px;background:var(--orange);border-radius:2px;transition:width .55s cubic-bezier(.4,0,.2,1);position:relative}
.progress-fill::after{content:'';position:absolute;right:0;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:50%;background:var(--orange);box-shadow:0 0 8px var(--orange)}
.progress-label{font-size:11px;color:var(--text3);margin-top:8px;text-align:right;letter-spacing:.05em}
.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:28px 24px 32px}
@media(min-width:900px){.screen{padding:40px 40px 48px}}

/* ── Animate ── */
@keyframes slideUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.animate-in{animation:slideUp .38s cubic-bezier(.25,.46,.45,.94) both}

/* ── Type ── */
.screen__emoji{font-size:40px;margin-bottom:18px;display:block}
@media(min-width:900px){.screen__emoji{font-size:52px;margin-bottom:22px}}

.screen__heading{font-family:var(--font-d);font-size:clamp(28px,5vw,52px);line-height:1.0;letter-spacing:.02em;color:var(--text);margin-bottom:18px;flex-grow:1}
.screen__heading .hl{color:var(--orange)}

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

/* ── CTA ── */
.screen__cta-wrap{margin-top:auto;padding-top:16px}
.cta-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:17px 28px;background:var(--orange);color:#000;font-family:var(--font);font-size:16px;font-weight:600;border:none;border-radius:var(--radius);cursor:pointer;transition:background .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{background:var(--orange-h);transform:translateY(-1px);box-shadow:0 8px 28px var(--orange-glow)}
.cta-btn:active{transform:scale(.98)}
.cta-btn--full{width:100%;display:flex}
.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:36px}
  .right-step-num{font-family:var(--font-d);font-size:120px;line-height:1;color:var(--card3);display:block;letter-spacing:-.02em}
  .right-step-name{font-size:11px;color:var(--text3);letter-spacing:.14em;text-transform:uppercase;margin-top:-12px}
  .right-insight{text-align:center;max-width:280px;margin-bottom:44px}
  .right-insight-icon{font-size:40px;margin-bottom:14px}
  .right-insight-title{font-size:15px;font-weight:500;color:var(--text);margin-bottom:8px;line-height:1.3}
  .right-insight-body{font-size:13px;color:var(--text2);line-height:1.6}
  .right-steps-list{width:100%;max-width:300px;display:flex;flex-direction:column;gap:0}
  .right-step-item{display:flex;align-items:center;gap:12px;padding:12px 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:var(--card3);flex-shrink:0;transition:background .2s,box-shadow .2s}
  .right-step-item.done .right-step-dot{background:var(--orange);border-color:var(--orange)}
  .right-step-item.current .right-step-dot{background:var(--orange);border-color:var(--orange);box-shadow:0 0 8px var(--orange-glow)}
  .right-brand{margin-top:auto;font-family:var(--font-d);font-size:16px;letter-spacing:.06em;color:var(--text3)}
  .right-brand span{color:var(--orange)}
}

/* ── Flip card ── */
.flip-card-wrap{flex:1;display:flex;align-items:center;justify-content:center;margin:20px 0}
.flip-card{width:100%;max-width:460px;height:220px;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(--radius);padding:28px 24px;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:var(--card);border-color:rgba(255,122,0,.2);transform:rotateY(180deg)}
.tap-hint{font-size:11px;color:var(--text3);margin-bottom:12px;text-transform:uppercase;letter-spacing:.1em}
.flip-card__front p{font-size:15px;color:var(--text2)}
.reveal-line{font-size:18px;font-weight:500;color:var(--text);line-height:1.5;margin-bottom:12px}
.reveal-note{font-size:13px;color:var(--orange)}

/* ── Choice ── */
.choices-list{display:flex;flex-direction:column;gap:10px;margin:16px 0;flex:1}
.choice-btn{width:100%;padding:16px 20px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text2);font-size:15px;font-weight:400;font-family:var(--font);text-align:left;cursor:pointer;transition:border-color .15s,background .15s,color .15s,transform .1s;-webkit-tap-highlight-color:transparent;line-height:1.4}
.choice-btn:hover{border-color:var(--border2);color:var(--text);background:var(--card2)}
.choice-btn.selected{border-color:var(--orange);background:var(--orange-soft);color:var(--text)}

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

/* ── Swipe ── */
.swipe-deck{position:relative;height:210px;margin:20px 0 14px;user-select:none}
.swipe-card{position:absolute;inset:0;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:28px 24px;display:flex;flex-direction:column;justify-content:center;gap:12px;cursor:grab}
.swipe-card:nth-child(2){transform:rotate(-1.5deg) translateY(5px);z-index:1}
.swipe-card:nth-child(3){transform:rotate(1deg) translateY(10px);z-index:0}
.swipe-card:first-child{z-index:2}
.swipe-signal{font-size:17px;font-weight:500;color:var(--text)}
.swipe-verdict{font-size:15px;color:var(--text2)}
.swipe-hint{font-size:11px;color:var(--text3);text-align:center;letter-spacing:.05em}
.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:14px 0;scroll-behavior:smooth;min-height:180px}
.chat-bubble{max-width:76%;padding:11px 16px;border-radius:18px;font-size:15px;line-height:1.45;animation:slideUp .25s ease both}
.chat-bubble--you{background:var(--orange);color:#000;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 ── */
.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(--radius-sm);color:var(--text);font-size:16px;font-family:var(--font);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}

/* ── Paywall ── */
.screen--paywall{overflow-y:auto;-webkit-overflow-scrolling:touch}
.paywall-badge{display:inline-block;padding:4px 12px;border:1px solid rgba(255,184,0,.25);background:rgba(255,184,0,.07);color:var(--amber);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;border-radius:100px;margin-bottom:14px}
.paywall-headline{font-family:var(--font-d);font-size:clamp(28px,5vw,50px);line-height:1.0;letter-spacing:.02em;margin-bottom:8px}
.paywall-sub{font-size:15px;color:var(--text2);margin-bottom:18px}
.paywall-book{display:flex;justify-content:center;margin:6px 0 18px}
.book-cover{width:108px;height:148px;background:linear-gradient(145deg,#1A0A00,#0D0A0B);border-radius:3px 12px 12px 3px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;border:1px solid rgba(255,122,0,.18);box-shadow:-4px 4px 0 rgba(0,0,0,.5),inset -3px 0 8px rgba(0,0,0,.35);position:relative}
.book-cover::before{content:'';position:absolute;left:9px;top:0;bottom:0;width:2px;background:rgba(255,255,255,.04);border-radius:1px}
.book-title{font-family:var(--font-d);font-size:14px;color:var(--orange);text-align:center;line-height:1.1}
.book-icon{font-size:24px}
.paywall-bullets{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.paywall-bullets li{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:13px 16px;font-size:14px;line-height:1.55;color:var(--text);transition:border-color .2s}
.paywall-bullets li:hover{border-color:rgba(255,122,0,.2)}
.paywall-price-wrap{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.price-orig{font-size:15px;color:var(--text3);text-decoration:line-through}
.price-now{font-family:var(--font-d);font-size:44px;color:var(--text);line-height:1}
.price-save{font-size:11px;color:var(--green);background:rgba(52,211,153,.07);padding:3px 9px;border-radius:100px;border:1px solid rgba(52,211,153,.15)}
.paywall-hook{font-size:14px;color:var(--text2);font-style:italic;margin-bottom:18px;line-height:1.55}
.paywall-guarantee{font-size:12px;color:var(--text3);text-align:center;margin-top:12px}
.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,.05);border:1px solid rgba(255,184,0,.15);border-radius:var(--radius-sm);padding:10px 16px;font-size:13px;color:var(--amber);text-align:center}

/* ── 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(--font-d);font-size:20px;letter-spacing:.04em}
.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(--radius-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(--font-d);font-size:20px;margin-left:auto}.orig-price{font-size:13px;color:var(--text3);text-decoration:line-through;font-weight:300;font-family:var(--font)}
.stripe-card-element{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-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(--radius-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 75% 30%,rgba(255,122,0,.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}
}

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