/* ══════════════════════════════════════════
   MyCoCar — UI v3  |  CO-CAR brand colors
   Sviluppato da Vicsam Sistemi
══════════════════════════════════════════ */

:root {
  /* CO-CAR brand: #009FE3 (barra "/" del logo) */
  --brand:        #006B9F;
  --brand-mid:    #009FE3;
  --brand-light:  #33B5EB;
  --brand-ultra:  #E6F6FD;
  --brand-glow:   rgba(0,159,227,0.26);

  --bg:           #eef2f7;
  --bg-card:      #ffffff;
  --bg-surface:   #f7f9fc;

  --text-1:       #0f172a;
  --text-2:       #475569;
  --text-3:       #94a3b8;

  --border:       #e2e8f0;

  --red:          #dc2626;
  --red-bg:       #fef2f2;
  --red-border:   #fca5a5;

  --orange:       #ea580c;
  --orange-bg:    #fff7ed;
  --orange-border:#fdba74;

  --green:        #16a34a;
  --green-bg:     #f0fdf4;
  --green-border: #86efac;

  --hdr-top:      #07111e;
  --hdr-bot:      #0e2a55;

  --r-xs: 6px;  --r-sm: 10px;  --r: 14px;  --r-lg: 20px;  --r-xl: 26px;

  --sh-xs:  0 1px 2px rgba(0,0,0,0.04);
  --sh-sm:  0 1px 3px rgba(0,0,0,0.05), 0 3px 10px rgba(0,0,0,0.06);
  --sh:     0 2px 8px rgba(0,0,0,0.06), 0 8px 24px rgba(0,0,0,0.07);
  --sh-md:  0 4px 14px rgba(0,0,0,0.08), 0 16px 40px rgba(0,0,0,0.09);
  --sh-blue: 0 4px 18px rgba(0,159,227,0.40), 0 1px 4px rgba(0,159,227,0.18);

  --nav-h:  64px;
  --safe-b: env(safe-area-inset-bottom, 0px);
}

/* ── Reset ──────────────────────────────── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family:-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Inter', sans-serif;
  background:var(--bg); color:var(--text-1); font-size:15px; line-height:1.5;
  -webkit-font-smoothing:antialiased; -webkit-tap-highlight-color:transparent; min-height:100vh;
}

/* ── Keyframes ──────────────────────────── */
@keyframes fadeUp    { from{opacity:0;transform:translateY(10px);}  to{opacity:1;transform:translateY(0);} }
@keyframes shimmer   { 0%{left:-100%;} 100%{left:200%;} }
@keyframes pulseRing { 0%{transform:scale(.92);opacity:.5;} 100%{transform:scale(1.4);opacity:0;} }
@keyframes spin      { to{transform:rotate(360deg);} }
@keyframes scaleIn   { from{opacity:0;transform:scale(.92);} to{opacity:1;transform:scale(1);} }
@keyframes scanLine  { 0%,100%{top:10%;} 50%{top:80%;} }

/* ══════════════════════════════════════════
   LOGO
══════════════════════════════════════════ */
/* Real logo image (white PNG, use on dark bg) */
.logo-img { height:28px; width:auto; display:block; }

/* Dark chip wrapper — puts white logo on any background */
.logo-chip {
  background:linear-gradient(135deg, var(--hdr-top), var(--hdr-bot));
  padding:6px 12px; border-radius:var(--r-xs);
  display:inline-flex; align-items:center;
  box-shadow:0 2px 8px rgba(0,0,0,0.3);
  flex-shrink:0;
}

