/* ============================================================
   THEME: Retro / Cyberpunk — 80s CRT terminal  (default theme)
   Neon phosphor, scanlines, pixel + terminal fonts, glow.
   Fluid/responsive; targets the same markup as theme-minimal.css.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=VT323&display=swap');

:root{
  --bg:#060814;
  --panel:#0b1024;
  --cyan:#00eaff;
  --magenta:#ff2d9b;
  --green:#38ff9d;
  --amber:#ffc24b;
  --text:#bdf3ff;
  --muted:#6f97a8;
  --line:rgba(0,234,255,.38);
  --mono:'VT323','Courier New',monospace;
  --pixel:'Press Start 2P','VT323',monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--mono);font-size:clamp(19px,1.5vw,24px);line-height:1.4;
  color:var(--text);
  background:
    radial-gradient(circle at 50% -10%, rgba(0,234,255,.13), transparent 55%),
    radial-gradient(circle at 90% 110%, rgba(255,45,155,.12), transparent 45%),
    linear-gradient(0deg, rgba(0,234,255,.05) 1px, transparent 1px) 0 0/100% 42px,
    linear-gradient(90deg, rgba(0,234,255,.05) 1px, transparent 1px) 0 0/42px 100%,
    var(--bg);
  min-height:100vh;display:flex;flex-direction:column;align-items:center;
  padding:clamp(20px,4vh,48px) clamp(16px,4vw,44px);
}
/* CRT scanlines + gentle flicker overlay */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9998;
  background:repeating-linear-gradient(180deg, rgba(0,0,0,0) 0 2px, rgba(0,0,0,.28) 3px, rgba(0,0,0,0) 4px);
  opacity:.5;animation:crtflicker 4s infinite steps(50);
}
@keyframes crtflicker{0%,100%{opacity:.46}48%{opacity:.42}50%{opacity:.55}52%{opacity:.43}}

.wrap{width:100%;max-width:1180px;margin-block:auto;display:grid;grid-template-columns:clamp(280px,34vw,440px) 1fr;column-gap:clamp(26px,3.4vw,52px);align-items:start}
.content{min-width:0}

.portrait{width:100%;aspect-ratio:1024/1535;margin:0;background:url('Fulvio-cyberpunk.png') center/contain no-repeat;border:1px solid rgba(0,234,255,.55);border-radius:10px;box-shadow:0 0 0 1px rgba(255,45,155,.4),0 0 36px rgba(0,234,255,.38);position:sticky;top:clamp(16px,3vh,28px)}
.eyebrow{font-family:var(--pixel);font-size:clamp(11px,1.3vw,15px);line-height:1.6;color:var(--cyan);text-transform:uppercase;margin-bottom:clamp(14px,2vw,22px);text-shadow:0 0 8px rgba(0,234,255,.7)}
.eyebrow::before{content:"> "}
.eyebrow::after{content:"_";animation:blink 1.05s steps(1) infinite;margin-left:2px}
@keyframes blink{0%,49%{opacity:1}50%,100%{opacity:0}}

