/* ===== FONTS (self-hosted Inter — no Google Fonts CDN, GDPR/Schrems II) ===== */
@font-face{
  font-family:'Inter';
  font-style:normal;
  font-weight:100 900;
  font-display:swap;
  src:url('/static/fonts/inter/Inter-roman.var.woff2') format('woff2-variations'),
      url('/static/fonts/inter/Inter-roman.var.woff2') format('woff2');
}

/* ===== TOKENS (extends email Light theme) ===== */
:root{
  /* Surfaces */
  --page-bg:#EEF1F4;
  --body-bg:#FFFFFF;
  --footer-bg:#F7FAFC;

  /* Header / dark surfaces */
  --header-bg:#000B14;
  --header-text:#FFFFFF;
  --header-eyebrow:#7BCBE8;

  /* Text */
  --body-text:#0E1A24;
  --muted:#5C6B78;

  /* Borders & chips */
  --border:#E3E8EC;
  --chip-bg:#F2F5F7;
  --chip-text:#3F4D58;

  /* Accent (CTA, links) */
  --accent:#0D7FA8;
  --accent-hover:#0A678A;
  --accent-text:#FFFFFF;

  /* Badge (package, count) */
  --badge-bg:#EAF6FB;
  --badge-text:#0D5A7A;
  --badge-border:#CFE6F0;

  /* Urgent (≤7 day deadline) */
  --urgent-bg:#FFF1E8;
  --urgent-text:#A8400D;
  --urgent-border:#F5C9AE;

  /* Success status (Aktivan / Yes pills) — WEB-ONLY */
  --success:#0E7C5A;
  --success-bg:#E6F5EF;

  /* Brand */
  --brand-cyan:#23BDFF;
  --brand-cyan-light:#7BE5FF;

  /* Radii */
  --r-sm:6px;
  --r-md:8px;
  --r-lg:12px;
  --r-xl:16px;

  /* Shadows */
  --shadow-sm:0 1px 2px rgba(14,26,36,.04);
  --shadow-md:0 4px 16px -4px rgba(14,26,36,.08), 0 1px 2px rgba(14,26,36,.04);
}

/* ===== RESET ===== */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--page-bg);
  color:var(--body-text);
  font-family:'Inter','Helvetica Neue',Helvetica,Arial,sans-serif;
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* ===== TOP BAR ===== */
.topbar{
  background:var(--header-bg);
  color:var(--header-text);
  padding:14px 32px;
  display:flex;
  align-items:center;
  gap:24px;
  border-bottom:1px solid #0a1622;
}
.brand{display:flex;align-items:center;gap:10px;color:#fff;text-decoration:none}
.brand:hover{text-decoration:none}
.logo-dot{
  width:28px;height:28px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%, #7BE5FF 0%, #23BDFF 45%, #0D415E 100%);
  box-shadow:0 0 0 1px rgba(123,229,255,.25), inset 0 1px 2px rgba(255,255,255,.15);
}
.wordmark{font-size:20px;font-weight:700;letter-spacing:-.02em;color:var(--brand-cyan);line-height:1}
.wordmark b{font-weight:800}

.search{
  flex:1;max-width:520px;
  position:relative;
}
.search input{
  width:100%;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  color:#fff;
  border-radius:8px;
  padding:9px 14px 9px 38px;
  font:inherit;font-size:14px;
  outline:none;
  transition:background .15s,border-color .15s;
}
.search input::placeholder{color:rgba(255,255,255,.55)}
.search input:focus{background:rgba(255,255,255,.1);border-color:var(--brand-cyan)}
.search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:rgba(255,255,255,.55)}

