/* assets/css/style.css */

:root{
    --bg:#050505;
    --surface:#0d0d0d;
    --surface-2:#121212;
    --border:#232323;
    --accent:#d4ff00;
    --text:#f5f5f5;
    --muted:#8a8a8a;
    --success:#00ff88;
    --danger:#ff5d5d;
    --radius:14px;
    --container:1400px;
    --shadow:0 0 30px rgba(212,255,0,.08);
}

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    background:var(--bg);
    color:var(--text);
    font-family:Inter,Segoe UI,sans-serif;
    line-height:1.6;
}

.container{
    width:min(92%,var(--container));
    margin:auto;
}

a{
    color:inherit;
    text-decoration:none;
}

img{
    max-width:100%;
}

.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    padding:14px 28px;
    border-radius:10px;
    cursor:pointer;
    transition:.25s;
    font-weight:600;
}

.btn-primary{
    background:var(--accent);
    color:#000;
}

.btn-primary:hover{
    transform:translateY(-2px);
}

.btn-secondary{
    border:1px solid var(--border);
}

header{
    position:sticky;
    top:0;
    z-index:100;
    backdrop-filter:blur(20px);
    background:rgba(5,5,5,.92);
    border-bottom:1px solid var(--border);
}

.navbar{
    height:80px;
    display:flex;
    align-items:center;
    justify-content:space-between;
}

.logo{
    color:var(--accent);
    font-weight:800;
    letter-spacing:2px;
    font-size:1.2rem;
}

.nav-links{
    display:flex;
    gap:30px;
    align-items:center;
}

.hero{
    min-height:90vh;
    display:flex;
    align-items:center;
}

.hero-content{
    max-width:900px;
}

.hero h1{
    font-size:4rem;
    line-height:1.1;
    margin-bottom:25px;
}

.hero p{
    color:var(--muted);
    font-size:1.2rem;
    max-width:760px;
}

.hero-actions{
    margin-top:40px;
    display:flex;
    gap:15px;
    flex-wrap:wrap;
}

section{
    padding:110px 0;
}

.section-title{
    font-size:2.5rem;
    margin-bottom:15px;
}

.section-subtitle{
    color:var(--muted);
    max-width:800px;
}

.grid{
    display:grid;
    gap:25px;
}

.grid-3{
    grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
}

.card{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--radius);
    padding:30px;
    transition:.3s;
}

.card:hover{
    border-color:var(--accent);
    box-shadow:var(--shadow);
}

.card h3{
    margin-bottom:15px;
    color:var(--accent);
}

.pricing-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
    gap:25px;
    margin-top:60px;
}

.plan{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:18px;
    padding:35px;
    transition:.3s;
}

.plan:hover{
    border-color:var(--accent);
    transform:translateY(-5px);
}

.plan.featured{
    border:2px solid var(--accent);
}

.plan-name{
    font-size:1.3rem;
    margin-bottom:15px;
}

.plan-price{
    font-size:3rem;
    font-weight:800;
    margin-bottom:25px;
}

.plan ul{
    list-style:none;
    margin-bottom:30px;
}

.plan li{
    padding:8px 0;
    color:var(--muted);
}

.badge{
    display:inline-block;
    background:var(--accent);
    color:#000;
    padding:6px 12px;
    border-radius:999px;
    font-size:.75rem;
    font-weight:700;
    margin-bottom:20px;
}

.auth-wrapper{
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:40px;
}

.auth-card{
    width:100%;
    max-width:500px;
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:20px;
    padding:40px;
}

.auth-card h1{
    margin-bottom:30px;
}

.form-group{
    margin-bottom:18px;
}

.form-group label{
    display:block;
    margin-bottom:8px;
}

.form-group input,
.form-group textarea,
.form-group select{
    width:100%;
    background:#0a0a0a;
    border:1px solid var(--border);
    color:white;
    padding:14px;
    border-radius:10px;
}

.dashboard{
    display:grid;
    grid-template-columns:280px 1fr;
    min-height:100vh;
}

.sidebar{
    border-right:1px solid var(--border);
    padding:30px;
}

.sidebar ul{
    list-style:none;
}

.sidebar li{
    margin-bottom:15px;
}

.content{
    padding:40px;
}

.stats{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
    gap:20px;
}

.stat-card{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:14px;
    padding:25px;
}

.stat-number{
    font-size:2rem;
    font-weight:800;
    color:var(--accent);
}

.timeline{
    margin-top:30px;
}

.timeline-item{
    border-left:2px solid var(--accent);
    padding-left:20px;
    margin-bottom:30px;
}

.upload-zone{
    border:2px dashed var(--border);
    padding:50px;
    border-radius:15px;
    text-align:center;
    margin-top:20px;
}

footer{
    border-top:1px solid var(--border);
    padding:40px 0;
    text-align:center;
    color:var(--muted);
}

@media(max-width:900px){

.hero h1{
    font-size:2.8rem;
}

.dashboard{
    grid-template-columns:1fr;
}

.sidebar{
    border-right:none;
    border-bottom:1px solid var(--border);
}

.nav-links{
    display:none;
}

}

