/* Estilo inspirado em pump.fun (cores escuras, neon suave, cantos arredondados) */
:root {
  /* Tema atual (verde) */
  --bg: #060f12;
  --bg-alt: #0d191d;
  --panel: #101f24;
  --border: #122a31;
  --text: #d9e6eb;
  --muted: #6b858e;
  --accent: #22d18a;
  --accent-alt: #1aa06a;
  --accent-glow: 158 70% 48%;
  --danger: #ff4769;
  --focus-ring: 0 0 0 3px #22d18a55, 0 0 0 1px #15905f;
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  font-family: 'Inter', system-ui, sans-serif;
  color-scheme: dark;
}

/* Tema inspirado visualmente em pump.fun (paleta alternativa) */
/* NOTA: Cores recriadas / aproximadas (não cópia literal de CSS proprietário) */
body.pf-theme {
  --bg: #05080c;
  --bg-alt: #090e16;
  --panel: #0f1622;
  --border: #1c2836;
  --text: #d8e3f1;
  --muted: #6b7d91;
  --accent: #ff2fb4;
  --accent-alt: #6d4bff;
  --accent-glow: 315 90% 55%;
  --danger: #ff4d61;
  --focus-ring: 0 0 0 3px #ff2fb444, 0 0 0 1px #962c88;
}

/* Gradientes de destaque (verde e magenta/roxo) */
.gradient-accent { background:linear-gradient(135deg,var(--accent),var(--accent-alt)); }
.text-gradient {
  background:linear-gradient(120deg,var(--accent),var(--accent-alt));
  background-clip:text; -webkit-background-clip:text; color:transparent; font-weight:600;
}

