/* ============================================================
   QRFlow – app.css
   Design: Refined dark-mode dashboard with electric accent
   Fonts: DM Sans (UI) + DM Mono (codes)
   ============================================================ */

:root {
  /* Core palette */
  --bg-base:        #0d0f14;
  --bg-surface:     #151820;
  --bg-raised:      #1c2030;
  --bg-hover:       #232740;
  --border:         #252a3a;
  --border-focus:   #4f6ef7;

  /* Text */
  --text-primary:   #e8eaf2;
  --text-secondary: #8b90a8;
  --text-muted:     #555c78;

  /* Accent – electric indigo */
  --accent:         #4f6ef7;
  --accent-hover:   #3a58e8;
  --accent-glow:    rgba(79,110,247,.25);
  --accent-subtle:  rgba(79,110,247,.10);

  /* Status */
  --success:        #28c76f;
  --danger:         #ea5455;
  --warning:        #ff9f43;

  /* Typography */
  --font-sans:  'DM Sans',  sans-serif;
  --font-mono:  'DM Mono',  monospace;

  /* Misc */
  --radius:     10px;
  --radius-lg:  16px;
  --shadow-sm:  0 2px 8px rgba(0,0,0,.4);
  --shadow-md:  0 4px 20px rgba(0,0,0,.5);
  --shadow-lg:  0 8px 40px rgba(0,0,0,.6);
  --transition: .18s ease;
}

/* ── Reset & Base ─────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-sans);
  background:  var(--bg-base);
  color:       var(--text-primary);
  min-height:  100vh;
  font-size:   15px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-hover); }

/* ── Auth Pages (login / register) ───────────────────────── */
.auth-page {
  min-height: 100vh;
  display:    flex;
  align-items: center;
  justify-content: center;
  background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(79,110,247,.12) 0%, transparent 70%),
              var(--bg-base);
  padding: 2rem 1rem;
}

.auth-card {
  background: var(--bg-surface);
  border:     1px solid var(--border);
  border-radius: var(--radius-lg);
  padding:    2.5rem 2rem;
  width:      100%;
  max-width:  420px;
  box-shadow: var(--shadow-lg);
}

.auth-logo {
  font-size:   2rem;
  font-weight: 700;
  letter-spacing: -1px;
  text-align:  center;
  margin-bottom: 1.8rem;
  color: var(--text-primary);
}
.auth-logo .accent { color: var(--accent); }
.auth-logo .icon   { font-size: 2.4rem; }

/* ── Navbar ───────────────────────────────────────────────── */
.qf-navbar {
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border);
  padding: .75rem 0;
  position: sticky;
  top: 0;
  z-index: 1030;
  backdrop-filter: blur(8px);
}

.qf-brand {
  font-weight: 700;
  font-size:   1.3rem;
  letter-spacing: -.5px;
  color: var(--text-primary) !important;
  display: flex;
  align-items: center;
  gap: .45rem;
}
.qf-brand-icon { color: var(--accent); font-size: 1.5rem; }
.qf-brand-accent { color: var(--accent); }

.qf-navbar .nav-link {
  color:       var(--text-secondary);
  font-weight: 500;
  padding:     .4rem .85rem;
  border-radius: var(--radius);
  transition:  var(--transition);
  display:     flex;
  align-items: center;
  gap:         .35rem;
}
.qf-navbar .nav-link:hover,
.qf-navbar .nav-link.active {
  color:      var(--text-primary);
  background: var(--bg-raised);
}

.qf-nav-user {
  font-size: .9rem;
  color:     var(--text-secondary);
  display:   flex;
  align-items: center;
  gap: .35rem;
}

.qf-btn-logout {
  font-size:    .85rem;
  padding:      .35rem .85rem;
  border:       1px solid var(--border);
  color:        var(--text-secondary);
  border-radius: var(--radius);
  background:   transparent;
  transition:   var(--transition);
  display:      flex;
  align-items:  center;
  gap:          .3rem;
}
.qf-btn-logout:hover {
  background: rgba(234,84,85,.1);
  border-color: var(--danger);
  color: var(--danger);
}

/* ── Page layout ──────────────────────────────────────────── */
.qf-page {
  padding: 2rem 1.5rem;
  max-width: 1200px;
  margin: 0 auto;
}

.qf-page-title {
  font-size:   1.6rem;
  font-weight: 700;
  letter-spacing: -.4px;
  margin-bottom: .25rem;
}

.qf-page-sub {
  color: var(--text-secondary);
  margin-bottom: 2rem;
  font-size: .95rem;
}

/* ── Stat cards ───────────────────────────────────────────── */
.qf-stat-card {
  background:    var(--bg-surface);
  border:        1px solid var(--border);
  border-radius: var(--radius-lg);
  padding:       1.4rem 1.6rem;
  transition:    var(--transition);
  position:      relative;
  overflow:      hidden;
}
.qf-stat-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--accent);
  opacity: 0;
  transition: var(--transition);
}
.qf-stat-card:hover::before { opacity: 1; }