/* ══════════════════════════════════════════
   APP HEADER
══════════════════════════════════════════ */
.app-header {
  background:linear-gradient(155deg, var(--hdr-top) 0%, var(--hdr-bot) 100%);
  padding:12px 20px 14px; position:sticky; top:0; z-index:100;
  box-shadow:0 2px 24px rgba(0,0,0,0.32);
}
.app-header::after {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse at 80% 50%, rgba(0,159,227,0.12) 0%, transparent 60%);
}
.app-header-inner {
  max-width:960px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  position:relative; z-index:1;
}
.hdr-left  { display:flex; align-items:center; gap:14px; }
.hdr-text .app-title    { color:#fff; font-size:16px; font-weight:700; }
.hdr-text .app-subtitle { color:#90a4ae; font-size:12px; margin-top:1px; }
.hdr-right { display:flex; align-items:center; gap:8px; }

.hdr-avatar {
  width:36px; height:36px; border-radius:50%;
  background:linear-gradient(135deg, var(--brand), var(--brand-light));
  color:#fff; font-size:13px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 2px 8px rgba(0,159,227,0.38); flex-shrink:0;
  text-decoration:none; transition:transform .15s, box-shadow .15s;
  letter-spacing:0;
}
.hdr-avatar:hover { transform:scale(1.05); box-shadow:0 4px 12px rgba(0,159,227,0.45); }

.hdr-logout {
  color:#90a4ae; font-size:12px; text-decoration:none; font-weight:500;
  padding:7px 12px; border-radius:var(--r-sm);
  border:1px solid rgba(255,255,255,0.1);
  transition:color .2s, background .2s;
}
.hdr-logout:hover { color:#fff; background:rgba(255,255,255,0.08); }

/* Desktop nav */
.hdr-nav { display:none; gap:4px; }
.hdr-nav-item {
  color:#90a4ae; font-size:13px; font-weight:600; text-decoration:none;
  padding:7px 14px; border-radius:var(--r-sm);
  transition:color .15s, background .15s;
}
.hdr-nav-item:hover  { color:#fff; background:rgba(255,255,255,0.08); }
.hdr-nav-item.active { color:#fff; background:rgba(255,255,255,0.13); }
@media(min-width:768px){ .hdr-nav { display:flex; } }

/* ── Page Header (inner pages) ──────────── */
.page-header {
  background:linear-gradient(155deg, var(--hdr-top) 0%, var(--hdr-bot) 100%);
  padding:0 20px; height:56px;
  display:flex; align-items:center; gap:12px;
  position:sticky; top:0; z-index:100;
  box-shadow:0 2px 20px rgba(0,0,0,0.28);
}
.page-header .back {
  color:#fff; text-decoration:none; font-size:24px; line-height:1;
  display:flex; align-items:center; justify-content:center;
  width:36px; height:36px; border-radius:50%; flex-shrink:0;
  opacity:.8; transition:opacity .15s, background .15s;
}
.page-header .back:hover { opacity:1; background:rgba(255,255,255,0.1); }
.page-header h1 { color:#fff; font-size:16px; font-weight:700; }
.page-header-right { margin-left:auto; }

/* ══════════════════════════════════════════
   LAYOUT
══════════════════════════════════════════ */
.main {
  max-width:960px; margin:0 auto;
  padding:20px 18px calc(var(--nav-h) + var(--safe-b) + 16px);
  animation:fadeUp .3s ease;
}
.main.no-nav { padding-bottom:28px; }
@media(min-width:768px){
  .main      { padding:28px 32px 36px; }
  .main.no-nav { padding-bottom:36px; }
}

/* Dashboard compact grid */
.dash-grid {
  display:grid; grid-template-columns:1fr; gap:0;
}
@media(min-width:768px){
  .dash-grid { grid-template-columns:300px 1fr; gap:24px; align-items:start; }
  .dash-left { position:sticky; top:76px; }
  .dash-right { margin-top:0 !important; }
}

/* ══════════════════════════════════════════
   ACTION BUTTONS
══════════════════════════════════════════ */
.btn-scan-wrap { position:relative; margin-bottom:10px; }
.btn-scan-wrap .pulse-ring {
  position:absolute; inset:0; border-radius:var(--r);
  border:2px solid rgba(0,159,227,0.35);
  animation:pulseRing 2.8s ease-out infinite;
  pointer-events:none;
}
.btn-scan {
  display:flex; align-items:center; justify-content:center; gap:11px;
  width:100%;
  background:linear-gradient(130deg, #0071B8 0%, #009FE3 55%, #33B5EB 100%);
  color:#fff; border:none; border-radius:var(--r);
  padding:18px 16px;
  font-size:15px; font-weight:800; letter-spacing:1.3px;
  cursor:pointer; text-decoration:none;
  box-shadow:var(--sh-blue);
  position:relative; overflow:hidden;
  transition:transform .12s, box-shadow .12s;
}
.btn-scan::before {
  content:''; position:absolute; top:0; left:-100%; width:55%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.15),transparent);
  animation:shimmer 4s ease-in-out infinite;
}
.btn-scan:active { transform:scale(.976); box-shadow:0 2px 10px rgba(0,159,227,.3); }

.btn-manual {
  display:flex; align-items:center; justify-content:center; gap:10px;
  width:100%;
  background:var(--bg-card); color:var(--text-1);
  border:1.5px solid var(--border); border-radius:var(--r);
  padding:15px 16px; font-size:15px; font-weight:600;
  cursor:pointer; text-decoration:none; margin-bottom:22px;
  box-shadow:var(--sh-xs);
  transition:background .15s, border-color .15s, transform .1s;
}
.btn-manual:hover  { background:var(--bg-surface); border-color:var(--brand-mid); }
.btn-manual:active { transform:scale(.98); }

/* Quick link cards (dashboard) */
.quick-card {
  display:flex; align-items:center; gap:14px;
  background:var(--bg-card); border-radius:var(--r);
  padding:18px 20px; text-decoration:none; color:var(--text-1);
  box-shadow:var(--sh-sm); border:1.5px solid var(--border);
  transition:transform .15s, box-shadow .15s, border-color .15s;
  margin-bottom:10px;
}
.quick-card:hover  { transform:translateY(-2px); box-shadow:var(--sh); border-color:var(--brand-mid); }
.quick-card:active { transform:scale(.99); }
.quick-card .qc-icon {
  width:44px; height:44px; border-radius:var(--r-sm);
  display:flex; align-items:center; justify-content:center;
  font-size:20px; flex-shrink:0;
}
.quick-card .qc-icon.blue  { background:var(--brand-ultra); }
.quick-card .qc-icon.green { background:var(--green-bg); }
.quick-card .qc-text h4   { font-size:15px; font-weight:700; }
.quick-card .qc-text p    { font-size:12px; color:var(--text-3); margin-top:2px; }
.quick-card .qc-arrow      { margin-left:auto; color:var(--text-3); font-size:20px; flex-shrink:0; }

/* ══════════════════════════════════════════
   STAT BOXES
══════════════════════════════════════════ */
.stats-row { display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; margin-bottom:20px; }
.stat-box {
  background:var(--bg-card); border-radius:var(--r-sm);
  padding:16px 8px; text-align:center;
  box-shadow:var(--sh-sm); border-top:3.5px solid var(--border);
  transition:transform .15s, box-shadow .15s;
}
.stat-box:hover { transform:translateY(-2px); box-shadow:var(--sh); }
.stat-box.red    { border-top-color:var(--red);    background:linear-gradient(170deg,var(--red-bg),#fff 65%); }
.stat-box.orange { border-top-color:var(--orange); background:linear-gradient(170deg,var(--orange-bg),#fff 65%); }
.stat-box.green  { border-top-color:var(--green);  background:linear-gradient(170deg,var(--green-bg),#fff 65%); }
.stat-box.brand  { border-top-color:var(--brand-mid); background:linear-gradient(170deg,var(--brand-ultra),#fff 65%); }
.stat-num { font-size:28px; font-weight:800; line-height:1; margin-bottom:5px; font-variant-numeric:tabular-nums; }
.stat-box.red    .stat-num { color:var(--red); }
.stat-box.orange .stat-num { color:var(--orange); }
.stat-box.green  .stat-num { color:var(--green); }
.stat-box.brand  .stat-num { color:var(--brand-mid); }
.stat-label { font-size:9px; font-weight:700; letter-spacing:.6px; color:var(--text-3); text-transform:uppercase; }

/* Section header */
.section-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.section-title  { font-size:11px; font-weight:700; color:var(--text-3); text-transform:uppercase; letter-spacing:.8px; }
.section-link   { font-size:13px; color:var(--brand-mid); font-weight:600; text-decoration:none; transition:opacity .15s; }
.section-link:hover { opacity:.75; }

/* ══════════════════════════════════════════
   TICKET CARDS
══════════════════════════════════════════ */
.ticket-card {
  background:var(--bg-card); border-radius:var(--r-sm);
  padding:14px 14px 14px 16px; margin-bottom:8px;
  box-shadow:var(--sh-sm);
  display:flex; align-items:center; gap:12px;
  text-decoration:none; color:var(--text-1);
  border-left:4px solid var(--border);
  transition:transform .15s, box-shadow .15s;
}
.ticket-card:hover   { transform:translateY(-1px); box-shadow:var(--sh); }
.ticket-card:active  { transform:scale(.99); }
.ticket-card.aperta   { border-left-color:var(--red); }
.ticket-card.in_corso { border-left-color:var(--orange); }
.ticket-card.risolta  { border-left-color:var(--green); }
.ticket-info { flex:1; min-width:0; }
.ticket-machine { font-size:11.5px; font-weight:700; color:var(--brand-mid); margin-bottom:3px; letter-spacing:.4px; }
.ticket-desc { font-size:14px; font-weight:500; color:var(--text-1); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-bottom:4px; }
.ticket-meta { font-size:11px; color:var(--text-3); }
.ticket-right { display:flex; flex-direction:column; align-items:flex-end; gap:8px; flex-shrink:0; }
.ticket-status { font-size:10px; font-weight:700; letter-spacing:.3px; padding:4px 9px; border-radius:20px; text-transform:uppercase; white-space:nowrap; }
.ticket-status.aperta   { background:var(--red-bg);    color:var(--red);    border:1px solid var(--red-border); }
.ticket-status.in_corso { background:var(--orange-bg); color:var(--orange); border:1px solid var(--orange-border); }
.ticket-status.risolta  { background:var(--green-bg);  color:var(--green);  border:1px solid var(--green-border); }
.ticket-chevron { color:var(--text-3); font-size:18px; }

/* ══════════════════════════════════════════
   FORMS
══════════════════════════════════════════ */
.form-card {
  background:var(--bg-card); border-radius:var(--r);
  padding:20px; margin-bottom:12px; box-shadow:var(--sh-sm);
}
.form-card-title {
  font-size:13px; font-weight:700; color:var(--text-1);
  margin-bottom:16px; display:flex; align-items:center; gap:10px;
}
.step-badge {
  width:24px; height:24px;
  background:var(--brand-mid); color:#fff; border-radius:50%;
  font-size:12px; font-weight:700;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.step-badge.done { background:var(--green); }
.form-group { margin-bottom:16px; }
.form-group:last-child { margin-bottom:0; }
.form-label { display:block; font-size:11px; font-weight:700; color:var(--text-3); margin-bottom:7px; text-transform:uppercase; letter-spacing:.5px; }
.form-control {
  width:100%; padding:12px 14px;
  border:1.5px solid var(--border); border-radius:var(--r-sm);
  font-size:15px; color:var(--text-1); background:#fff;
  transition:border-color .2s, box-shadow .2s;
  -webkit-appearance:none; font-family:inherit;
}
.form-control:focus { outline:none; border-color:var(--brand-mid); box-shadow:0 0 0 3px rgba(0,159,227,0.12); }
textarea.form-control { resize:vertical; min-height:110px; }

/* Buttons */
.btn-primary {
  width:100%; background:linear-gradient(130deg, #0071B8, #009FE3);
  color:#fff; border:none; border-radius:var(--r-sm);
  padding:15px; font-size:15px; font-weight:700; cursor:pointer;
  letter-spacing:.5px; box-shadow:0 3px 14px rgba(0,159,227,.28);
  transition:transform .12s, box-shadow .12s; font-family:inherit;
}
.btn-primary:hover  { box-shadow:var(--sh-blue); }
.btn-primary:active { transform:scale(.98); box-shadow:0 1px 6px rgba(0,159,227,.22); }
.btn-primary:disabled { background:#90caf9; cursor:not-allowed; box-shadow:none; }

.btn-outline {
  width:100%; background:transparent;
  color:var(--brand-mid); border:1.5px solid var(--brand-mid);
  border-radius:var(--r-sm); padding:14px;
  font-size:15px; font-weight:600; cursor:pointer;
  transition:background .15s; font-family:inherit;
  text-decoration:none; display:block; text-align:center;
}
.btn-outline:hover { background:var(--brand-ultra); }

.btn-danger {
  width:100%; background:transparent;
  color:var(--red); border:1.5px solid var(--red-border);
  border-radius:var(--r-sm); padding:14px;
  font-size:15px; font-weight:600; cursor:pointer;
  transition:background .15s; font-family:inherit;
  text-decoration:none; display:block; text-align:center;
}
.btn-danger:hover { background:var(--red-bg); }

/* ══════════════════════════════════════════
   ALERTS
══════════════════════════════════════════ */
.alert {
  padding:13px 14px; border-radius:var(--r-sm); margin-bottom:14px;
  font-size:14px; line-height:1.5;
  display:flex; align-items:flex-start; gap:10px;
}
.alert-icon { font-size:16px; flex-shrink:0; margin-top:1px; }
.alert-error   { background:var(--red-bg);    color:#991b1b; border:1px solid var(--red-border); }
.alert-success { background:var(--green-bg);  color:#166534; border:1px solid var(--green-border); }
.alert-info    { background:var(--brand-ultra); color:#0c4a6e; border:1px solid #7dd3fc; }
.alert-warning { background:var(--orange-bg); color:#9a3412; border:1px solid var(--orange-border); }

/* ══════════════════════════════════════════
   LOGIN PAGE
══════════════════════════════════════════ */
.login-page { min-height:100vh; display:flex; }

.login-brand {
  display:none;
  background:linear-gradient(155deg, var(--hdr-top) 0%, var(--hdr-bot) 100%);
  flex-direction:column; justify-content:center; padding:56px 48px;
  position:relative; overflow:hidden; flex:0 0 42%;
}
.login-brand::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse at 25% 65%, rgba(0,159,227,0.15) 0%, transparent 60%),
             radial-gradient(ellipse at 85% 15%, rgba(0,159,227,0.1) 0%, transparent 55%);
}
.login-brand-inner { position:relative; z-index:1; }
.login-brand .app-name    { color:#fff; font-size:34px; font-weight:800; margin-top:18px; letter-spacing:-.5px; }
.login-brand .app-tagline { color:#94a3b8; font-size:15px; margin-top:6px; margin-bottom:40px; line-height:1.5; }
.feat-list { list-style:none; }
.feat-list li { display:flex; align-items:flex-start; gap:14px; color:#cbd5e1; font-size:14px; margin-bottom:20px; line-height:1.45; }
.feat-icon { width:32px; height:32px; flex-shrink:0; background:rgba(0,159,227,0.2); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:14px; margin-top:1px; }
.login-powered { margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,0.08); font-size:12px; color:#475569; line-height:1.7; }
.login-powered strong { color:#94a3b8; }
.tustena-badge { display:inline-block; background:#f97316; color:#fff; font-size:9px; font-weight:800; letter-spacing:.5px; padding:2px 7px; border-radius:3px; margin-left:4px; vertical-align:middle; }

.login-form-panel {
  flex:1; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(155deg, var(--hdr-top) 0%, #0a1e40 100%);
  padding:32px 24px;
}
.login-card {
  background:#fff; border-radius:var(--r-xl);
  padding:32px 28px; width:100%; max-width:400px;
  box-shadow:0 24px 64px rgba(0,0,0,0.35), 0 4px 16px rgba(0,0,0,0.2);
}
.login-card-logo { display:flex; align-items:center; gap:12px; margin-bottom:28px; }
.login-card-logo .login-app-name { font-size:20px; font-weight:800; color:var(--text-1); }
.login-card h2  { font-size:22px; font-weight:800; color:var(--text-1); margin-bottom:5px; }
.login-card .sub{ font-size:14px; color:var(--text-2); margin-bottom:24px; }
.login-hint { margin-top:20px; padding-top:16px; border-top:1px solid var(--border); font-size:12px; color:var(--text-3); text-align:center; line-height:1.7; }

@media(min-width:768px){
  .login-brand { display:flex; }
  .login-form-panel { background:var(--bg); }
  .login-card { box-shadow:var(--sh-md); }
}

/* ══════════════════════════════════════════
   MACHINE CARD
══════════════════════════════════════════ */
.machine-card {
  background:linear-gradient(135deg,#f0f8fe,var(--brand-ultra));
  border:1.5px solid #7dd3fc; border-radius:var(--r);
  padding:16px; margin-bottom:12px;
  display:flex; align-items:center; gap:14px;
}
.machine-code-badge {
  background:linear-gradient(135deg, var(--brand), var(--brand-mid));
  color:#fff; font-size:13px; font-weight:800;
  padding:10px 13px; border-radius:var(--r-sm);
  flex-shrink:0; letter-spacing:2px; text-align:center;
  min-width:76px; box-shadow:0 2px 8px rgba(0,159,227,.3);
}
.machine-info { flex:1; min-width:0; }
.machine-info h4  { font-size:14px; font-weight:700; color:var(--text-1); }
.machine-info p   { font-size:12px; color:var(--text-2); margin-top:2px; line-height:1.4; }
.machine-info .sn { font-size:11px; color:var(--text-3); margin-top:1px; font-family:monospace; }

/* ══════════════════════════════════════════
   STEP INDICATOR
══════════════════════════════════════════ */
.step-indicator { display:flex; align-items:center; margin-bottom:20px; }
.step-item {
  display:flex; flex-direction:column; align-items:center; gap:5px;
  flex:1; font-size:10px; font-weight:600; color:var(--text-3);
  text-transform:uppercase; letter-spacing:.3px; text-align:center;
}
.step-item.active { color:var(--brand-mid); }
.step-item.done   { color:var(--green); }
.step-dot {
  width:26px; height:26px; border:2px solid var(--border); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:700; background:#fff; transition:all .2s;
}
.step-item.active .step-dot { border-color:var(--brand-mid); color:var(--brand-mid); background:var(--brand-ultra); }
.step-item.done   .step-dot { border-color:var(--green); background:var(--green); color:#fff; }
.step-line { flex:.6; height:2px; background:var(--border); margin:0 4px; margin-bottom:18px; }
.step-line.done { background:var(--green); }

/* OR divider */
.or-divider {
  display:flex; align-items:center; gap:12px;
  font-size:11px; color:var(--text-3); margin:12px 0;
  text-transform:uppercase; letter-spacing:.5px;
}
.or-divider::before, .or-divider::after { content:''; flex:1; height:1px; background:var(--border); }

/* ══════════════════════════════════════════
   FILE UPLOAD  — fix: hide native input
══════════════════════════════════════════ */
.upload-area {
  display:block;
  border:2px dashed var(--border); border-radius:var(--r);
  padding:24px 16px; text-align:center; color:var(--text-3);
  cursor:pointer; transition:border-color .2s, background .2s;
  user-select:none;
}
.upload-area:hover, .upload-area.dragover { border-color:var(--brand-mid); background:var(--brand-ultra); }
/* Hide native file input completely */
.upload-area input[type="file"] { display:none !important; }
.upload-area .up-icon { font-size:28px; margin-bottom:10px; display:block; }
.upload-area .up-text { font-size:14px; line-height:1.5; }
.upload-area .up-text strong { color:var(--brand-mid); }
.upload-area .up-hint { font-size:11px; color:var(--text-3); margin-top:4px; }
.file-list { margin-top:12px; }
.file-item {
  display:flex; align-items:center; gap:10px;
  padding:10px 12px; background:var(--bg-surface); border:1px solid var(--border);
  border-radius:var(--r-sm); margin-bottom:6px; font-size:13px;
}
.file-item .fi-icon { font-size:20px; flex-shrink:0; }
.file-item .fi-name { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--text-1); font-weight:500; }
.file-item .fi-size { color:var(--text-3); font-size:11px; flex-shrink:0; }
.file-item .fi-rm   { color:var(--red); cursor:pointer; font-size:20px; flex-shrink:0; line-height:1; background:none; border:none; padding:0; }

/* ══════════════════════════════════════════
   SUCCESS SCREEN
══════════════════════════════════════════ */
.success-screen { text-align:center; padding:32px 16px 24px; animation:scaleIn .3s ease; }
.success-icon-wrap {
  width:80px; height:80px; background:var(--green-bg); border:2px solid var(--green-border);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  margin:0 auto 20px; font-size:36px;
}
.success-screen h2 { font-size:22px; font-weight:800; margin-bottom:8px; }
.success-screen p  { color:var(--text-2); font-size:14px; margin-bottom:24px; line-height:1.6; }
.crm-ref-box { background:var(--brand-ultra); border:1.5px solid #7dd3fc; border-radius:var(--r); padding:18px 16px; margin-bottom:20px; }
.crm-ref-box .crm-label { font-size:11px; color:var(--text-3); text-transform:uppercase; letter-spacing:.6px; margin-bottom:6px; }
.crm-ref-box .crm-value { font-size:24px; font-weight:800; color:var(--brand-mid); font-family:monospace; margin-bottom:10px; }
.crm-platform-row { display:flex; align-items:center; justify-content:center; gap:6px; font-size:12px; color:var(--text-3); }
.tustena-pill { background:#f97316; color:#fff; font-size:10px; font-weight:800; letter-spacing:.5px; padding:2px 8px; border-radius:4px; }
.ts-label { color:var(--text-2); font-weight:600; }

/* ══════════════════════════════════════════
   FILTER TABS
══════════════════════════════════════════ */
.filter-tabs { display:flex; gap:8px; margin-bottom:16px; overflow-x:auto; padding-bottom:2px; scrollbar-width:none; }
.filter-tabs::-webkit-scrollbar { display:none; }
.filter-tab { flex-shrink:0; padding:8px 18px; border-radius:20px; font-size:13px; font-weight:600; border:1.5px solid var(--border); background:var(--bg-card); color:var(--text-2); cursor:pointer; text-decoration:none; transition:all .15s; white-space:nowrap; }
.filter-tab.active { background:var(--brand-mid); color:#fff; border-color:var(--brand-mid); }
.filter-tab:hover:not(.active) { border-color:var(--brand-mid); color:var(--brand-mid); }

/* ══════════════════════════════════════════
   TICKET DETAIL
══════════════════════════════════════════ */
.detail-card { background:var(--bg-card); border-radius:var(--r); box-shadow:var(--sh-sm); overflow:hidden; margin-bottom:12px; }
.detail-row { display:flex; justify-content:space-between; align-items:center; gap:12px; padding:13px 16px; border-bottom:1px solid var(--border); font-size:14px; }
.detail-row:last-child { border-bottom:none; }
.detail-row .dl { color:var(--text-2); font-size:13px; flex-shrink:0; }
.detail-row .dv { font-weight:600; text-align:right; }
.detail-desc { background:var(--bg-card); border-radius:var(--r); box-shadow:var(--sh-sm); padding:16px; font-size:14px; color:var(--text-1); line-height:1.7; margin-bottom:12px; }
.detail-section-title { font-size:11px; font-weight:700; color:var(--text-3); text-transform:uppercase; letter-spacing:.7px; margin:18px 0 8px; }
.attachment-item { display:flex; align-items:center; gap:12px; padding:12px 14px; background:var(--bg-card); border-radius:var(--r-sm); box-shadow:var(--sh-xs); border:1px solid var(--border); margin-bottom:8px; }
.attachment-item .att-icon { font-size:24px; flex-shrink:0; }
.attachment-item a { color:var(--brand-mid); text-decoration:none; font-weight:600; flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; font-size:13px; }
.attachment-item .att-size { color:var(--text-3); font-size:11px; flex-shrink:0; }

/* ══════════════════════════════════════════
   QR SCANNER
══════════════════════════════════════════ */
.scanner-wrap { border-radius:var(--r); overflow:hidden; background:#000; margin-bottom:12px; }
.scanner-status { text-align:center; font-size:13px; color:var(--text-3); padding:10px 0; }

/* ══════════════════════════════════════════
   PROFILE PAGE
══════════════════════════════════════════ */
.profile-avatar-big {
  width:72px; height:72px; border-radius:50%;
  background:linear-gradient(135deg, var(--brand), var(--brand-light));
  color:#fff; font-size:26px; font-weight:800;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 16px rgba(0,159,227,.4); margin:0 auto 16px;
}
.profile-name { font-size:20px; font-weight:800; text-align:center; color:var(--text-1); }
.profile-sub  { font-size:13px; color:var(--text-3); text-align:center; margin-top:4px; }

/* ══════════════════════════════════════════
   BOTTOM NAV (mobile)
══════════════════════════════════════════ */
.bottom-nav {
  position:fixed; bottom:0; left:0; right:0;
  height:calc(var(--nav-h) + var(--safe-b)); padding-bottom:var(--safe-b);
  background:rgba(255,255,255,0.94);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-top:1px solid var(--border);
  display:flex; align-items:center; z-index:200;
  box-shadow:0 -4px 20px rgba(0,0,0,0.08);
}
.nav-items { display:flex; width:100%; align-items:center; max-width:960px; margin:0 auto; padding:0 20px; }
.nav-item {
  flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:3px; text-decoration:none; color:var(--text-3);
  font-size:10px; font-weight:600; letter-spacing:.3px; text-transform:uppercase; padding:8px 0;
  transition:color .15s;
}
.nav-item.active { color:var(--brand-mid); }
.nav-icon { font-size:22px; line-height:1; }
.nav-item-new { flex:0 0 auto; margin:0 20px; }
.nav-fab {
  width:52px; height:52px;
  background:linear-gradient(135deg, var(--brand), var(--brand-mid));
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:26px; font-weight:300;
  box-shadow:var(--sh-blue); transform:translateY(-10px);
  transition:transform .15s, box-shadow .15s;
}
.nav-item-new:active .nav-fab { transform:translateY(-10px) scale(.94); }
@media(min-width:768px){ .bottom-nav { display:none; } }

/* ══════════════════════════════════════════
   MISC
══════════════════════════════════════════ */
.empty-state { text-align:center; padding:52px 20px; color:var(--text-3); }
.empty-state .empty-icon { font-size:52px; margin-bottom:14px; display:block; }
.empty-state p { font-size:14px; line-height:1.6; }

.code-input { font-size:22px; font-weight:800; text-align:center; letter-spacing:4px; text-transform:uppercase; padding:16px; }
.code-input::placeholder { letter-spacing:1px; font-weight:400; font-size:15px; }

.pw-strength { height:4px; border-radius:2px; margin-top:8px; background:var(--border); overflow:hidden; }
.pw-strength-bar { height:100%; transition:width .3s, background .3s; border-radius:2px; width:0; }

.spinner { display:inline-block; width:16px; height:16px; border:2.5px solid rgba(255,255,255,.4); border-top-color:#fff; border-radius:50%; animation:spin .7s linear infinite; vertical-align:middle; margin-right:8px; }

.divider { height:1px; background:var(--border); margin:20px 0; }

.onboarding-tip { display:flex; align-items:flex-start; gap:12px; background:var(--brand-ultra); border:1px solid #7dd3fc; border-radius:var(--r); padding:16px; margin-bottom:16px; }
.onboarding-tip .tip-icon { font-size:22px; flex-shrink:0; }
.onboarding-tip .tip-text { font-size:13px; color:#0c4a6e; line-height:1.5; }
.onboarding-tip .tip-text strong { display:block; margin-bottom:3px; font-size:14px; }