h1{font-family:var(--mono);font-weight:400;font-size:clamp(34px,4.8vw,64px);line-height:1.0;letter-spacing:.5px;color:#eafffb;text-shadow:0 0 10px rgba(0,234,255,.65),0 0 2px rgba(0,234,255,.9);margin-bottom:4px}
h1 .name{display:block;white-space:nowrap;color:var(--magenta);text-shadow:0 0 14px rgba(255,45,155,.7)}

.rule{width:clamp(120px,18vw,180px);height:4px;margin:clamp(16px,2.4vw,26px) 0 clamp(18px,2.4vw,26px);border:none;background:linear-gradient(90deg,var(--cyan),var(--magenta));box-shadow:0 0 14px rgba(0,234,255,.6)}

.lede{font-size:clamp(20px,2.4vw,28px);color:#9fd8e6;margin-bottom:clamp(24px,3vw,36px);max-width:42ch}

.card{background:linear-gradient(180deg,rgba(13,18,40,.95),rgba(7,10,24,.95));border:1px solid var(--line);border-radius:6px;padding:clamp(20px,3vw,36px);box-shadow:0 0 0 1px rgba(0,234,255,.12),0 0 32px rgba(0,234,255,.12),inset 0 0 46px rgba(0,234,255,.04)}

.step{display:flex;align-items:center;gap:11px;font-family:var(--pixel);font-size:clamp(10px,1.15vw,13px);line-height:1.5;text-transform:uppercase;color:var(--cyan);margin:0 0 16px;text-shadow:0 0 6px rgba(0,234,255,.5)}
.step .dot{width:26px;height:26px;border-radius:3px;background:var(--magenta);color:#06070f;display:inline-flex;align-items:center;justify-content:center;font-family:var(--pixel);font-size:10px;box-shadow:0 0 10px rgba(255,45,155,.6);flex:none}
.step.mt{margin-top:clamp(22px,3vw,32px)}

.chips{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}
.chip{cursor:pointer;font-family:var(--mono);font-size:clamp(17px,1.7vw,21px);line-height:1.1;color:var(--cyan);background:rgba(0,234,255,.05);border:1px solid var(--line);border-radius:3px;padding:7px 14px;transition:all .12s}
.chip::before{content:"["}
.chip::after{content:"]"}
.chip:hover{background:rgba(0,234,255,.16);box-shadow:0 0 12px rgba(0,234,255,.35)}
.chip.active{background:var(--magenta);border-color:var(--magenta);color:#06070f;box-shadow:0 0 14px rgba(255,45,155,.55)}
.chip.free{color:var(--green);border-color:rgba(56,255,157,.5)}
.chip.free.active{color:#06070f;background:var(--green);border-color:var(--green)}

.prompt{position:relative;background:#02040a;border:1px solid rgba(56,255,157,.5);border-radius:3px;padding:clamp(14px,2vw,20px);font-family:var(--mono);font-size:clamp(17px,1.8vw,21px);line-height:1.45;color:var(--green);text-shadow:0 0 6px rgba(56,255,157,.4);white-space:pre-wrap;word-break:break-word;max-height:280px;overflow:auto}

.copy-btn{width:100%;margin-top:18px;cursor:pointer;font-family:var(--mono);font-size:clamp(21px,2.3vw,28px);letter-spacing:1px;text-transform:uppercase;color:var(--cyan);background:transparent;border:2px solid var(--cyan);border-radius:3px;padding:clamp(11px,1.6vw,16px) 18px;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .14s;text-shadow:0 0 8px rgba(0,234,255,.5)}
.copy-btn:hover{background:var(--cyan);color:#06070f;text-shadow:none;box-shadow:0 0 18px rgba(0,234,255,.6)}
.copy-btn:active{transform:translateY(1px)}
.copy-btn.copied{border-color:var(--green);color:var(--green)}
.copy-btn.copied:hover{background:var(--green)}
.copy-btn svg{width:20px;height:20px;flex:none}

.ai-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.ai-btn{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-decoration:none;color:var(--text);background:rgba(13,18,40,.7);border:1px solid var(--line);border-radius:4px;padding:clamp(16px,2vw,22px) 10px clamp(13px,1.6vw,16px);font-family:var(--mono);font-size:clamp(18px,1.9vw,22px);cursor:pointer;transition:all .14s}
.ai-btn:hover{border-color:var(--magenta);box-shadow:0 0 16px rgba(255,45,155,.4);transform:translateY(-2px)}
.ai-btn:active{transform:translateY(0)}
.ai-btn svg{width:clamp(28px,3vw,34px);height:clamp(28px,3vw,34px);filter:drop-shadow(0 0 6px rgba(0,234,255,.35))}
.ai-btn small{font-size:clamp(13px,1.3vw,15px);color:var(--muted)}
.ai-btn .badge{position:absolute;top:8px;right:8px;font-family:var(--pixel);font-size:8px;text-transform:uppercase;color:#06070f;background:var(--amber);border-radius:2px;padding:3px 5px;box-shadow:0 0 8px rgba(255,194,75,.5)}

.hint{font-size:clamp(16px,1.6vw,19px);color:var(--muted);margin-top:16px;text-align:center;line-height:1.5}

.meta{margin-top:clamp(26px,3vw,36px);font-size:clamp(19px,2vw,23px);color:var(--muted);text-align:center}
.meta a{color:var(--cyan);text-decoration:none;border-bottom:1px dashed rgba(0,234,255,.5);text-shadow:0 0 6px rgba(0,234,255,.4)}
.meta a:hover{color:var(--magenta);border-color:var(--magenta)}

.foot{margin-top:clamp(28px,3vw,40px);font-size:clamp(14px,1.4vw,17px);color:#557180;text-align:center;line-height:1.7}

.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);background:#02040a;color:var(--cyan);border:1px solid var(--cyan);padding:13px 20px;border-radius:3px;font-family:var(--mono);font-size:clamp(18px,1.9vw,22px);opacity:0;pointer-events:none;transition:all .25s;z-index:50;box-shadow:0 0 20px rgba(0,234,255,.4)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* theme switcher */
.theme-switch{position:fixed;top:16px;right:16px;display:flex;gap:7px;z-index:60}
.theme-switch button{cursor:pointer;font-family:var(--mono);font-size:clamp(15px,1.5vw,18px);letter-spacing:.5px;text-transform:uppercase;color:var(--cyan);background:rgba(6,8,20,.82);border:1px solid var(--line);border-radius:3px;padding:5px 13px;transition:all .14s}
.theme-switch button:hover{box-shadow:0 0 12px rgba(0,234,255,.4)}
.theme-switch button.active{background:var(--magenta);border-color:var(--magenta);color:#06070f}

@media (max-width:820px){
  .wrap{grid-template-columns:1fr;row-gap:clamp(14px,3vw,22px)}
  .portrait{position:static;max-width:340px;margin:0 auto;justify-self:center}
}
@media (max-width:560px){
  .ai-grid{grid-template-columns:repeat(2,1fr)}
  .theme-switch{top:10px;right:10px}
}