.topbar-right{display:flex;align-items:center;gap:14px;margin-left:auto}
.client-pill{
  display:flex;align-items:center;gap:10px;
  padding:6px 12px 6px 8px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  font-size:13px;font-weight:500;color:#fff;
  cursor:pointer;
  transition:background .15s;
}
.client-pill:hover{background:rgba(255,255,255,.1)}
.client-avatar{
  width:24px;height:24px;border-radius:50%;
  background:linear-gradient(135deg,#23BDFF,#0D415E);
  color:#fff;display:grid;place-items:center;
  font-size:11px;font-weight:700;letter-spacing:0;
}
.caret{opacity:.6}
.ghost-btn{
  background:transparent;color:rgba(255,255,255,.7);
  border:0;font:inherit;font-size:13px;cursor:pointer;padding:6px 8px;border-radius:6px;
}
.ghost-btn:hover{color:#fff;background:rgba(255,255,255,.06)}

/* ===== SUBNAV ===== */
.subnav{
  background:#fff;
  border-bottom:1px solid var(--border);
  padding:0 32px;
  display:flex;align-items:center;justify-content:space-between;
  height:48px;
}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}
.breadcrumb a{color:var(--muted);font-weight:500}
.breadcrumb a:hover{color:var(--accent);text-decoration:none}
.breadcrumb .sep{color:#C2CCD3}
.breadcrumb .current{color:var(--body-text);font-weight:500}

.pager{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--muted)}
.pager-count{color:var(--muted);font-size:12px;padding:0 6px}
.pager-btn{
  display:flex;align-items:center;gap:6px;
  padding:6px 10px;border-radius:6px;
  color:var(--body-text);font-weight:500;
  cursor:pointer;background:transparent;border:0;font:inherit;font-size:13px;
}
.pager-btn:hover{background:var(--chip-bg);text-decoration:none}
.pager-divider{width:1px;height:18px;background:var(--border);margin:0 6px}

/* ===== TENDER DETAIL — LAYOUT ===== */
.page-detail{
  max-width:1200px;margin:0 auto;padding:32px;
  display:grid;
  grid-template-columns:minmax(0,1fr) 360px;
  gap:32px;
}

/* ===== DIGEST — LAYOUT ===== */
.page-digest{
  max-width:1200px;margin:0 auto;padding:24px 32px 48px;
}

/* ===== TENDER DETAIL — HERO ===== */
.hero{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:32px;
  box-shadow:var(--shadow-sm);
}
.hero-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.tag{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:600;
  padding:4px 10px;border-radius:999px;
  letter-spacing:.04em;text-transform:uppercase;
}
.tag-pkg{background:var(--badge-bg);color:var(--badge-text);border:1px solid var(--badge-border)}
.tag-status{background:var(--chip-bg);color:var(--chip-text);border:1px solid var(--border)}
.tag-status.success{background:var(--success-bg);color:var(--success);border-color:#BCE3D2}
.tag-status.success::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--success)}
.tag-status.danger{background:var(--urgent-bg);color:var(--urgent-text);border-color:var(--urgent-border)}
.tag-status.danger::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--urgent-text)}
.tag-status.neutral::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--chip-text)}
.tag-procedure{background:var(--chip-bg);color:var(--chip-text);border:1px solid var(--border)}

.urgent-strip{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--urgent-bg);color:var(--urgent-text);
  border:1px solid var(--urgent-border);
  border-radius:var(--r-sm);
  padding:6px 12px;
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  margin-bottom:14px;
}
.urgent-strip::before{content:"●";font-size:9px}

h1.tender-title{
  font-size:32px;font-weight:700;letter-spacing:-.02em;line-height:1.2;
  margin:0 0 18px 0;color:var(--body-text);
  text-wrap:pretty;
}

.org{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:14px}
.org-mark{
  width:36px;height:36px;border-radius:8px;
  background:linear-gradient(135deg,#0E1A24,#243748);
  color:#fff;display:grid;place-items:center;
  font-size:13px;font-weight:700;letter-spacing:.02em;
  flex-shrink:0;
}
.org-name{color:var(--body-text);font-weight:600;font-size:15px;letter-spacing:-.005em}
.org-meta{font-size:13px;color:var(--muted)}
.org-meta b{color:var(--body-text);font-weight:500}

/* ===== META GRID (key dates + value) ===== */
.meta-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  margin-top:24px;
  border:1px solid var(--border);
  border-radius:var(--r-md);
  overflow:hidden;
}
.meta-cell{
  padding:18px 20px;
  background:#fff;
  border-right:1px solid var(--border);
}
.meta-cell:last-child{border-right:0;background:#FAFCFD}
.meta-label{
  font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);margin-bottom:6px;
}
.meta-value{font-size:18px;font-weight:600;letter-spacing:-.01em;color:var(--body-text);line-height:1.2}
.meta-sub{font-size:12px;color:var(--muted);margin-top:4px;font-weight:500}
.meta-sub.urgent{color:var(--urgent-text);font-weight:600}
.meta-value.value-big{font-size:20px}
.meta-value-currency{font-size:13px;font-weight:500;color:var(--muted);margin-left:4px}

