/* ====================================================================
   MPG Design System — app.css
   Path: public_html/assets/css/app.css
   Premium Light Theme  ·  Poppins + Inter  ·  Mobile-first
   Used in tandem with Tailwind CDN inside layout.php
   ==================================================================== */

:root{
  --primary:#0f766e;
  --primary-600:#0e6b63;
  --primary-50:#ecfdf5;
  --secondary:#f59e0b;
  --secondary-600:#d97706;
  --bg:#f8fafc;
  --card:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --border:#e2e8f0;
  --success:#16a34a;
  --danger:#dc2626;
}

html,body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,.font-display{
  font-family:'Poppins',sans-serif;
  letter-spacing:-0.01em;
}

.container-x{max-width:1280px;margin:0 auto;padding:0 1rem;}
@media(min-width:768px){.container-x{padding:0 2rem;}}

/* -------- Buttons -------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.75rem 1.25rem;font-weight:600;border-radius:.625rem;
  transition:all .2s ease;font-size:.9375rem;white-space:nowrap;cursor:pointer;border:0;}
.btn:disabled{opacity:.6;cursor:not-allowed;}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 1px 2px rgba(15,118,110,.2);}
.btn-primary:hover{background:var(--primary-600);transform:translateY(-1px);box-shadow:0 8px 20px -8px rgba(15,118,110,.5);}
.btn-secondary{background:var(--secondary);color:#0f172a;}
.btn-secondary:hover{background:var(--secondary-600);color:#fff;transform:translateY(-1px);}
.btn-outline{background:#fff;color:var(--text);border:1px solid var(--border);}
.btn-outline:hover{border-color:var(--primary);color:var(--primary);}
.btn-ghost{color:var(--text);background:transparent;}
.btn-ghost:hover{background:#f1f5f9;}
.btn-danger{background:var(--danger);color:#fff;}

/* -------- Cards -------- */
.card{background:var(--card);border:1px solid var(--border);border-radius:1rem;transition:all .25s ease;}
.card-hover:hover{transform:translateY(-4px);box-shadow:0 20px 40px -20px rgba(15,23,42,.15);border-color:#cbd5e1;}

/* -------- Pills / Badges -------- */
.pill{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:600;}
.pill-live{background:#fee2e2;color:#b91c1c;}
.pill-live::before{content:"";width:.4rem;height:.4rem;border-radius:9999px;background:#dc2626;animation:pulse 1.5s infinite;}
.pill-soon{background:#fef3c7;color:#92400e;}
.pill-new{background:var(--primary-50);color:var(--primary);}
.pill-success{background:#dcfce7;color:#15803d;}

@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.4;}}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}
.float{animation:float 6s ease-in-out infinite;}

/* -------- Hero -------- */
.gradient-hero{
  background:
    radial-gradient(ellipse at top right, rgba(245,158,11,.12), transparent 50%),
    radial-gradient(ellipse at bottom left, rgba(15,118,110,.10), transparent 50%),
    linear-gradient(180deg,#ffffff 0%, #f8fafc 100%);
}
.gradient-text{
  background:linear-gradient(135deg,#0f766e 0%, #f59e0b 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.dot-grid{
  background-image:radial-gradient(circle, #cbd5e1 1px, transparent 1px);
  background-size:24px 24px;
}
.ring-soft{box-shadow:0 0 0 8px rgba(15,118,110,.06);}

/* -------- Nav -------- */
.nav-link{position:relative;color:#334155;font-weight:500;font-size:.9375rem;padding:.5rem 0;}
.nav-link:hover{color:var(--primary);}
.nav-link.active{color:var(--primary);}
.nav-link.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--primary);border-radius:2px;}
.mobile-menu{transform:translateX(100%);transition:transform .3s ease;}
.mobile-menu.open{transform:translateX(0);}

/* -------- Forms -------- */
.input,.select,.textarea{
  width:100%;padding:.7rem .9rem;border:1px solid var(--border);border-radius:.625rem;
  background:#fff;color:var(--text);font:inherit;outline:none;transition:border-color .2s, box-shadow .2s;
}
.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(15,118,110,.15);}
.label{display:block;font-size:.8125rem;font-weight:600;color:#334155;margin-bottom:.4rem;}
.hint{font-size:.75rem;color:var(--muted);margin-top:.3rem;}
.error{font-size:.75rem;color:var(--danger);margin-top:.3rem;}

/* -------- Wizard progress -------- */
.wiz-steps{display:flex;gap:.5rem;align-items:center;}
.wiz-steps .dot{flex:1;height:6px;background:#e2e8f0;border-radius:9999px;}
.wiz-steps .dot.active{background:var(--primary);}
.wiz-steps .dot.done{background:var(--secondary);}

/* -------- Voting progress bar -------- */
.progress{height:6px;background:#e2e8f0;border-radius:9999px;overflow:hidden;}
.progress > div{height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary));border-radius:9999px;transition:width .6s ease;}

/* -------- Misc -------- */
.stat-num{font-variant-numeric:tabular-nums;}
.scroll-x{scrollbar-width:none;}
.scroll-x::-webkit-scrollbar{display:none;}

/* -------- Flash messages -------- */
.flash{padding:.85rem 1rem;border-radius:.625rem;margin-bottom:1rem;font-size:.9rem;border:1px solid;}
.flash-success{background:#f0fdf4;color:#15803d;border-color:#bbf7d0;}
.flash-error{background:#fef2f2;color:#b91c1c;border-color:#fecaca;}
.flash-info{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe;}