/* Botão de alternância de tema (opcional) */
.theme-toggle { position:fixed; right:14px; bottom:14px; z-index:50; }
.theme-toggle button { background:#0f1922; border:1px solid #20313f; color:var(--text); padding:8px 14px; border-radius:var(--radius-md); cursor:pointer; font-size:12px; }
.theme-toggle button:hover { background:#172432; }
* { box-sizing: border-box; }
body { margin:0; background: radial-gradient(circle at 30% 20%, #0d2025, #050b0d 70%); color: var(--text); font-family: 'Inter', system-ui, sans-serif; min-height:100vh; display:flex; flex-direction:column; }
.topbar { display:flex; align-items:center; justify-content:space-between; padding:10px 26px; background:rgba(13,32,37,0.85); backdrop-filter:blur(12px); border-bottom:1px solid var(--border); position:sticky; top:0; z-index:10; flex-wrap:nowrap; }
.topbar .brand { flex:0 0 auto; }
.topbar .actions { flex:0 0 auto; display:flex; gap:12px; }
/* CA centralizado no desktop */
.topbar .ca-center { position:absolute; left:50%; transform:translateX(-50%); display:flex; }
.ca-btn { font-size:11px; letter-spacing:.5px; background:linear-gradient(135deg,#22d18a,#18a36b); color:#fff; border:1px solid #15905f; box-shadow:0 0 0 1px #15905f, 0 0 0 4px #15905f22, 0 4px 14px -4px #22d18acc; }
.ca-btn.full { width:auto; }
.ca-btn:hover { filter:brightness(1.1); }
.toast-container { position:fixed; left:50%; bottom:18px; transform:translateX(-50%); display:flex; flex-direction:column; gap:8px; z-index:1000; pointer-events:none; }
.toast { position:relative; background:#0f2024; border:1px solid #1c474f; padding:10px 16px; border-radius:12px; font-size:13px; color:var(--text); box-shadow:0 10px 32px -8px #000, 0 0 0 1px #143338, 0 0 0 4px #14333855; animation:toastIn .35s ease, toastOut .3s ease 3.7s forwards; }
@keyframes toastIn { from { opacity:0; transform:translate(-50%,12px); } to { opacity:1; transform:translate(-50%,0); } }
@keyframes toastOut { to { opacity:0; transform:translate(-50%,-6px); } }
/* stylelint-disable-next-line selector-class-pattern */
.brand { font-weight:700; letter-spacing:1px; font-size:20px; display:flex; align-items:center; gap:6px; }
.brand .pill { filter: drop-shadow(0 0 4px #22d18a90); }
.brand-icon { width:1em; height:1em; object-fit:contain; filter:drop-shadow(0 0 4px #22d18a90); transform:translateY(2px); }
/* stylelint-disable-next-line selector-class-pattern */
.actions { display:flex; gap:12px; }
.btn { background: var(--panel); border:1px solid var(--border); color: var(--text); padding:10px 18px; border-radius:var(--radius-md); font-weight:500; cursor:pointer; position:relative; transition:.25s background, .25s border, .25s transform, .25s box-shadow; font-size:14px; }
.btn:hover { background:#162d34; }
.btn.primary { background:linear-gradient(135deg,var(--accent),var(--accent-alt)); border-color:var(--accent-alt); box-shadow:0 0 0 1px var(--accent-alt), 0 0 0 4px color-mix(in hsl, var(--accent) 40%, transparent), 0 4px 18px -4px var(--accent); }
.btn.primary:hover { filter:brightness(1.08); }
.btn.primary:focus-visible { outline:none; box-shadow:var(--focus-ring); }
.btn:active { transform:translateY(1px); }
.btn.danger { background:#33141c; border:1px solid #61202f; color:#ff6484; }
.btn.danger:hover { background:#461a25; }

/* Variante ghost */
.btn.ghost { background:rgba(255,255,255,0.03); border:1px solid #20363c; }
.btn.ghost:hover { background:rgba(255,255,255,0.06); }

/* Glow utilitário */
.glow { box-shadow:0 0 0 1px var(--accent), 0 0 12px -2px var(--accent); }

/* Cartões reutilizáveis */
.card { background:var(--panel); border:1px solid var(--border); border-radius:var(--radius-lg); padding:14px 16px; position:relative; }
.card.soft { background:linear-gradient(145deg,var(--panel),var(--bg-alt)); }

/* Mini switch (visual) */
.switch { position:relative; display:inline-flex; align-items:center; gap:8px; font-size:12px; cursor:pointer; }
.switch input { position:absolute; opacity:0; pointer-events:none; }
.switch .track { width:42px; height:22px; background:#14252b; border:1px solid #1c343a; border-radius:30px; position:relative; transition:.25s background, .25s border; }
.switch .thumb { position:absolute; top:2px; left:2px; width:18px; height:18px; background:linear-gradient(135deg,var(--accent),var(--accent-alt)); border-radius:50%; box-shadow:0 2px 6px -2px #000, 0 0 0 1px #000; transition:.30s cubic-bezier(.55,.2,.25,1); }
.switch input:checked + .track { background:#18363f; border-color:#27525c; }
.switch input:checked + .track .thumb { transform:translateX(20px); }

.layout { display:flex; flex:1; overflow:hidden; flex-direction:column; }
.panel { width:100%; background:var(--panel); border-top:1px solid var(--border); padding:14px 16px 54px; display:flex; flex-direction:column; gap:18px; overflow:auto; order:2; }
.panel h2 { margin:0 0 4px; font-size:16px; letter-spacing:.5px; font-weight:600; }
.hat-selector { display:grid; grid-template-columns:repeat(auto-fill,minmax(110px,1fr)); gap:12px; }
.hat-option { background:#0b181b; border:1px solid var(--border); border-radius:12px; cursor:pointer; padding:6px; display:flex; align-items:center; justify-content:center; transition:.25s; position:relative; }
.hat-option img { max-width:100%; pointer-events:none; }
.hat-option:hover { border-color:#1f404a; background:#112327; }
.hat-option.active { outline:2px solid #22d18a; }
.hat-upload { display:flex; margin-top:6px; }
.btn.small { padding:6px 12px; font-size:12px; }
.tips ul { margin:6px 0 0; padding-left:18px; font-size:12px; color:var(--muted); line-height:1.4; }
.tips strong { color: var(--text); font-weight:600; }
.controls { background:#0b181b; border:1px solid var(--border); padding:14px 14px 16px; border-radius:var(--radius-lg); display:flex; flex-direction:column; gap:14px; position:relative; overflow:hidden; }
.controls::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 80% 10%, rgba(255,255,255,0.04), transparent 60%); pointer-events:none; }
.controls h3 { margin:0; font-size:14px; font-weight:600; letter-spacing:.5px; }
.control-group { display:flex; flex-direction:column; gap:4px; }
.control-group label { font-size:12px; text-transform:uppercase; letter-spacing:1px; color:var(--muted); display:flex; justify-content:space-between; }
input[type=range] { width:100%; accent-color:#22d18a; }
.buttons-row { display:flex; gap:8px; flex-wrap:wrap; }
.divider { border:none; border-top:1px solid #173036; margin:4px 0 8px; }
.layers-list { display:flex; flex-direction:column; gap:6px; max-height:180px; overflow:auto; background:#0b181b; border:1px solid var(--border); padding:8px; border-radius:10px; font-size:12px; }
.layers-list.empty { opacity:.6; font-style:italic; }
.layer-item { display:flex; align-items:center; gap:8px; padding:6px 8px; border:1px solid #143036; border-radius:8px; background:#0f1d21; cursor:pointer; position:relative; }
.layer-item.active { outline:2px solid #22d18a; }
.layer-thumb { width:34px; height:24px; object-fit:contain; pointer-events:none; filter:drop-shadow(0 0 4px #000); }
.layer-meta { flex:1; display:flex; flex-direction:column; line-height:1.1; }
.layer-meta span { opacity:.7; font-size:10px; }

.canvas-wrapper { flex:1; position:relative; display:flex; align-items:center; justify-content:center; overflow:auto; padding:12px; order:1; }
.drop-zone { position:relative; border:2px dashed #1a343c; border-radius:18px; width:100%; height:100%; display:flex; align-items:center; justify-content:center; min-height:320px; background: repeating-conic-gradient(from 0deg, #0b181b 0% 25%, #0e1d21 0% 50%) 50%/40px 40px; }
.placeholder { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:22px; font-weight:500; color:#33535c; pointer-events:none; text-shadow:0 0 20px #000; }
#editorCanvas { background:#071214; border:1px solid #123039; border-radius:var(--radius-lg); max-width:100%; height:auto; box-shadow:0 6px 28px -8px #000, 0 0 0 4px #071214, 0 0 0 1px #123039; touch-action:none; }
.transform-hud { position:absolute; pointer-events:none; background:rgba(10,30,32,0.88); padding:6px 10px; border:1px solid #144b52; border-radius:8px; font-size:12px; font-weight:500; color:var(--text); box-shadow:0 4px 18px -6px #000, 0 0 0 1px #144b52, 0 0 0 4px #144b5233, 0 0 22px -4px var(--accent); backdrop-filter:blur(6px); transform:translate(-50%, -140%); white-space:nowrap; }
.transform-hud.fade { animation: hudFade .3s ease forwards; }
@keyframes hudFade { to { opacity:0; transform:translate(-50%,-160%); } }

/* Gradient selection outline effect */
.selection-glow { position:absolute; inset:0; border-radius:inherit; pointer-events:none; }

/* Curved text input styling tweaks */
#curveTextInput { background:#0b181b; border:1px solid #173036; color:var(--text); padding:8px 10px; border-radius:8px; font-size:13px; }
#curveTextInput:focus { outline:1px solid #22d18a; border-color:#22d18a; }

/* Copy PNG success state */
.btn.copied { position:relative; }
.btn.copied::after { content:'✔'; position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-weight:600; color:#fff; background:linear-gradient(135deg,#22d18a,#15905f); animation:pop .5s ease; border-radius:inherit; }
@keyframes pop { 0%{transform:scale(.4); opacity:0;} 60%{transform:scale(1.05); opacity:1;} 100%{transform:scale(1);} }

/* Add-hat micro animation (scale up) handled inline via JS by temporary class */
.hat-animating { animation: hatPop .35s cubic-bezier(.25,1.4,.4,1); }
@keyframes hatPop { 0%{ transform:scale(.7); opacity:.4;} 70%{ transform:scale(1.03); opacity:1;} 100%{ transform:scale(1);} }

.footer { text-align:center; padding:14px 20px; font-size:12px; color:#4d6972; letter-spacing:.5px; }

/* Overlay controls (visual helpers) */
.guide-handle { position:absolute; width:14px; height:14px; background:#22d18a; border:2px solid #fff; border-radius:50%; box-shadow:0 0 0 2px #22d18a88, 0 0 10px #22d18a; cursor:pointer; transform:translate(-50%, -50%); }
.guide-rotate { background:linear-gradient(#22d18a,#1aa06a); }
.selection-rect { position:absolute; border:2px dashed #22d18a; border-radius:4px; pointer-events:none; }

/* Scrollbar styling */
.panel::-webkit-scrollbar { width:10px; }
.panel::-webkit-scrollbar-track { background:#0d191d; }
.panel::-webkit-scrollbar-thumb { background:#153036; border-radius:6px; }
.panel::-webkit-scrollbar-thumb:hover { background:#1e424a; }

/* Desktop adjustments */
@media (min-width: 900px) {
  .layout { flex-direction:row; }
  .panel { width:300px; order:initial; border-top:none; border-right:1px solid var(--border); height:auto; }
  .canvas-wrapper { order:initial; padding:20px; }
}

/* Mobile refinements */
@media (max-width: 680px) {
  .topbar { flex-direction:column; gap:8px; padding:10px 14px; }
  .topbar .brand { font-size:18px; }
  .topbar .ca-center { position:static; transform:none; }
  .topbar .actions { order:3; }
  .topbar .actions .btn { padding:8px 14px; font-size:13px; }
  .ca-btn { font-size:13px; }
}
@media (max-width: 440px) {
  /* stylelint-disable-next-line selector-class-pattern */
  .brand { font-size:16px; }
  .actions .btn { padding:6px 10px; font-size:11px; }
  .ca-btn { font-size:11px; }
}