/* ── Extensions v2 ─────────────────────────────────────────────── */
:root {
  --accent-dim: rgba(212,255,0,.08);
  --accent-dim2: rgba(212,255,0,.14);
  --surface-2: #111111;
  --border-2: #2a2a2a;
  --success: #00e676;
  --danger: #ff4444;
  --warning: #ffaa00;
}

.btn:disabled { opacity:.4; cursor:not-allowed; transform:none !important; }
.btn-sm { padding:9px 18px; font-size:.82rem; }
.btn-lg { padding:16px 36px; font-size:1rem; }
.w-full  { width:100%; }
.hidden  { display:none !important; }
.text-center { text-align:center; }
.text-accent { color:var(--accent); }
.text-muted  { color:var(--muted); }
.mt-8  { margin-top:8px; }
.mt-16 { margin-top:16px; }
.mt-24 { margin-top:24px; }
.mt-32 { margin-top:32px; }
.mt-48 { margin-top:48px; }
.mb-16 { margin-bottom:16px; }
.flex  { display:flex; }
.gap-12 { gap:12px; }
.items-center { align-items:center; }
.justify-between { justify-content:space-between; }

/* Alerts */
.alert {
  padding:14px 18px; border-radius:var(--radius);
  font-size:.88rem; align-items:flex-start; gap:10px;
  margin-bottom:16px; display:none;
}
.alert.visible { display:flex; }
.alert-error   { background:rgba(255,68,68,.1);  border:1px solid rgba(255,68,68,.2);  color:var(--danger); }
.alert-success { background:rgba(0,230,118,.1);  border:1px solid rgba(0,230,118,.2);  color:var(--success); }
.alert-info    { background:var(--accent-dim);    border:1px solid var(--accent-dim2);  color:var(--accent); }

/* Auth */
.auth-subtitle { color:var(--muted); font-size:.9rem; margin-bottom:32px; }
.auth-footer   { text-align:center; margin-top:20px; font-size:.85rem; color:var(--muted); }
.auth-footer a { color:var(--accent); }

/* Form */
.form-group input:focus,
.form-group textarea:focus {
  border-color:var(--accent); outline:none;
}
.form-error { font-size:.78rem; color:var(--danger); margin-top:4px; display:none; }
.form-error.visible { display:block; }
.field-tags { display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.field-tag {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--accent-dim); border:1px solid var(--accent-dim2);
  color:var(--accent); font-size:.78rem; padding:4px 10px; border-radius:6px;
}

/* Upload zone */
.upload-zone {
  border:2px dashed var(--border); border-radius:var(--radius);
  padding:48px 24px; text-align:center; cursor:pointer; transition:.2s;
}
.upload-zone:hover, .upload-zone.drag-over {
  border-color:var(--accent); background:var(--accent-dim);
}
.upload-zone input[type=file] { display:none; }
.uploaded-file {
  display:flex; align-items:center; justify-content:space-between;
  background:var(--surface-2); border:1px solid var(--border);
  border-radius:8px; padding:10px 14px; font-size:.84rem; margin-top:8px;
}

/* Dashboard */
.app-layout { display:grid; grid-template-columns:260px 1fr; min-height:100vh; }
.sidebar {
  border-right:1px solid var(--border); padding:32px 20px;
  position:sticky; top:0; height:100vh; overflow-y:auto;
  display:flex; flex-direction:column;
}
.sidebar-logo  { padding:0 8px; margin-bottom:40px; }
.sidebar-nav   { flex:1; }
.sidebar-nav a {
  display:flex; align-items:center; gap:12px;
  padding:11px 12px; border-radius:var(--radius);
  font-size:.88rem; font-weight:500; color:var(--muted);
  transition:.15s; margin-bottom:3px;
}
.sidebar-nav a:hover  { color:var(--text); background:var(--surface); }
.sidebar-nav a.active { color:var(--accent); background:var(--accent-dim); }
.sidebar-bottom { padding-top:20px; border-top:1px solid var(--border); }
.dash-main { padding:40px 44px; }
.dash-header {
  display:flex; align-items:center; justify-content:space-between; margin-bottom:36px;
}
.stats-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:16px; margin-bottom:28px;
}
.stat-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); padding:24px 28px;
}
.stat-num   { font-size:2rem; font-weight:800; color:var(--accent); line-height:1.1; }
.stat-label { font-size:.78rem; color:var(--muted); text-transform:uppercase; letter-spacing:.1em; margin-top:4px; }
.progress-bar { height:6px; background:var(--border); border-radius:3px; overflow:hidden; margin-top:8px; }
.progress-fill { height:100%; background:var(--accent); border-radius:3px; transition:width .8s ease; }

/* Timeline */
.timeline-list { position:relative; padding-left:24px; }
.timeline-list::before {
  content:''; position:absolute; left:7px; top:0; bottom:0;
  width:1px; background:var(--border);
}
.timeline-item { position:relative; padding-bottom:24px; }
.timeline-item::before {
  content:''; position:absolute; left:-20px; top:6px;
  width:8px; height:8px; border-radius:50%;
  background:var(--border); border:1px solid var(--border);
}
.timeline-item.done::before    { background:var(--accent); border-color:var(--accent); }
.timeline-item.current::before { background:var(--accent); border-color:var(--accent); box-shadow:0 0 0 4px var(--accent-dim); }
.timeline-item.error::before   { background:var(--danger);  border-color:var(--danger); }
.timeline-label { font-size:.88rem; font-weight:500; }
.timeline-date  { font-size:.76rem; color:var(--muted); margin-top:2px; }

