/* KLAUDE · CostaCX — panel de tareas
   Navy #042C53 · Amber #EAAF0C */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root{
  --navy:#042C53;
  --navy-900:#021c36;
  --navy-800:#06335f;
  --navy-700:#0b426f;
  --amber:#EAAF0C;
  --amber-soft:#f6cd54;
  --ink:#e8eef6;
  --muted:#8aa1bd;
  --line:rgba(138,161,189,.18);
  --ok:#3fb37f;
  --warn:#EAAF0C;
  --err:#e2614f;
  --radius:14px;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --sans:'Sora',system-ui,sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:
    radial-gradient(900px 500px at 85% -10%, rgba(234,175,12,.10), transparent 60%),
    radial-gradient(700px 600px at -10% 110%, rgba(11,66,111,.45), transparent 55%),
    var(--navy-900);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}

/* Grano sutil */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;opacity:.035;z-index:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wordmark{font-weight:700;letter-spacing:.14em;font-size:2.2rem}
.wordmark.sm{font-size:1.2rem}
.wordmark .dot{color:var(--amber)}

/* ---- Login ---- */
.login-body{display:grid;place-items:center;padding:24px}
.login-card{
  position:relative;z-index:1;width:min(360px,92vw);
  background:linear-gradient(180deg,var(--navy-800),var(--navy-900));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:36px 30px;box-shadow:0 30px 80px rgba(0,0,0,.5);
  animation:rise .5s ease both;
}
.login-card .subtitle{color:var(--muted);margin:.2rem 0 1.6rem;font-size:.85rem;letter-spacing:.04em}
.login-card label{display:block;font-size:.78rem;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.08em}
.login-card input,textarea,.dropzone{font-family:var(--sans)}
.login-card input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid var(--line);background:var(--navy-900);color:var(--ink);font-size:1rem}
.login-card input:focus{outline:none;border-color:var(--amber)}
button{
  margin-top:18px;width:100%;padding:12px;border:none;border-radius:10px;cursor:pointer;
  background:var(--amber);color:var(--navy-900);font-weight:700;font-size:1rem;letter-spacing:.02em;
  transition:transform .12s ease,background .2s ease;
}
button:hover{background:var(--amber-soft);transform:translateY(-1px)}
.alert{background:rgba(226,97,79,.14);border:1px solid rgba(226,97,79,.4);color:#ffd7cf;padding:10px 12px;border-radius:10px;font-size:.85rem;margin-bottom:14px}

/* ---- Topbar ---- */
.topbar{
  position:relative;z-index:1;display:flex;justify-content:space-between;align-items:center;
  padding:18px 28px;border-bottom:1px solid var(--line);
}
.topbar-right{display:flex;align-items:center;gap:16px}
.owner{color:var(--muted);font-size:.82rem;letter-spacing:.06em}
.logout{color:var(--ink);text-decoration:none;font-size:.85rem;border:1px solid var(--line);padding:6px 14px;border-radius:8px}
.logout:hover{border-color:var(--amber);color:var(--amber)}

/* ---- Layout ---- */
.wrap{position:relative;z-index:1;max-width:860px;margin:0 auto;padding:28px 20px 60px;display:grid;gap:22px}
.panel{
  background:linear-gradient(180deg,rgba(6,51,95,.55),rgba(2,28,54,.55));
  border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;
  animation:rise .45s ease both;
}
.panel h2{margin:0 0 16px;font-size:1.05rem;font-weight:600;letter-spacing:.02em}
.list-head{display:flex;justify-content:space-between;align-items:baseline}
.muted{color:var(--muted);font-size:.74rem;font-family:var(--mono)}

/* ---- Form nueva tarea ---- */
.new-task label{display:block;font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin:14px 0 6px}
.new-task label:first-of-type{margin-top:0}
textarea{
  width:100%;padding:12px 14px;border-radius:10px;border:1px solid var(--line);
  background:var(--navy-900);color:var(--ink);font-size:.95rem;resize:vertical;
}
textarea:focus{outline:none;border-color:var(--amber)}
.dropzone{
  border:1.5px dashed var(--line);border-radius:12px;padding:22px;text-align:center;
  background:rgba(2,28,54,.4);transition:border-color .2s,background .2s;
}
.dropzone.drag{border-color:var(--amber);background:rgba(234,175,12,.07)}
.dz-text{margin:0;color:var(--ink);font-size:.92rem}
.dz-hint{margin:6px 0 0;color:var(--muted);font-size:.76rem;font-family:var(--mono)}
.link{display:inline;width:auto;margin:0;padding:0;background:none;color:var(--amber);font-weight:600;text-decoration:underline;cursor:pointer}
.link:hover{background:none;transform:none;color:var(--amber-soft)}
.file-list{list-style:none;margin:14px 0 0;padding:0;display:grid;gap:6px}
.file-list li{font-family:var(--mono);font-size:.8rem;color:var(--ink);background:var(--navy-900);border:1px solid var(--line);border-radius:8px;padding:8px 12px;display:flex;justify-content:space-between;align-items:center}
.file-list .rm{color:var(--err);cursor:pointer;font-weight:700}

/* ---- Lista de trabajos ---- */
.empty{color:var(--muted);font-size:.9rem;padding:14px 0}
.job{
  display:flex;justify-content:space-between;gap:16px;align-items:flex-start;
  padding:16px 0;border-top:1px solid var(--line);animation:rise .4s ease both;
}
.job:first-child{border-top:none}
.job-id{font-family:var(--mono);font-size:.72rem;color:var(--muted);letter-spacing:.02em}
.job-title{margin-top:3px;font-size:.96rem;font-weight:500;line-height:1.4}
.job-side{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}
.badge{font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:999px;white-space:nowrap}
.badge.queued{background:rgba(138,161,189,.18);color:var(--muted)}
.badge.working{background:rgba(234,175,12,.16);color:var(--amber-soft)}
.badge.working::after{content:"";display:inline-block;width:6px;height:6px;margin-left:6px;border-radius:50%;background:var(--amber);animation:pulse 1s infinite}
.badge.question{background:rgba(234,175,12,.2);color:var(--amber-soft)}
.badge.answered{background:rgba(63,179,127,.14);color:#8fe0bb}
.badge.done{background:rgba(63,179,127,.18);color:#8fe0bb}
.badge.error{background:rgba(226,97,79,.18);color:#ffb3a6}
.dl{font-size:.82rem;color:var(--navy-900);background:var(--amber);padding:6px 14px;border-radius:8px;text-decoration:none;font-weight:700}
.dl:hover{background:var(--amber-soft)}

.job-question{margin-top:10px;background:rgba(234,175,12,.08);border:1px solid rgba(234,175,12,.3);border-radius:10px;padding:12px 14px;font-size:.88rem;line-height:1.5}
.answer-form{display:flex;gap:8px;margin-top:10px}
.answer-form input{flex:1;padding:9px 12px;border-radius:8px;border:1px solid var(--line);background:var(--navy-900);color:var(--ink);font-size:.88rem}
.answer-form input:focus{outline:none;border-color:var(--amber)}
.answer-form button{margin:0;width:auto;padding:9px 16px;font-size:.85rem}
.job-error{margin-top:8px;color:#ffb3a6;font-size:.84rem;font-family:var(--mono)}

@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}

@media(max-width:560px){
  .wrap{padding:18px 14px 50px}
  .panel{padding:18px 16px}
  .job{flex-direction:column}
  .job-side{flex-direction:row;align-items:center}
}