.qf-stat-icon {
  width:  48px;
  height: 48px;
  border-radius: var(--radius);
  background: var(--accent-subtle);
  color:     var(--accent);
  font-size: 1.4rem;
  display:   flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
}
.qf-stat-number {
  font-size:   2rem;
  font-weight: 700;
  line-height: 1;
  margin-bottom: .2rem;
}
.qf-stat-label {
  font-size: .85rem;
  color:     var(--text-secondary);
}

/* ── QR Table ─────────────────────────────────────────────── */
.qf-card {
  background:    var(--bg-surface);
  border:        1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow:      hidden;
}

.qf-card-header {
  padding:       1rem 1.5rem;
  border-bottom: 1px solid var(--border);
  display:       flex;
  align-items:   center;
  justify-content: space-between;
  gap: 1rem;
}

.qf-card-title {
  font-weight: 600;
  font-size:   1rem;
  margin:      0;
}

.qf-table {
  width:   100%;
  border-collapse: collapse;
}
.qf-table th {
  background:   var(--bg-raised);
  color:        var(--text-secondary);
  font-size:    .78rem;
  font-weight:  600;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding:      .7rem 1.2rem;
  border-bottom: 1px solid var(--border);
  white-space:  nowrap;
}
.qf-table td {
  padding:     .85rem 1.2rem;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  font-size:   .9rem;
}
.qf-table tr:last-child td { border-bottom: none; }
.qf-table tbody tr {
  transition: background var(--transition);
}
.qf-table tbody tr:hover { background: var(--bg-hover); }

/* QR thumbnail in table */
.qf-qr-thumb {
  width:  52px;
  height: 52px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: #fff;
  object-fit: contain;
  padding: 3px;
}

/* short-code badge */
.qf-code-badge {
  font-family: var(--font-mono);
  font-size:   .8rem;
  background:  var(--accent-subtle);
  color:       var(--accent);
  padding:     .2rem .55rem;
  border-radius: 6px;
  border:      1px solid rgba(79,110,247,.2);
  white-space: nowrap;
}

/* scan count */
.qf-scan-count {
  font-family: var(--font-mono);
  font-size:   .9rem;
  font-weight: 500;
}

/* destination url truncated */
.qf-dest-url {
  max-width:    220px;
  overflow:     hidden;
  text-overflow: ellipsis;
  white-space:  nowrap;
  color:        var(--text-secondary);
  font-size:    .85rem;
  display:      block;
}

/* Action buttons */
.qf-action-btn {
  display:     inline-flex;
  align-items: center;
  justify-content: center;
  width:       32px;
  height:      32px;
  border-radius: var(--radius);
  border:      1px solid var(--border);
  background:  transparent;
  color:       var(--text-secondary);
  font-size:   .9rem;
  transition:  var(--transition);
  cursor:      pointer;
}
.qf-action-btn:hover { background: var(--bg-hover); color: var(--text-primary); }
.qf-action-btn.edit:hover   { border-color: var(--accent); color: var(--accent); }
.qf-action-btn.delete:hover { border-color: var(--danger); color: var(--danger); }
.qf-action-btn.download:hover { border-color: var(--success); color: var(--success); }
.qf-action-btn.stats:hover  { border-color: var(--warning); color: var(--warning); }

/* ── Forms ────────────────────────────────────────────────── */
.qf-form-card {
  background:    var(--bg-surface);
  border:        1px solid var(--border);
  border-radius: var(--radius-lg);
  padding:       2rem;
}

.form-label {
  color:       var(--text-secondary);
  font-size:   .85rem;
  font-weight: 500;
  margin-bottom: .4rem;
}

.form-control, .form-select {
  background:  var(--bg-raised);
  border:      1px solid var(--border);
  color:       var(--text-primary);
  border-radius: var(--radius);
  padding:     .6rem .9rem;
  font-size:   .92rem;
  transition:  border-color var(--transition), box-shadow var(--transition);
}
.form-control::placeholder { color: var(--text-muted); }
.form-control:focus, .form-select:focus {
  background:  var(--bg-raised);
  border-color: var(--accent);
  box-shadow:  0 0 0 3px var(--accent-glow);
  color:       var(--text-primary);
  outline:     none;
}
.form-control:focus { outline: none; }

.form-text { color: var(--text-muted); font-size: .82rem; }

/* ── Buttons ──────────────────────────────────────────────── */
.btn-qf-primary {
  background:    var(--accent);
  color:         #fff;
  border:        1px solid var(--accent);
  border-radius: var(--radius);
  padding:       .6rem 1.3rem;
  font-weight:   600;
  font-size:     .92rem;
  transition:    var(--transition);
  display:       inline-flex;
  align-items:   center;
  gap:           .4rem;
}
.btn-qf-primary:hover {
  background:  var(--accent-hover);
  border-color: var(--accent-hover);
  color:        #fff;
  box-shadow:   0 4px 14px var(--accent-glow);
  transform:    translateY(-1px);
}
.btn-qf-primary:active { transform: translateY(0); }

