/* generate.css — styles for /generate.html, tries to match the site's vibe */

/* Ambient page backdrop — subtle radial glows, stalker vibe */
body::before{
  content:"";
  position:fixed;inset:0;
  background:
    radial-gradient(900px 500px at 15% 10%, rgba(255,138,31,.08), transparent 60%),
    radial-gradient(700px 400px at 85% 90%, rgba(255,138,31,.06), transparent 60%),
    radial-gradient(500px 300px at 50% 50%, rgba(255,138,31,.03), transparent 70%);
  pointer-events:none;
  z-index:-1;
}

.gen-main{max-width:520px;margin:0 auto;padding:10px 12px 30px}

/* Desktop: widen for two-column form layout */
@media(min-width:900px){
  .gen-main{max-width:980px;padding:20px 24px 40px}
}

/* Two-column layout inside formBox on desktop */
.gen-form-layout{padding:16px}
@media(min-width:900px){
  .gen-form-layout{
    display:grid;
    grid-template-columns:1.1fr .9fr;
    gap:32px;
    padding:28px 32px;
    align-items:center;
  }
  .gen-form-col{display:flex;flex-direction:column}
  .gen-showcase{display:flex;flex-direction:column;gap:4px}
}
/* Marketing copy — compact on mobile, full on desktop */
.gen-showcase-copy{display:block;text-align:center;margin:-8px 0 18px;padding:0 6px}
.gen-showcase-lead,
.gen-showcase-bullets{display:none}
@media(min-width:900px){
  .gen-showcase-copy{text-align:left;margin-top:10px;margin-bottom:0}
  .gen-showcase-lead,
  .gen-showcase-bullets{display:block}
  .gen-showcase-bullets{display:flex}
}
.gen-showcase-kicker{
  display:inline-block;
  font-size:10px;font-weight:800;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--accent);
  padding:3px 10px;border-radius:999px;
  background:rgba(255,138,31,.10);
  border:1px solid rgba(255,138,31,.30);
  margin-bottom:10px;
}
.gen-showcase-title{
  color:var(--text);
  font-size:22px;line-height:1.1;
  font-weight:900;letter-spacing:.5px;
  text-transform:uppercase;
  margin:0 0 6px;
}
@media(min-width:900px){
  .gen-showcase-kicker{font-size:11px;margin-bottom:14px}
  .gen-showcase-title{font-size:28px;margin:0 0 12px}
}
.gen-showcase-title br{display:block}
.gen-showcase-lead{
  color:var(--mute);font-size:13px;line-height:1.55;
  margin:0 0 14px;
}
.gen-showcase-bullets{
  list-style:none;padding:0;margin:0;
  flex-direction:column;gap:6px;
}
.gen-showcase-bullets li{
  position:relative;
  padding-left:18px;
  font-size:12px;color:var(--text);line-height:1.45;
}
.gen-showcase-bullets li::before{
  content:"▸";
  position:absolute;left:0;top:0;
  color:var(--accent);font-weight:900;
}

.gen-box{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:16px;
  margin-bottom:14px;
}

.gen-title{
  color:var(--accent);
  font-size:14px;
  font-weight:800;
  letter-spacing:1px;
  text-transform:uppercase;
  margin:0 0 6px;
}

.gen-sub{color:var(--mute);font-size:13px;line-height:1.45;margin:0 0 16px}

