/* ============================================================
   The Town Gossip, app shell, retro-comic system
   Matches the landing (web/index.html): cream + teal/coral/yellow,
   thick ink outlines, hard offset shadows, pill buttons.
   Type: Anton (display) / Pacifico (script) / Alfa Slab One
   (numbers) / Archivo (UI) / Courier (editor + log).
   NOTE: class & id names kept intact for the JS in js/*.
   ============================================================ */
:root{
  --ink:#34251A;
  --bg:#FDF6E7;
  --card:#FFFCF4;
  --teal:#16A39A; --teal-dk:#0F837B;
  --coral:#EF5740; --coral-dk:#D33F29;
  --yellow:#FFC23B; --yellow-dk:#CE8C10;
  --pink:#F2939E;
  --muted:#5b4a3b;

  --disp:"Anton",Impact,sans-serif;
  --script:"Pacifico",cursive;
  --slab:"Alfa Slab One",serif;
  --ui:"Archivo",system-ui,sans-serif;

  /* semantic aliases kept for existing markup */
  --paper:#FDF6E7;
  --paper-2:#FFFCF4;
  --card-bg:#FFFCF4;
  --cream:#FDF6E7;
  --cream-dark:#FFFCF4;
  --ink-light:#5b4a3b;
  --cherry:#16A39A; --cherry-d:#0F837B;   /* primary = teal pop */
  --teal-d:#0F837B;
  --mustard:#FFC23B; --mustard-d:#CE8C10; /* accent = yellow */
  --gold:#FFC23B; --gold-light:#FFD877; --gold-dark:#CE8C10;
  --red:#EF5740;                          /* danger = coral */
  --green:#16A39A;                        /* success = teal */
  --blue:#34251A;                         /* info = ink */
  --grey:#5b4a3b; --border:#E4D8BE;
  --white:#ffffff;
}
*{margin:0;padding:0;box-sizing:border-box}
body{
  font-family:var(--ui);background:var(--bg);color:var(--ink);
  font-size:16px;line-height:1.55;font-weight:500;min-height:100vh;
  -webkit-font-smoothing:antialiased;
  background-image:radial-gradient(rgba(52,37,26,.045) 1px,transparent 1.4px);
  background-size:15px 15px;
}

/* ---------- Auth / licence gate ---------- */
.gate{position:fixed;inset:0;background:var(--ink);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:500;
  background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1.4px);background-size:16px 16px}