.btn-qf-secondary {
  background:  transparent;
  color:       var(--text-secondary);
  border:      1px solid var(--border);
  border-radius: var(--radius);
  padding:     .6rem 1.3rem;
  font-weight: 500;
  font-size:   .92rem;
  transition:  var(--transition);
  display:     inline-flex;
  align-items: center;
  gap:         .4rem;
}
.btn-qf-secondary:hover {
  background:  var(--bg-raised);
  color:       var(--text-primary);
}

/* ── Alerts ───────────────────────────────────────────────── */
.qf-alert {
  border-radius: var(--radius);
  padding:       .75rem 1rem;
  font-size:     .9rem;
  display:       flex;
  align-items:   flex-start;
  gap:           .6rem;
  border:        1px solid transparent;
}
.qf-alert.success {
  background: rgba(40,199,111,.1);
  border-color: rgba(40,199,111,.3);
  color: var(--success);
}
.qf-alert.error {
  background: rgba(234,84,85,.1);
  border-color: rgba(234,84,85,.3);
  color: var(--danger);
}

/* ── QR Preview panel ─────────────────────────────────────── */
.qf-qr-preview {
  background:    var(--bg-raised);
  border:        1px solid var(--border);
  border-radius: var(--radius-lg);
  padding:       2rem;
  text-align:    center;
}
.qf-qr-preview img {
  max-width: 240px;
  width:     100%;
  border-radius: var(--radius);
  border:   2px solid var(--border);
  background: #fff;
  padding:  8px;
  box-shadow: var(--shadow-md);
}
.qf-short-url-display {
  font-family:  var(--font-mono);
  font-size:    .85rem;
  color:        var(--accent);
  background:   var(--accent-subtle);
  border:       1px solid rgba(79,110,247,.2);
  border-radius: var(--radius);
  padding:      .4rem .8rem;
  margin-top:   1rem;
  word-break:   break-all;
}

/* ── Empty state ──────────────────────────────────────────── */
.qf-empty {
  text-align: center;
  padding:    4rem 2rem;
  color:      var(--text-muted);
}
.qf-empty .icon {
  font-size: 3rem;
  color:     var(--text-muted);
  opacity:   .5;
  margin-bottom: 1rem;
  display:   block;
}
.qf-empty h5 { color: var(--text-secondary); }

/* ── Analytics mini-table ─────────────────────────────────── */
.qf-log-row td { font-size: .82rem; }
.qf-log-ip {
  font-family: var(--font-mono);
  font-size:   .8rem;
  color:       var(--text-secondary);
}
.qf-log-time { color: var(--text-muted); white-space: nowrap; }

/* ── Modal overrides ──────────────────────────────────────── */
.modal-content {
  background:    var(--bg-surface);
  border:        1px solid var(--border);
  border-radius: var(--radius-lg);
  color:         var(--text-primary);
}
.modal-header {
  border-bottom: 1px solid var(--border);
  padding:       1.2rem 1.5rem;
}
.modal-footer { border-top: 1px solid var(--border); }
.btn-close { filter: invert(1) brightness(.6); }

/* ── Landing page ─────────────────────────────────────────── */
.landing-hero {
  min-height:  100vh;
  display:     flex;
  align-items: center;
  background:
    radial-gradient(ellipse 70% 50% at 50% -5%, rgba(79,110,247,.2) 0%, transparent 70%),
    var(--bg-base);
}
.hero-title {
  font-size:    clamp(2.5rem, 6vw, 4rem);
  font-weight:  800;
  letter-spacing: -2px;
  line-height:  1.1;
}
.hero-sub {
  font-size:  1.1rem;
  color:      var(--text-secondary);
  max-width:  520px;
  margin-top: 1rem;
}
.hero-badge {
  display:       inline-flex;
  align-items:   center;
  gap:           .4rem;
  background:    var(--accent-subtle);
  border:        1px solid rgba(79,110,247,.25);
  border-radius: 100px;
  padding:       .3rem .9rem;
  font-size:     .82rem;
  color:         var(--accent);
  margin-bottom: 1.5rem;
  font-weight:   500;
}
.hero-qr-demo {
  background: var(--bg-surface);
  border:     1px solid var(--border);
  border-radius: var(--radius-lg);
  padding:    2rem;
  text-align: center;
  box-shadow: var(--shadow-lg);
}

/* ── Utility ──────────────────────────────────────────────── */
.text-accent  { color: var(--accent) !important; }
.text-muted-qf{ color: var(--text-muted) !important; }
.fw-mono      { font-family: var(--font-mono); }
.bg-raised    { background: var(--bg-raised); }

/* ── Responsive tweaks ────────────────────────────────────── */
@media (max-width: 768px) {
  .qf-table th:nth-child(4),
  .qf-table td:nth-child(4),
  .qf-table th:nth-child(5),
  .qf-table td:nth-child(5) { display: none; }

  .qf-page { padding: 1.2rem .8rem; }
  .auth-card { padding: 1.8rem 1.2rem; }
}

/* ── Animations ───────────────────────────────────────────── */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
.fade-up { animation: fadeUp .4s ease both; }
.fade-up-1 { animation-delay: .05s; }
.fade-up-2 { animation-delay: .10s; }
.fade-up-3 { animation-delay: .15s; }
.fade-up-4 { animation-delay: .20s; }