/* Global progress bar (counts DOWN from 1000 to 0) */
.gen-progress-wrap{margin-bottom:14px}
.gen-progress-label{
  display:flex;justify-content:space-between;align-items:center;
  font-size:11px;color:var(--mute);letter-spacing:.5px;
  text-transform:uppercase;font-weight:700;margin-bottom:6px;
}
.gen-progress-label b{color:var(--accent);font-variant-numeric:tabular-nums}
.gen-progress-bar{
  height:10px;background:var(--bg);border:1px solid var(--border);
  border-radius:999px;overflow:hidden;
}
.gen-progress-fill{
  height:100%;
  background:linear-gradient(90deg,var(--accent),var(--accent2,#ffb352));
  border-radius:999px;
  transition:width .4s ease;
}
.gen-progress-wrap.low .gen-progress-fill{
  background:linear-gradient(90deg,#ff6a6a,#ff8a1f);
}
.gen-progress-wrap.critical .gen-progress-fill{
  background:#ff6a6a;
  animation:progPulse 1.4s ease-in-out infinite;
}
@keyframes progPulse{
  0%,100%{opacity:1}
  50%{opacity:.55}
}

/* Exhausted state — shows inside formBox instead of drop zone + button */
.gen-exhausted{
  position:relative;
  text-align:center;
  margin-top:130px;
  padding:28px 22px 22px;
  background:
    radial-gradient(ellipse 70% 60% at 50% 0%, rgba(245,158,11,.1), transparent 65%),
    linear-gradient(180deg, #15191c 0%, #0f1316 100%);
  border:1px solid var(--border);
  border-top:1px solid rgba(245,158,11,.3);
  border-radius:14px;
  overflow:visible;
  box-shadow:0 10px 30px rgba(0,0,0,.35);
}
.gen-exhausted-stage{
  position:absolute;
  top:-150px;left:0;right:0;height:170px;
  display:flex;align-items:flex-end;justify-content:center;
  pointer-events:none;
}
.gen-exhausted-glow{
  position:absolute;
  inset:-20px 20% 0 20%;
  background:radial-gradient(ellipse at 50% 60%,
    rgba(245,158,11,.4) 0%,
    rgba(245,158,11,.12) 40%,
    transparent 70%);
  filter:blur(8px);
}
.gen-exhausted-sid{
  position:relative;z-index:1;
  width:auto;max-width:380px;height:180px;
  object-fit:contain;object-position:bottom;
  filter:drop-shadow(0 14px 22px rgba(0,0,0,.7));
  user-select:none;
}
.gen-exhausted-quote{
  font-style:italic;
  color:#e6e6de;
  font-size:15px;line-height:1.55;
  margin:0 auto 10px;
  padding:6px 0;
  max-width:380px;
}
.gen-exhausted-sig{
  color:var(--accent);
  font-size:12px;font-weight:800;
  letter-spacing:2px;text-transform:uppercase;
  margin:0 0 16px;
}
.gen-exhausted-sub{
  color:var(--mute);
  font-size:12px;line-height:1.5;
  margin:0;
  padding-top:10px;
  border-top:1px dashed rgba(255,255,255,.08);
}
.gen-exhausted-sub a{
  color:var(--accent);text-decoration:none;
  border-bottom:1px dotted var(--accent);
}
@media (max-width:500px){
  .gen-exhausted{margin-top:160px;padding-top:24px}
  .gen-exhausted-stage{top:-140px;height:160px}
  .gen-exhausted-sid{max-width:300px;height:155px}
  .gen-exhausted-quote{font-size:14px}
}

/* Inline loading/result — replace the form content without re-layout */
.gen-loading-inline,
.gen-result-inline{
  text-align:center;
  padding:22px 18px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:12px;
}
.gen-inline-title{
  color:var(--accent);
  font-size:15px;font-weight:900;
  letter-spacing:.5px;text-transform:uppercase;
  margin:14px 0 8px;
}
.gen-inline-sub{color:var(--text);font-size:13px;line-height:1.5;margin:0 0 6px}
.gen-inline-hint{color:var(--mute);font-size:11px;line-height:1.4;margin:10px 0 0}
.gen-result-inline .gen-canvas{margin:8px 0 14px}

/* Guest login prompt — shows in formBox when pool is open but user isn't logged in */
.gen-guest{
  text-align:center;
  padding:22px 18px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:12px;
}
.gen-guest-icon{font-size:36px;line-height:1;margin-bottom:8px}
.gen-guest-title{
  color:var(--accent);
  font-size:15px;font-weight:900;
  letter-spacing:.5px;text-transform:uppercase;
  margin:0 0 10px;
}
.gen-guest-text{
  color:var(--text);
  font-size:13px;line-height:1.55;
  margin:0 0 14px;
}
.gen-guest-btn{margin-top:4px}

/* Blocker (global limit exhausted) */
.gen-blocker{text-align:center;padding:30px 20px}
.gen-blocker-emoji{font-size:50px;margin-bottom:10px}
.gen-blocker-title{
  color:#ff6a6a;font-size:18px;font-weight:900;
  letter-spacing:1.5px;text-transform:uppercase;margin:0 0 10px;
}
.gen-blocker-text{color:var(--text);font-size:14px;line-height:1.5;margin:0 0 10px}
.gen-blocker-sub{color:var(--mute);font-size:12px;line-height:1.5;margin:0}

/* Example preview — three fanned cards with ambient glow */
.gen-example{
  position:relative;
  display:flex;justify-content:center;align-items:center;
  margin:-4px 0 26px;
  padding:16px 0 10px;
  height:300px;
  perspective:1200px;
  pointer-events:none;
}
.gen-example-glow{
  position:absolute;inset:-6% 0;
  background:radial-gradient(ellipse at center,
    rgba(255,138,31,.32) 0%,
    rgba(255,138,31,.10) 40%,
    transparent 72%);
  filter:blur(26px);
  z-index:0;
}
.gen-example-card{
  position:absolute;
  width:170px;height:auto;
  border-radius:10px;
  display:block;
  box-shadow:
    0 18px 38px rgba(0,0,0,.55),
    0 4px 12px rgba(255,138,31,.14),
    0 0 0 1px rgba(255,138,31,.10);
  transition:transform .4s ease;
}
.gen-example-card.center{
  z-index:3;
  transform:translateY(0) rotate(0deg);
  animation:genExampleFloatC 6s ease-in-out infinite;
}
.gen-example-card.left{
  z-index:2;
  transform:translateX(-82px) translateY(18px) rotate(-9deg);
  animation:genExampleFloatL 6s ease-in-out infinite;
  filter:brightness(.88);
}
.gen-example-card.right{
  z-index:2;
  transform:translateX(82px) translateY(18px) rotate(9deg);
  animation:genExampleFloatR 6s ease-in-out infinite;
  filter:brightness(.88);
}
@keyframes genExampleFloatC{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-8px) rotate(0deg)}
}
@keyframes genExampleFloatL{
  0%,100%{transform:translateX(-82px) translateY(18px) rotate(-9deg)}
  50%{transform:translateX(-82px) translateY(10px) rotate(-9deg)}
}
@keyframes genExampleFloatR{
  0%,100%{transform:translateX(82px) translateY(18px) rotate(9deg)}
  50%{transform:translateX(82px) translateY(10px) rotate(9deg)}
}
@media(max-width:380px){
  .gen-example{height:260px}
  .gen-example-card{width:140px}
  .gen-example-card.left{transform:translateX(-64px) translateY(16px) rotate(-9deg)}
  .gen-example-card.right{transform:translateX(64px) translateY(16px) rotate(9deg)}
  @keyframes genExampleFloatL{
    0%,100%{transform:translateX(-64px) translateY(16px) rotate(-9deg)}
    50%{transform:translateX(-64px) translateY(8px) rotate(-9deg)}
  }
  @keyframes genExampleFloatR{
    0%,100%{transform:translateX(64px) translateY(16px) rotate(9deg)}
    50%{transform:translateX(64px) translateY(8px) rotate(9deg)}
  }
}
@media(prefers-reduced-motion:reduce){
  .gen-example-card{animation:none}
}

/* Quota pills row */
.gen-quota-row{
  display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;
}
.gen-quota{
  display:inline-flex;align-items:center;
  padding:6px 12px;
  background:rgba(255,138,31,.10);
  border:1px solid rgba(255,138,31,.35);
  border-radius:999px;
  color:var(--accent);
  font-size:11px;
  font-weight:700;
  letter-spacing:.5px;
  text-transform:uppercase;
}
.gen-quota b{margin:0 2px;font-variant-numeric:tabular-nums}
.gen-quota.exhausted{
  background:rgba(255,106,106,.12);
  border-color:rgba(255,106,106,.5);
  color:#ff8a8a;
}

/* Coffee icon button next to quota pills — same pill height, circle shape,
   pushed to the right end of the row. Opens the social-proof support modal. */
.gen-coffee-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;padding:0;
  background:rgba(255,138,31,.10);
  border:1px solid rgba(255,138,31,.35);
  border-radius:50%;
  color:var(--accent);cursor:pointer;
  transition:background .15s ease,border-color .15s ease,transform .12s ease;
}
.gen-coffee-btn:hover{
  background:rgba(255,138,31,.22);
  border-color:var(--accent);
  transform:scale(1.06);
}
.gen-coffee-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
/* Soft orange ripple — fired ~5s after the form-active state appears IF user
   has never opened the social-proof modal. 3 pulses then stops naturally. */
@keyframes genCoffeePulse {
  0%   { box-shadow: 0 0 0 0   rgba(255,138,31,.55) }
  70%  { box-shadow: 0 0 0 14px rgba(255,138,31,0)   }
  100% { box-shadow: 0 0 0 0   rgba(255,138,31,0)   }
}
.gen-coffee-btn.pulse{
  animation: genCoffeePulse 1.5s ease-out 3
}

/* Drop zone — big, centered, SVG icon */
.gen-drop{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:220px;padding:20px;
  background:var(--bg);
  border:2px dashed var(--border);
  border-radius:12px;
  cursor:pointer;
  transition:border-color .15s,background .15s;
  overflow:hidden;
  margin-bottom:14px;
  text-align:center;
}
.gen-drop:hover{border-color:var(--accent);background:rgba(255,138,31,.04)}
.gen-drop img{max-width:100%;max-height:340px;border-radius:10px;display:block}
.gen-drop-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--mute)}
.gen-drop-icon{width:44px;height:44px;color:var(--accent)}
.gen-drop-text{font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--mute)}