/* Data table */
.data-table { width:100%; border-collapse:collapse; }
.data-table th {
  text-align:left; padding:10px 14px;
  font-size:.75rem; font-weight:600; text-transform:uppercase;
  letter-spacing:.08em; color:var(--muted); border-bottom:1px solid var(--border);
}
.data-table td { padding:14px; font-size:.88rem; border-bottom:1px solid var(--border); }
.data-table tr:last-child td { border:none; }
.data-table tr:hover td { background:var(--surface-2); }

/* Badges */
.badge {
  display:inline-flex; align-items:center; gap:5px;
  font-size:.72rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.07em; padding:4px 10px; border-radius:6px;
}
.badge-waiting  { background:rgba(255,170,0,.1);  color:var(--warning); }
.badge-progress { background:rgba(212,255,0,.1);  color:var(--accent); }
.badge-done     { background:rgba(0,230,118,.1);  color:var(--success); }
.badge-sent     { background:rgba(150,150,255,.1);color:#aab4ff; }
.badge-accepted { background:rgba(0,230,118,.1);  color:var(--success); }
.badge-refused  { background:rgba(255,68,68,.1);  color:var(--danger); }
.badge-error    { background:rgba(255,68,68,.1);  color:var(--danger); }
.badge-followup { background:rgba(255,170,0,.1);  color:var(--warning); }

/* Notif dot */
.notif-dot {
  display:inline-block; width:7px; height:7px;
  border-radius:50%; background:var(--accent); margin-left:6px;
}

/* OTP */
.otp-group { display:flex; gap:12px; justify-content:center; margin:24px 0; }
.otp-input {
  width:52px; height:64px; text-align:center;
  font-size:1.5rem; font-weight:700;
  background:var(--surface-2); border:1.5px solid var(--border);
  border-radius:var(--radius); color:var(--text); outline:none;
}
.otp-input:focus { border-color:var(--accent); }

/* Steps */
.steps-nav { display:flex; gap:0; margin-bottom:48px; border-radius:var(--radius); overflow:hidden; border:1px solid var(--border); }
.step-tab {
  flex:1; padding:14px; text-align:center; font-size:.82rem; font-weight:600;
  color:var(--muted); background:var(--surface); border-right:1px solid var(--border); cursor:default;
}
.step-tab:last-child { border:none; }
.step-tab.active { background:var(--accent); color:#000; }
.step-tab.done   { color:var(--text); }
.step-panel      { display:none; }
.step-panel.active { display:block; }

/* Footer */
footer { border-top:1px solid var(--border); padding:48px 0 32px; color:var(--muted); }
.footer-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px;
}
.footer-col h4 { font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:var(--text); margin-bottom:16px; }
.footer-col a  { display:block; font-size:.84rem; color:var(--muted); margin-bottom:10px; transition:color .2s; }
.footer-col a:hover { color:var(--text); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; font-size:.78rem; padding-top:24px; border-top:1px solid var(--border); }
.footer-legal  { display:flex; gap:24px; }
.footer-legal a { color:var(--muted); }
.footer-legal a:hover { color:var(--text); }

/* Section */
section { padding:100px 0; }
.section-label { font-size:.75rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); margin-bottom:16px; display:block; }
.section-subtitle { color:var(--muted); max-width:640px; font-size:1rem; line-height:1.7; }

/* Hero extensions */
.hero-eyebrow { display:inline-flex; align-items:center; gap:8px; font-size:.8rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); margin-bottom:28px; }
.hero-eyebrow::before { content:''; width:32px; height:1px; background:var(--accent); }
.hero h1 span { color:var(--accent); }
.hero-stats { display:flex; gap:48px; margin-top:64px; padding-top:48px; border-top:1px solid var(--border); }
.hero-stat-num   { font-size:1.8rem; font-weight:800; color:var(--accent); display:block; }
.hero-stat-label { font-size:.8rem; color:var(--muted); text-transform:uppercase; letter-spacing:.1em; }

/* Card extensions */
.card-icon { width:44px; height:44px; background:var(--accent-dim); border-radius:10px; display:flex; align-items:center; justify-content:center; margin-bottom:20px; font-size:1.2rem; }
.card-accent:hover { border-color:var(--accent); box-shadow:0 0 40px rgba(212,255,0,.08); }

@media(max-width:900px) {
  .footer-grid  { grid-template-columns:1fr 1fr; }
  .app-layout   { grid-template-columns:1fr; }
  .sidebar      { display:none; }
  .dash-main    { padding:24px 20px; }
  .hero-stats   { flex-wrap:wrap; gap:28px; }
  .footer-bottom { flex-direction:column; gap:14px; text-align:center; }
}
