/* SnapGen by Snaphomz — Brand Theme */
:root {
  --orange:     #F07820;
  --orange-dk:  #C45E10;
  --orange-lt:  #F9A55A;
  --bg:         #18181B;
  --bg2:        #1F1F23;
  --bg3:        #2A2A30;
  --border:     #38383F;
  --text:       #F0F0F0;
  --text-muted: #9A9AA8;
  --green:      #22C55E;
  --red:        #EF4444;
  --blue:       #3B82F6;
}
*{box-sizing:border-box;scroll-behavior:smooth}
body{font-family:system-ui,-apple-system,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);margin:0;padding:0;line-height:1.6;min-height:100vh;display:flex;flex-direction:column}

/* Navbar */
.navbar{background:var(--bg2);border-bottom:2px solid var(--orange);padding:0 24px;display:flex;align-items:center;gap:8px;height:60px;flex-wrap:wrap}
.navbar .brand{display:flex;align-items:center;margin-right:20px}
.navbar .brand img{height:32px}
.navbar a{color:var(--text-muted);text-decoration:none;padding:6px 12px;border-radius:6px;font-size:.9rem;font-weight:500;transition:.15s}
.navbar a:hover{color:var(--text);background:var(--bg3)}
.navbar a.active{color:var(--orange);background:rgba(240,120,32,.12)}
.navbar .spacer{flex:1}
.navbar .logout{color:var(--text-muted);font-size:.85rem}

/* Layout */
.wrap{max-width:860px;margin:0 auto;padding:28px 20px;flex:1}
h1{color:var(--orange);font-size:1.75rem;margin:0 0 6px;font-weight:700}
h2{color:var(--text);font-size:1.25rem;font-weight:600}
.subtitle{color:var(--text-muted);margin:0 0 24px;font-size:.95rem}

/* Cards */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:24px;margin:16px 0}
.card-title{font-weight:600;color:var(--text);margin:0 0 16px;font-size:1rem}

/* Form */
.form-group{margin:14px 0}
label{display:block;margin-bottom:5px;color:var(--text-muted);font-size:.85rem;font-weight:500}
input,select,textarea{width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:.95rem;outline:none;transition:border-color .15s}
input:focus,select:focus,textarea:focus{border-color:var(--orange)}
select option{background:var(--bg2)}
textarea{min-height:100px;resize:vertical}

/* Buttons */
.btn{background:var(--orange);color:#fff;border:none;padding:12px 28px;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:600;width:100%;transition:background .15s,transform .1s}
.btn:hover:not(:disabled){background:var(--orange-dk)}
.btn:active:not(:disabled){transform:scale(.98)}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn-sm{padding:7px 16px;font-size:.85rem;width:auto}
.btn-ghost{background:transparent;color:var(--orange);border:1px solid var(--orange)}
.btn-ghost:hover:not(:disabled){background:rgba(240,120,32,.1)}
.btn-danger{background:var(--red)}
.btn-danger:hover:not(:disabled){background:#c53030}

/* Status / alerts */
.status-box{padding:12px 16px;border-radius:8px;margin:12px 0;font-size:.9rem;border-left:4px solid}
.status-info{background:rgba(59,130,246,.1);border-color:var(--blue)}
.status-success{background:rgba(34,197,94,.1);border-color:var(--green)}
.status-error{background:rgba(239,68,68,.1);border-color:var(--red)}
.status-warning{background:rgba(240,120,32,.1);border-color:var(--orange)}

/* Badge */
.badge-free{color:var(--green);font-size:.7rem;font-weight:700;margin-left:4px;letter-spacing:.4px}
.badge-orange{background:rgba(240,120,32,.15);color:var(--orange);padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:600}

/* Progress */
.progress{height:4px;background:var(--bg3);border-radius:4px;overflow:hidden;margin:12px 0}
.progress-bar{height:100%;background:linear-gradient(90deg,var(--orange),var(--orange-lt));width:0;transition:width .4s;border-radius:4px}

/* Media preview */
.media-preview{margin:16px 0;text-align:center}
.media-preview img,.media-preview video{max-width:100%;border-radius:10px;border:1px solid var(--border);max-height:600px;object-fit:contain}
.media-preview a{display:inline-block;margin-top:8px;color:var(--orange);text-decoration:none;font-size:.9rem;font-weight:500}
.media-preview a:hover{text-decoration:underline}

/* Info strip */
.info-strip{background:rgba(240,120,32,.08);border:1px solid rgba(240,120,32,.25);border-radius:8px;padding:10px 14px;font-size:.85rem;color:var(--orange-lt);margin-bottom:12px}
.info-strip strong{color:var(--orange)}

/* Table */
table{width:100%;border-collapse:collapse;font-size:.9rem}
th{text-align:left;padding:10px 12px;color:var(--text-muted);border-bottom:1px solid var(--border);font-weight:600}
td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text)}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.02)}

/* Footer disclaimer */
.footer{background:var(--bg2);border-top:1px solid var(--border);padding:14px 24px;text-align:center;font-size:.78rem;color:var(--text-muted);line-height:1.6}
.footer strong{color:var(--text)}

/* Job queue cards */
.job-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:12px;transition:border-color .2s}
.job-card:hover{border-color:var(--orange)}
.job-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:2px}
.job-label{font-size:.9rem;font-weight:500;color:var(--text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.job-badge{padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:700;letter-spacing:.4px;white-space:nowrap}
.job-badge.pending{background:rgba(240,120,32,.15);color:var(--orange)}
.job-badge.done{background:rgba(34,197,94,.15);color:var(--green)}
.job-badge.error{background:rgba(239,68,68,.15);color:var(--red)}
.job-progress{height:3px;background:var(--bg3);border-radius:3px;overflow:hidden;margin:8px 0 10px}
.job-bar{height:100%;background:linear-gradient(90deg,var(--orange),var(--orange-lt));width:0;transition:width .6s;border-radius:3px}

/* Login centered layout */
.center-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}
.login-box{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:40px 36px;width:100%;max-width:420px;box-shadow:0 8px 40px rgba(0,0,0,.4)}
.login-box .logo{display:block;margin:0 auto 24px;height:40px}
.login-box h1{font-size:1.4rem;margin:0 0 4px;text-align:center}
.login-box .sub{text-align:center;color:var(--text-muted);margin:0 0 28px;font-size:.9rem}
.err-msg{color:var(--red);font-size:.85rem;margin-top:12px;min-height:20px;text-align:center}