/* Name input — big, uppercase, centered */
.gen-name-wrap{position:relative;margin-bottom:14px}
.gen-input{
  width:100%;
  padding:12px 14px;
  background:var(--bg);
  color:var(--text);
  border:1px solid var(--border);
  border-radius:10px;
  font:inherit;
  font-size:16px;
  outline:none;
  box-sizing:border-box;
}
.gen-input:focus{border-color:var(--accent)}
.gen-name{
  text-align:center;
  font-size:20px;
  font-weight:900;
  letter-spacing:2px;
  text-transform:uppercase;
  padding:14px 44px;
}
.gen-name::placeholder{color:var(--mute);letter-spacing:4px;font-weight:700;opacity:.6}
.gen-name-counter{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  font-size:10px;color:var(--mute);letter-spacing:.5px;pointer-events:none;
  font-variant-numeric:tabular-nums;
}

/* Generate button */
.gen-generate{
  width:100%;
  padding:14px;
  background:var(--accent);
  color:#1a0e00;
  border:1px solid var(--accent);
  border-radius:10px;
  font:inherit;
  font-size:15px;
  font-weight:900;
  letter-spacing:.5px;
  cursor:pointer;
  transition:opacity .12s,transform .08s;
}
.gen-generate:disabled{opacity:.35;cursor:not-allowed}
.gen-generate:not(:disabled):active{transform:scale(.98)}