.gate-card{background:var(--card);border:4px solid var(--ink);border-radius:18px;box-shadow:9px 11px 0 var(--coral);padding:2rem 1.9rem;max-width:410px;width:100%;text-align:center}
.gate-brand{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:.3rem}
.gate-brand .disc{flex:none;width:62px;height:62px;border-radius:50%;border:3px solid var(--ink);background:var(--yellow);overflow:hidden;display:grid;place-items:center}
.gate-brand .disc img{width:100%;height:100%;object-fit:contain}
.gate-brand .wm{line-height:.82;text-align:left}
.gate-brand .wm .a{display:block;font-family:var(--ui);font-weight:800;font-size:10px;letter-spacing:.25em;color:var(--coral);margin-bottom:2px}
.gate-brand .wm .b{display:block;font-family:var(--disp);font-size:30px;letter-spacing:.02em;text-transform:uppercase}
.gate-card h1{margin:0}
.gate-card h1 span{display:none}
.gate-tag{font-family:var(--script);color:var(--coral);font-size:1.2rem;margin:.1rem 0 .9rem;transform:rotate(-1.5deg)}
.gate-sub{color:var(--muted);font-size:.92rem;font-weight:600;margin-bottom:1.3rem}
.gate-card label{margin-top:.75rem;text-align:left}
.gate-btn{width:100%;margin-top:.75rem;justify-content:center}
.gate-or{display:flex;align-items:center;color:var(--ink-light);font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;margin:1rem 0 .1rem}
.gate-or::before,.gate-or::after{content:"";flex:1;height:2px;background:var(--ink);opacity:.18}
.gate-or span{padding:0 .7rem}
.btn-google{background:#fff;color:var(--ink)}.btn-google:hover{background:#f4f0e6}
.gate-msg{margin-top:.9rem;font-size:.85rem;color:var(--coral-dk);min-height:1rem;font-weight:800}

/* ---------- Header / topbar ---------- */
header{position:sticky;top:0;z-index:60;background:var(--card);color:var(--ink);border-bottom:4px solid var(--ink);
  padding:.6rem 2rem;display:flex;align-items:center;gap:1rem 1.5rem;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:11px}
.brand .disc{flex:none;width:48px;height:48px;border-radius:50%;border:3px solid var(--ink);background:var(--yellow);overflow:hidden;display:grid;place-items:center}
.brand .disc img{width:100%;height:100%;object-fit:contain}
.brand .wm{line-height:.82}
.brand .wm .a{display:block;font-family:var(--ui);font-weight:800;font-size:9.5px;letter-spacing:.25em;color:var(--coral);margin-bottom:2px}
.brand .wm .b{display:block;font-family:var(--disp);font-size:22px;letter-spacing:.02em;text-transform:uppercase}
nav{display:flex;gap:4px;flex-wrap:wrap;margin:0 auto 0 0}
nav button{background:transparent;border:none;color:var(--ink);font-family:var(--ui);font-size:13px;font-weight:800;
  text-transform:uppercase;letter-spacing:.05em;padding:.5rem .8rem;cursor:pointer;border-bottom:3px solid transparent;transition:color .15s}
nav button:hover{color:var(--coral)}
nav button.active{color:var(--coral);border-bottom-color:var(--coral)}
.head-right{display:flex;align-items:center;gap:.6rem}

.upgrade-banner{background:var(--yellow);color:var(--ink);border-bottom:4px solid var(--ink);padding:.65rem 2rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;font-family:var(--ui);font-weight:800;font-size:.85rem}

main{max-width:1100px;margin:0 auto;padding:2.4rem 2rem}
.panel{display:none;animation:fadeIn .2s ease}.panel.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

/* ---------- Headings ---------- */
h2{font-family:var(--disp);font-weight:400;font-size:2rem;text-transform:uppercase;letter-spacing:.01em;
  color:var(--ink);margin-bottom:1.3rem;padding-bottom:.45rem;border-bottom:4px solid var(--coral);display:inline-block}
h3{font-family:var(--disp);font-weight:400;font-size:1.2rem;text-transform:uppercase;letter-spacing:.01em;color:var(--ink);margin-bottom:.75rem}

/* ---------- Cards ---------- */
.card{background:var(--card);border:4px solid var(--ink);border-radius:14px;padding:1.6rem;margin-bottom:1.5rem;box-shadow:6px 7px 0 var(--ink)}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.9rem;gap:.75rem;flex-wrap:wrap}
.card-head h3{margin-bottom:0}