/* ===== ACTIONS ===== */
.actions{
  display:flex;gap:10px;margin-top:24px;flex-wrap:wrap;
}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 18px;border-radius:var(--r-md);
  font:inherit;font-size:14px;font-weight:600;
  cursor:pointer;border:1px solid transparent;
  transition:background .15s,border-color .15s,color .15s;
  letter-spacing:-.005em;
  text-decoration:none;
}
.btn-primary{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);text-decoration:none}
.btn-secondary{background:#fff;color:var(--body-text);border-color:var(--border)}
.btn-secondary:hover{background:var(--chip-bg);text-decoration:none}
.btn-secondary.is-active{background:var(--badge-bg);color:var(--badge-text);border-color:var(--badge-border)}
.btn-soon{position:relative}
.btn-soon::after{
  content:"uskoro";position:absolute;top:-7px;right:-7px;
  background:#0E1A24;color:#fff;font-size:9px;font-weight:600;
  padding:2px 6px;border-radius:6px;letter-spacing:.04em;text-transform:uppercase;
}
.btn-ghost{background:transparent;color:var(--muted);border:0;padding:9px 10px}
.btn-ghost:hover{color:var(--body-text);background:var(--chip-bg);text-decoration:none}
.btn-danger{background:#d23f31;color:#fff;border-color:#d23f31}
.btn-danger:hover{background:#b53528;border-color:#b53528;text-decoration:none}

/* ===== TENDER DETAIL — SECTIONS ===== */
.section{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--r-xl);padding:28px 32px;
  box-shadow:var(--shadow-sm);
  margin-top:24px;
}
.section h2{
  font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);margin:0 0 18px 0;
  display:flex;align-items:center;gap:10px;
}
.section h2 .count{
  background:var(--chip-bg);color:var(--chip-text);
  font-size:11px;padding:2px 8px;border-radius:999px;letter-spacing:0;
  text-transform:none;font-weight:600;
}

/* Lots */
.lot{
  border:1px solid var(--border);border-radius:var(--r-md);
  padding:20px 24px;margin-bottom:12px;
}
.lot:last-child{margin-bottom:0}
.lot-header{display:flex;align-items:baseline;gap:12px;margin-bottom:8px}
.lot-num{
  font-size:11px;font-weight:700;color:var(--muted);
  background:var(--chip-bg);padding:2px 8px;border-radius:6px;letter-spacing:.04em;
}
.lot-title{font-size:17px;font-weight:600;letter-spacing:-.01em;color:var(--body-text);margin:0;flex:1}
.lot-values{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:14px;
  border-top:1px solid var(--border);padding-top:14px;
}
.lot-values .meta-label{margin-bottom:4px}
.lot-values .v{font-size:15px;font-weight:600;letter-spacing:-.005em}
.lot-values .v.total{color:var(--accent)}
.lot-subjects{
  margin-top:14px;padding-top:14px;border-top:1px dashed var(--border);
  font-size:13px;color:var(--muted);
}
.lot-subjects b{color:var(--body-text);font-weight:600}

/* CPV */
.cpv-list{display:flex;flex-direction:column;gap:8px}
.cpv-row{
  display:grid;grid-template-columns:140px 1fr;gap:16px;
  padding:10px 12px;border-radius:var(--r-sm);
  transition:background .15s;
}
.cpv-row:hover{background:var(--chip-bg)}
.cpv-code{
  font-family:'JetBrains Mono','SF Mono',Menlo,monospace;
  font-size:13px;font-weight:500;color:var(--accent);
}
.cpv-name{font-size:14px;color:var(--body-text)}

/* Procedure details */
.kv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0}
.kv{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 0;border-bottom:1px solid var(--border);
}
.kv:nth-last-child(-n+2){border-bottom:0}
.kv .k{font-size:13px;color:var(--muted);font-weight:500}
.kv .v{font-size:14px;font-weight:600;color:var(--body-text)}
.kv-grid .kv:nth-child(odd){padding-right:24px;border-right:1px solid var(--border)}
.kv-grid .kv:nth-child(even){padding-left:24px}
.yes-no{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;font-weight:600;padding:3px 10px;border-radius:999px;
}
.yn-no{background:var(--chip-bg);color:var(--chip-text)}
.yn-yes{background:var(--success-bg);color:var(--success)}

/* Conditions */
.condition{
  border:1px solid var(--border);border-radius:var(--r-md);
  margin-bottom:10px;overflow:hidden;background:#fff;
}
.condition:last-child{margin-bottom:0}
.condition-head{
  display:flex;align-items:center;gap:14px;
  padding:16px 20px;cursor:pointer;
  background:#fff;
  transition:background .15s;
  list-style:none;
}
.condition-head::-webkit-details-marker{display:none}
.condition-head:hover{background:#FAFCFD}
.condition-icon{
  width:32px;height:32px;border-radius:8px;
  background:var(--badge-bg);color:var(--badge-text);
  display:grid;place-items:center;font-size:14px;font-weight:700;
  flex-shrink:0;
}
.condition-title{flex:1;font-size:15px;font-weight:600;color:var(--body-text)}
.condition-type{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-right:12px}
.chev{transition:transform .2s;color:var(--muted)}
.condition[open] .chev{transform:rotate(180deg)}
.condition-body{
  padding:0 20px 18px 66px;font-size:14px;color:var(--muted);line-height:1.6;
  border-top:1px solid var(--border);padding-top:14px;
}

/* ===== SIDEBAR ===== */
.sidebar{
  display:flex;flex-direction:column;gap:16px;
  position:sticky;top:24px;align-self:start;
}
.countdown{
  background:var(--header-bg);color:#fff;
  border-radius:var(--r-xl);padding:24px;
  position:relative;overflow:hidden;
}
.countdown::before{
  content:"";position:absolute;top:-40px;right:-40px;
  width:140px;height:140px;border-radius:50%;
  background:radial-gradient(circle,rgba(35,189,255,.25),transparent 70%);
}
.countdown-label{
  font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;
  color:var(--header-eyebrow);margin-bottom:12px;
  position:relative;
}
.countdown-value{
  font-size:48px;font-weight:700;letter-spacing:-.03em;line-height:1;
  color:#fff;margin-bottom:6px;
  position:relative;
  font-variant-numeric:tabular-nums;
}
.countdown-value .unit{font-size:18px;font-weight:500;color:var(--header-eyebrow);margin-left:6px;letter-spacing:0}
.countdown-when{font-size:13px;color:rgba(255,255,255,.7);position:relative}
.countdown-when b{color:#fff;font-weight:600}
.countdown-bar{
  position:relative;margin-top:18px;
  height:4px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden;
}
.countdown-bar i{
  display:block;height:100%;
  background:linear-gradient(90deg,var(--brand-cyan),var(--brand-cyan-light));
}
.countdown-bar-meta{
  display:flex;justify-content:space-between;
  font-size:10px;text-transform:uppercase;letter-spacing:.06em;
  color:rgba(255,255,255,.5);margin-top:6px;
  position:relative;
}

.side-card{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--r-xl);padding:20px 22px;
}
.side-card h3{
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);margin:0 0 12px 0;
}
.side-row{
  display:flex;justify-content:space-between;align-items:flex-start;gap:12px;
  padding:8px 0;font-size:13px;
}
.side-row + .side-row{border-top:1px solid var(--border)}
.side-row .k{color:var(--muted);font-weight:500}
.side-row .v{color:var(--body-text);font-weight:600;text-align:right}