.gen-err{
  margin-top:12px;padding:10px 12px;
  background:#442020;color:#ff9a9a;
  border:1px solid #5a2828;border-radius:8px;
  font-size:12px;line-height:1.45;
  display:none;
}
.gen-err.show{display:block}

/* Loading */
.gen-loader{
  width:50px;height:50px;margin:16px auto;
  border:3px solid rgba(255,138,31,.15);
  border-top-color:var(--accent);
  border-radius:50%;
  animation:genSpin 1s linear infinite;
}
@keyframes genSpin{to{transform:rotate(360deg)}}

/* Result canvas — always fits the viewport */
.gen-canvas{
  width:100%;
  max-width:100%;
  height:auto;
  border:1px solid var(--border);
  border-radius:10px;
  margin:10px 0 14px;
  display:block;
}

.gen-actions{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.gen-btn{
  padding:11px 16px;
  background:var(--card);color:var(--text);
  border:1px solid var(--border);border-radius:10px;
  font:inherit;font-size:14px;font-weight:700;
  cursor:pointer;transition:opacity .12s;
}
.gen-btn.primary{background:var(--accent);color:#1a0e00;border-color:var(--accent)}
.gen-btn.sec{background:transparent;color:var(--mute);font-weight:500}
.gen-btn:active{opacity:.75}

/* SEO block — minimalist */
.gen-seo{
  margin-top:20px;padding:16px;
  background:var(--card);border:1px solid var(--border);
  border-radius:12px;
  color:var(--mute);font-size:12px;line-height:1.6;
}
.gen-seo h3{color:var(--accent);font-size:11px;letter-spacing:1px;text-transform:uppercase;margin:0 0 10px;font-weight:800}
.gen-seo ol{margin:0;padding-left:20px}
.gen-seo li{margin-bottom:3px}

/* Google sign-in */
.gbtn{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 18px;
  background:#fff;color:#1f1f1f;
  border:0;border-radius:8px;
  font:inherit;font-size:14px;font-weight:600;
  cursor:pointer;margin-top:8px;
}
.gbtn:active{opacity:.85}

@media(min-width:480px){
  .gen-actions{flex-direction:row;justify-content:center}
  .gen-btn{flex:1;max-width:200px}
}
@media(min-width:900px){
  .gen-btn{padding:7px 12px;font-size:13px;border-radius:8px}
}