/* ---------- Forms ---------- */
label{display:block;font-family:var(--ui);font-size:.74rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4rem;color:var(--muted)}
input,textarea,select{width:100%;padding:.65rem .8rem;border:3px solid var(--ink);border-radius:10px;font-family:var(--ui);font-size:.95rem;font-weight:500;background:#fff;color:var(--ink)}
input::placeholder,textarea::placeholder{color:#a89a86;font-style:italic}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 3px rgba(239,87,64,.18)}
textarea{resize:vertical}
input[type=file]{font-family:var(--ui);font-size:.82rem;font-weight:600;border:none;background:transparent;padding:.3rem 0}

/* ---------- Buttons (comic pills) ---------- */
.btn{font-family:var(--ui);font-weight:900;font-size:13px;letter-spacing:.04em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.5em;cursor:pointer;padding:.7rem 1.3rem;
  border:3px solid var(--ink);border-radius:999px;box-shadow:4px 4px 0 var(--ink);
  transition:transform .08s ease,box-shadow .08s ease,background .15s ease}
.btn:hover{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}
.btn:active{transform:translate(4px,4px);box-shadow:0 0 0 var(--ink)}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:4px 4px 0 var(--ink)}
.btn-primary{background:var(--teal);color:var(--card)}.btn-primary:hover{background:var(--teal-dk)}
.btn-secondary{background:var(--ink);color:var(--card)}.btn-secondary:hover{background:#241a12}
.btn-danger{background:var(--coral);color:var(--card)}.btn-danger:hover{background:var(--coral-dk)}
.btn-outline{background:var(--card);color:var(--ink)}.btn-outline:hover{background:#fff}
.btn-sm{padding:.45rem .9rem;font-size:11.5px;box-shadow:3px 3px 0 var(--ink)}
.btn-sm:hover{box-shadow:1px 1px 0 var(--ink)}

/* ---------- Layout helpers ---------- */
.row{display:flex;gap:1rem;margin-bottom:1rem}.row>*{flex:1}
.mb-1{margin-bottom:1rem}.mb-05{margin-bottom:.5rem}.mt-1{margin-top:1rem}
.text-grey{color:var(--muted)}.text-sm{font-size:.8rem}

/* ---------- Badges ---------- */
.badge{display:inline-block;padding:.22rem .65rem;border-radius:999px;font-family:var(--ui);font-size:.66rem;font-weight:900;
  text-transform:uppercase;letter-spacing:.05em;border:2.5px solid var(--ink)}
.badge-gold{background:var(--yellow);color:var(--ink)}
.badge-green{background:#bfe7e2;color:var(--teal-dk)}
.badge-red{background:#fbd0c9;color:var(--coral-dk)}

/* ---------- Compose editor / preview ---------- */
#htmlEditor{min-height:300px;font-family:"Courier New",monospace;font-size:.85rem;line-height:1.5}
.preview-frame{width:100%;min-height:400px;border:3px solid var(--ink);border-radius:10px;background:#fff}

/* ---------- Subscriber table ---------- */
.sub-table{width:100%;border-collapse:collapse;font-size:.88rem}
.sub-table th{text-align:left;padding:.65rem .8rem;border-bottom:3px solid var(--ink);font-family:var(--ui);font-size:.72rem;
  font-weight:900;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.sub-table td{padding:.6rem .8rem;border-bottom:2px dashed var(--border)}
.sub-table tr:hover td{background:rgba(255,194,59,.16)}

/* ---------- Analytics ---------- */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}
.stat-card{background:var(--card);border:3px solid var(--ink);border-radius:12px;padding:1.25rem;text-align:center;box-shadow:5px 6px 0 var(--ink)}
.stat-card .stat-value{font-family:var(--slab);font-size:2.1rem;color:var(--coral);line-height:.9}
.stat-card .stat-label{font-family:var(--ui);font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-top:.5rem}

/* ---------- Send log (teletype) ---------- */
#sendLog{max-height:250px;overflow-y:auto;font-family:"Courier New",monospace;font-size:.8rem;background:var(--ink);color:#FFE6A6;
  padding:1rem;border-radius:10px;line-height:1.6;border:3px solid var(--ink)}
#sendLog .log-error{color:#FF9C8C}#sendLog .log-info{color:#7FD8D0}#sendLog .log-success{color:#FFE6A6}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:2rem;right:2rem;padding:.7rem 1.4rem;border-radius:999px;font-family:var(--ui);font-size:.85rem;
  font-weight:900;text-transform:uppercase;letter-spacing:.03em;color:var(--card);z-index:9999;border:3px solid var(--ink);
  box-shadow:4px 4px 0 var(--ink);animation:slideUp .3s ease}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.toast-success{background:var(--teal)}.toast-error{background:var(--coral)}.toast-info{background:var(--ink)}

/* ---------- Modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(52,37,26,.6);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}
.modal{background:var(--card);border:4px solid var(--ink);border-radius:18px;box-shadow:9px 11px 0 var(--coral);padding:2rem;max-width:500px;width:90%}
.modal h3{margin-bottom:1rem}
.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}

/* ---------- Progress ---------- */
.progress-bar{width:100%;height:12px;background:var(--card);border:3px solid var(--ink);border-radius:999px;overflow:hidden;margin:.8rem 0}
.progress-bar .fill{height:100%;background:var(--teal);transition:width .3s;width:0%}

.scheduled-item{display:flex;align-items:center;justify-content:space-between;padding:.65rem 0;border-bottom:2px dashed var(--border)}

@media(max-width:700px){
  header{padding:.6rem 1rem}
  .upgrade-banner{padding:.65rem 1rem;flex-wrap:wrap}
  .row{flex-direction:column}
  main{padding:1.3rem 1rem}
  nav button{padding:.5rem .6rem;font-size:12px}
  h2{font-size:1.6rem}
}