.nav-arrows{display:flex;flex-direction:column;gap:8px}
.nav-arrow{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;border:1px solid var(--border);border-radius:var(--r-md);
  background:#fff;text-decoration:none;color:inherit;
  transition:border-color .15s,background .15s;
}
.nav-arrow:hover{border-color:var(--accent);background:#FAFCFD;text-decoration:none}
.nav-arrow .dir{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:2px;display:flex;align-items:center;gap:4px}
.nav-arrow .nt{font-size:13px;font-weight:500;color:var(--body-text);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.nav-arrow.next .dir{justify-content:flex-end}
.nav-arrow.next .nt{text-align:right}

.personalized{
  background:#FAFCFD;border:1px dashed var(--badge-border);
  border-radius:var(--r-md);padding:14px 16px;
  font-size:13px;color:var(--badge-text);
  display:flex;gap:10px;align-items:flex-start;
}
.personalized .check{
  width:18px;height:18px;border-radius:50%;
  background:var(--accent);color:#fff;display:grid;place-items:center;
  font-size:10px;flex-shrink:0;margin-top:1px;
}
.personalized b{color:var(--body-text);font-weight:600;display:block;margin-bottom:2px}

/* ===== DIGEST — HERO BAND ===== */
.hero-band{
  background:linear-gradient(180deg,#000B14 0%,#0A1F2D 100%);
  color:#fff;padding:36px 32px 32px;
  border-bottom:1px solid #0a1622;
  position:relative;overflow:hidden;
}
.hero-band::before{
  content:"";position:absolute;top:-100px;right:-100px;
  width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle,rgba(35,189,255,.12),transparent 70%);
  pointer-events:none;
}
.hero-inner{max-width:1200px;margin:0 auto;position:relative}
.hero-eyebrow{
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;
  color:var(--header-eyebrow);margin-bottom:12px;
  display:flex;align-items:center;gap:10px;
}
.hero-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--brand-cyan);box-shadow:0 0 0 4px rgba(35,189,255,.18)}
.hero-greet{font-size:14px;color:rgba(255,255,255,.55);margin-bottom:6px}
.hero-h1{
  font-size:40px;font-weight:700;letter-spacing:-.02em;line-height:1.15;
  margin:0 0 22px 0;text-wrap:pretty;max-width:780px;
}
.hero-h1 .accent-num{
  background:linear-gradient(180deg,var(--brand-cyan-light),var(--brand-cyan));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  font-weight:800;
}
.hero-stats{display:flex;gap:32px;flex-wrap:wrap}
.hero-stat{display:flex;flex-direction:column;gap:2px}
.hero-stat .v{font-size:22px;font-weight:700;letter-spacing:-.01em;color:#fff;font-variant-numeric:tabular-nums}
.hero-stat .v.urgent{color:#FFB48A}
.hero-stat .l{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.55);font-weight:600}
.hero-divider{width:1px;align-self:stretch;background:rgba(255,255,255,.1)}

/* ===== DIGEST — TOOLBAR ===== */
.toolbar{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  margin-bottom:18px;
}
.filter-chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 12px;border-radius:999px;
  background:#fff;border:1px solid var(--border);
  font-size:13px;font-weight:500;color:var(--body-text);
  cursor:pointer;font-family:inherit;
  transition:border-color .15s,background .15s;
  user-select:none;
  text-decoration:none;
}
.filter-chip:hover{border-color:var(--accent);background:#FAFCFD;text-decoration:none}
.filter-chip .count{
  background:var(--chip-bg);color:var(--chip-text);
  padding:1px 7px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:0;
}
.filter-chip.is-active{
  background:var(--badge-bg);border-color:var(--badge-border);color:var(--badge-text);
}
.filter-chip.is-active .count{background:var(--badge-text);color:#fff}
.filter-chip.is-active::before{content:"✓";font-weight:700;font-size:12px}

.toolbar-divider{width:1px;height:24px;background:var(--border);margin:0 4px}

.sort-select{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 12px;border-radius:999px;
  background:#fff;border:1px solid var(--border);
  font-size:13px;font-weight:500;color:var(--body-text);
  font-family:inherit;cursor:pointer;
}
.sort-select:hover{border-color:var(--accent)}
.sort-select .l{color:var(--muted);font-weight:400}

.toolbar-meta{margin-left:auto;display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted)}
.results-count{font-weight:500;color:var(--body-text)}

/* ===== DIGEST — GROUPS ===== */
.group{margin-top:32px}
.group:first-of-type{margin-top:8px}
.group-head{
  display:flex;align-items:baseline;gap:12px;
  padding:0 4px 12px 4px;
  border-bottom:1px solid var(--border);
  margin-bottom:14px;
}
.group-head h2{
  font-size:18px;font-weight:700;letter-spacing:-.01em;
  margin:0;color:var(--body-text);
}
.group-head .count-badge{
  background:var(--badge-bg);color:var(--badge-text);
  border:1px solid var(--badge-border);
  font-size:11px;font-weight:600;
  padding:2px 9px;border-radius:10px;letter-spacing:0;
}
.group-head.is-urgent h2{color:var(--urgent-text)}
.group-head.is-urgent{border-bottom-color:var(--urgent-border)}
.group-head.is-urgent .count-badge{background:var(--urgent-bg);color:var(--urgent-text);border-color:var(--urgent-border)}
.group-head .desc{margin-left:auto;font-size:13px;color:var(--muted)}
.urgent-icon{
  width:20px;height:20px;border-radius:50%;
  background:var(--urgent-bg);border:1px solid var(--urgent-border);
  display:inline-grid;place-items:center;
  font-size:10px;color:var(--urgent-text);
}

/* ===== DIGEST — CARDS ===== */
.cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.card{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--r-lg);padding:18px 20px;
  display:flex;flex-direction:column;gap:12px;
  text-decoration:none;color:inherit;
  transition:border-color .15s,box-shadow .15s,transform .15s;
  cursor:pointer;
  position:relative;
}
.card:hover{
  border-color:var(--accent);
  box-shadow:var(--shadow-md);
  text-decoration:none;
}
.card.is-urgent{border-color:var(--urgent-border)}
.card.is-urgent:hover{border-color:var(--urgent-text)}
.card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.card-eyebrow{
  font-size:11px;font-weight:600;color:var(--muted);
  text-transform:uppercase;letter-spacing:.06em;
}
.urgent-tag{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--urgent-bg);color:var(--urgent-text);
  border:1px solid var(--urgent-border);
  border-radius:4px;padding:3px 8px;
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
}
.urgent-tag::before{content:"●";font-size:8px}
.pkg-tag{
  background:var(--chip-bg);color:var(--chip-text);
  font-size:11px;font-weight:600;
  padding:3px 8px;border-radius:4px;
  text-transform:uppercase;letter-spacing:.04em;
  white-space:nowrap;
}
.card h3{
  font-size:16px;font-weight:600;letter-spacing:-.005em;line-height:1.4;
  margin:0;color:var(--body-text);text-wrap:pretty;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.authority{
  font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;
  color:var(--muted);
  display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;
}
.card-meta{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  padding-top:12px;border-top:1px solid var(--border);
}
.card-meta > div{padding:0 16px;border-right:1px solid var(--border)}
.card-meta > div:first-child{padding-left:0}
.card-meta > div:last-child{padding-right:0;border-right:0;text-align:right}
.card-meta .ml{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:3px}
.card-meta .mv{font-size:13px;font-weight:600;color:var(--body-text);font-variant-numeric:tabular-nums}
.card-meta .mv.urgent{color:var(--urgent-text)}
.card-meta .mv .sub{display:block;font-size:11px;font-weight:500;color:var(--muted);margin-top:1px}
.card-meta .mv.urgent .sub{color:var(--urgent-text);opacity:.85}

.show-more{
  display:flex;align-items:center;justify-content:center;gap:8px;
  margin-top:12px;padding:12px;
  background:transparent;border:1px dashed var(--border);
  border-radius:var(--r-md);color:var(--accent);
  font:inherit;font-size:13px;font-weight:600;cursor:pointer;
  width:100%;
  transition:background .15s,border-color .15s;
}
.show-more:hover{background:#FAFCFD;border-color:var(--accent);border-style:solid}

/* ===== DIGEST — SUBSCRIPTION STRIP ===== */
.subscription{
  margin-top:48px;
  background:#fff;border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:24px 28px;
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
}
.sub-icon{
  width:44px;height:44px;border-radius:10px;
  background:var(--badge-bg);color:var(--badge-text);
  display:grid;place-items:center;flex-shrink:0;
}
.sub-text{flex:1;min-width:240px}
.sub-text b{display:block;font-size:15px;font-weight:600;color:var(--body-text);margin-bottom:2px}
.sub-text span{font-size:13px;color:var(--muted)}
.sub-actions{display:flex;gap:8px;flex-wrap:wrap}

/* The digest subscription strip uses smaller btn variants */
.subscription .btn{
  padding:9px 14px;
  font-size:13px;
  gap:6px;
}

/* ===== DIGEST — EMPTY STATE ===== */
.empty-state{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:32px 32px;margin-top:24px;
  box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;gap:8px;align-items:flex-start;
}
.empty-state h2{
  font-size:20px;font-weight:700;letter-spacing:-.01em;
  margin:0;color:var(--body-text);
}
.empty-state p{margin:0;font-size:14px;color:var(--muted);line-height:1.55}

/* ===== DASHBOARD — PAGINATION ===== */
/* Used by /moji-tenderi when the result set spans multiple pages.
   Each side is a btn + the middle holds a small "page X of N" label. */
.pagination{
  display:flex;justify-content:space-between;align-items:center;
  gap:12px;flex-wrap:wrap;margin-top:24px;
}
.pagination-status{
  flex:0 0 auto;font-size:13px;color:var(--muted);
  font-variant-numeric:tabular-nums;
}
/* Style a non-clickable disabled pagination boundary the same shape as
   the active button so the layout doesn't jump on the first/last page. */
.btn.is-disabled{
  cursor:not-allowed;opacity:0.5;pointer-events:none;
}

/* ===== PAGE FOOTER ===== */
.page-footer{
  background:var(--footer-bg);border-top:1px solid var(--border);
  padding:28px 32px;color:var(--muted);font-size:12px;
  margin-top:48px;
}
.page-footer-inner{max-width:1200px;margin:0 auto;display:flex;flex-wrap:wrap;gap:20px;align-items:center;justify-content:space-between}
.page-footer a{color:var(--accent);font-weight:600;margin-right:14px}

/* ===== MOBILE ===== */
@media (max-width:960px){
  .page-detail{grid-template-columns:1fr;padding:20px;gap:20px}
  .sidebar{position:static;flex-direction:row;flex-wrap:wrap}
  .sidebar > *{flex:1;min-width:240px}
  .meta-grid{grid-template-columns:repeat(2,1fr)}
  .meta-cell:nth-child(2){border-right:0}
  .meta-cell:nth-child(-n+2){border-bottom:1px solid var(--border)}
  .kv-grid{grid-template-columns:1fr}
  .kv-grid .kv{padding:14px 0!important;border-right:0!important;border-bottom:1px solid var(--border)!important}
  .kv-grid .kv:last-child{border-bottom:0!important}
  .topbar{padding:12px 16px;flex-wrap:wrap}
  .search{order:3;width:100%;flex-basis:100%;max-width:none}
  .subnav{padding:0 16px;height:auto;flex-direction:column;align-items:flex-start;padding-top:10px;padding-bottom:10px;gap:8px}
  h1.tender-title{font-size:24px}
  .hero,.section{padding:20px}
  .lot-values{grid-template-columns:1fr}
  .lot-values > *{padding:8px 0}
  .countdown-value{font-size:40px}
}

@media (max-width:880px){
  .hero-band{padding:24px 16px}
  .hero-h1{font-size:28px}
  .hero-stats{gap:18px}
  .hero-stat .v{font-size:18px}
  .hero-divider{display:none}
  .page-digest{padding:20px 16px 32px}
  .cards-grid{grid-template-columns:1fr}
  .toolbar{gap:8px}
  .toolbar-meta{margin-left:0;width:100%}
  .group-head{flex-wrap:wrap}
  .group-head .desc{margin-left:0;width:100%}
}

/* ===== SIGNUP / SUCCESS PAGE ============================================ */

/* Centered single-column layout. Same chrome (topbar + page-footer) as the
   tender detail / digest pages, just a narrower content column. */
.page-narrow{
  max-width:720px;
  margin:0 auto;
  padding:32px;
}
@media (max-width:720px){
  .page-narrow{padding:20px}
}

.page-eyebrow{
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;
  color:var(--badge-text);margin-bottom:8px;
}
.page-h1{
  font-size:28px;font-weight:700;letter-spacing:-.02em;line-height:1.25;
  color:var(--body-text);margin:0 0 6px;
}
.page-lead{
  font-size:15px;color:var(--muted);line-height:1.55;margin:0 0 24px;
}

/* The form sits inside a single white card so the layout reads as one unit. */
.form-card{
  background:var(--body-bg);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:28px 32px;
  box-shadow:var(--shadow-sm);
}
@media (max-width:720px){
  .form-card{padding:20px}
}

.form-section + .form-section{margin-top:28px}

.form-section-h2{
  font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);margin:0 0 12px;
}

.form-field{margin-bottom:16px}
.form-field:last-child{margin-bottom:0}

.form-label{
  display:block;font-size:13px;font-weight:600;color:var(--body-text);
  margin-bottom:6px;
}
.form-label .req{color:var(--urgent-text);margin-left:2px;font-weight:700}

.form-input{
  width:100%;
  font:inherit;font-size:14px;
  background:#fff;color:var(--body-text);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:10px 14px;
  transition:border-color .15s,box-shadow .15s;
}
.form-input::placeholder{color:#A8B3BC}
.form-input:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(13,127,168,.12);
}

.form-help{
  display:block;margin-top:6px;font-size:12px;color:var(--muted);line-height:1.5;
}

.form-error-banner{
  background:var(--urgent-bg);
  border:1px solid var(--urgent-border);
  color:var(--urgent-text);
  border-radius:var(--r-md);
  padding:12px 16px;margin-bottom:20px;
  font-size:13px;line-height:1.5;
}
.form-error-banner b{display:block;margin-bottom:4px;font-size:13px}
.form-error-banner ul{margin:4px 0 0;padding-left:20px}
.form-error-banner li{margin:2px 0}

/* Info banner — shown above the signup form when the user arrived via an
   admin-issued invite link. Same shape as form-error-banner so layout is
   consistent, but uses the badge palette (cyan/teal) to read as "you're
   on a happy path", not "fix this". */
.form-info-banner{
  background:var(--badge-bg);
  border:1px solid var(--badge-border);
  color:var(--badge-text);
  border-radius:var(--r-md);
  padding:12px 16px;margin-bottom:20px;
  font-size:13px;line-height:1.5;
}

/* Success banner — shown after a settings save or any other "we did the
   thing you asked" confirmation. Green-tinted shape mirroring
   form-error-banner so headers/messaging slot in identically. */
.form-success-banner{
  background:#E7F6EC;
  border:1px solid #B7DFC6;
  color:#1D5A35;
  border-radius:var(--r-md);
  padding:12px 16px;margin-bottom:20px;
  font-size:13px;line-height:1.5;
}
.form-success-banner b{display:block;margin-bottom:4px;font-size:13px}

/* Visual hint for readonly inputs (invite-pre-filled email). Muted backdrop
   + not-allowed cursor signal "this is locked, not editable". */
.form-input[readonly]{
  background:var(--chip-bg);
  color:var(--muted);
  cursor:not-allowed;
}

/* Two-column grid of selectable cards for packages.
   Each card carries its own checkbox; clicking anywhere in the card toggles
   it (the <label> wraps the input). Hover + checked states tinted with the
   badge palette so they read as "selected" without screaming. */
.checkbox-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
}
@media (max-width:640px){
  .checkbox-grid{grid-template-columns:1fr}
}

.checkbox-card{
  display:flex;align-items:flex-start;gap:12px;
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:12px 14px;
  background:#fff;cursor:pointer;
  transition:border-color .15s,background .15s;
}
.checkbox-card:hover{border-color:var(--accent);background:#FAFCFD}
.checkbox-card input[type=checkbox]{
  margin:2px 0 0;flex:none;width:16px;height:16px;
  accent-color:var(--accent);cursor:pointer;
}
.checkbox-card:has(input:checked){
  border-color:var(--badge-border);background:var(--badge-bg);
}
.checkbox-card-title{
  font-size:14px;font-weight:600;color:var(--body-text);line-height:1.35;
  margin:0 0 2px;
}
.checkbox-card-desc{
  font-size:12px;color:var(--muted);line-height:1.45;
}

/* Inline checkboxes used for delivery channels — flex row instead of grid. */
.checkbox-inline-row{
  display:flex;flex-wrap:wrap;gap:8px;
}
.checkbox-inline{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid var(--border);
  border-radius:999px;
  padding:7px 14px;
  background:#fff;cursor:pointer;
  font-size:13px;font-weight:500;color:var(--body-text);
  transition:border-color .15s,background .15s;
}
.checkbox-inline:hover{border-color:var(--accent);background:#FAFCFD}
.checkbox-inline input[type=checkbox]{
  width:14px;height:14px;accent-color:var(--accent);cursor:pointer;
}
.checkbox-inline:has(input:checked){
  border-color:var(--badge-border);background:var(--badge-bg);color:var(--badge-text);
}

.form-actions{margin-top:28px;display:flex;gap:10px;flex-wrap:wrap}

/* Success page — green-tinted result card; reuses .form-card for the wrapper. */
.success-card{
  background:#E6F5EF;
  border:1px solid #B5E0C9;
  border-radius:var(--r-md);
  padding:18px 20px;
  margin-bottom:20px;
}
.success-card dl{margin:0;display:grid;grid-template-columns:max-content 1fr;
  gap:8px 16px;font-size:14px}
.success-card dt{color:var(--muted);font-weight:500}
.success-card dd{margin:0;color:var(--body-text);font-weight:600}
.success-card ul{margin:6px 0 0;padding-left:20px;color:var(--body-text)}

.next-step-card{
  background:var(--badge-bg);
  border:1px solid var(--badge-border);
  border-radius:var(--r-md);
  padding:18px 20px;margin-top:16px;
}
.next-step-card h3{
  margin:0 0 6px;font-size:15px;font-weight:600;color:var(--badge-text);
}
.next-step-card p{margin:0;font-size:14px;color:var(--body-text);line-height:1.55}
.next-step-card code{
  background:#fff;border:1px solid var(--badge-border);
  border-radius:4px;padding:1px 6px;font-size:13px;
  font-family:'JetBrains Mono','SF Mono',Menlo,monospace;
}

/* ============================================================
   PWA Faza 1 — mobile + standalone overrides (2026-05-11).
   Breakpoint 768px = iPhone Plus / small tablet boundary.
   Above it, the existing desktop rules win. Below it, we
   tighten padding, hide secondary nav, and ensure touch
   targets meet Apple's 44px minimum.
   The /admin/* surface uses inline CSS in each template and
   gets its mobile rules from /static/css/admin-mobile.css —
   the block here only governs the public/digest/signup chrome.
   ============================================================ */
@media (max-width:768px){
  /* iOS prevents page zoom on form focus only when font-size >= 16px.
     Set on all form controls so digest, signup, settings, contact
     forms behave the same. Min-height bumps controls into the 44px
     touch-target band. */
  input[type="text"], input[type="email"], input[type="number"],
  input[type="tel"], input[type="search"], input[type="url"],
  input[type="password"], select, textarea{
    font-size:16px;
    min-height:44px;
  }
  button, .btn, .form-card button[type="submit"]{
    min-height:44px;
    padding:10px 16px;
  }

  /* Reserve space at the page foot for the mobile tab bar (Task 6).
     Stacks above the page-footer so neither overlaps content. */
  body{padding-bottom:64px}
}

/* Standalone display mode — once the user installs to home screen.
   Hides chrome that only makes sense in a browser tab (the topbar
   "Pomoć" ghost button is a placeholder; revisit when we wire help). */
@media (display-mode:standalone){
  .topbar .browser-only{display:none}
}

/* ============================================================
   PWA install hint + iOS hint banner
   ============================================================ */
.pwa-install-btn{
  display:none;  /* JS flips to inline-block when beforeinstallprompt fires */
  background:var(--brand-cyan);color:#000B14;
  border:none;border-radius:var(--r-md);
  font-weight:600;cursor:pointer;
  padding:8px 14px;font-size:13px;
  margin-left:8px;
}
.pwa-install-btn:hover{background:var(--brand-cyan-light)}

.ios-install-hint{
  display:none;  /* JS flips to block on iOS Safari, non-standalone */
  background:var(--badge-bg);color:var(--badge-text);
  border-bottom:1px solid var(--badge-border);
  padding:8px 16px;font-size:13px;text-align:center;
}

/* ============================================================
   Mobile bottom-tab nav (Task 6)
   Hidden by default; @media query below flips to flex on narrow
   viewports. Lives at the bottom of every consumer-facing page
   (admin pages handle their own copy via admin-mobile.css).
   ============================================================ */
.mobile-tab-bar{
  display:none;
  position:fixed;
  bottom:0;left:0;right:0;
  background:var(--header-bg);
  border-top:1px solid #2a3a48;
  z-index:100;
  justify-content:space-around;
  padding:4px 0;
}
.mobile-tab-bar .tab{
  flex:1;
  display:flex;flex-direction:column;align-items:center;
  padding:6px 0;
  text-decoration:none;
  color:rgba(255,255,255,0.7);
  font-size:11px;
}
.mobile-tab-bar .tab.active{color:var(--brand-cyan)}
.mobile-tab-bar .tab-icon{font-size:20px}

@media (max-width:768px){
  .mobile-tab-bar{display:flex}
}

/* ============================================================
   PRODUCT DISCLAIMERS
   ============================================================ */

/* Accuracy pill — discreet "informativni alat" reminder shown at
   the top of UI surfaces where users make decisions on our data
   (digest, tender detail). Soft cyan/teal palette mirrors
   .form-info-banner so it reads as informational, not alarming.
   Rendered by templates/_partials/_accuracy_pill.html. */
.accuracy-pill{
  display:flex;align-items:flex-start;gap:8px;
  background:var(--badge-bg);
  border:1px solid var(--badge-border);
  color:var(--badge-text);
  border-radius:var(--r-md);
  padding:8px 12px;
  margin:12px auto;
  max-width:1100px;
  font-size:12.5px;line-height:1.45;
}
.accuracy-pill__icon{flex:0 0 auto;font-size:14px;line-height:1.2}
.accuracy-pill__text{flex:1 1 auto}
.accuracy-pill a{color:inherit;text-decoration:underline}

