/* ===================================================
   skolskedokumenty.sk – Globálny štýlopis
   =================================================== */

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

:root {
  --white:      #ffffff;
  --off-white:  #f2f6fa;
  --blue-light: #e8f1fb;
  --blue-mid:   #c2d9f5;
  --blue-soft:  #1a6abf;
  --blue-deep:  #14549a;
  --green-pale: #e2f4ec;
  --green-soft: #1e8a60;
  --green-mid:  #166648;
  --text-dark:  #0e1e2e;
  --text-body:  #3d5567;
  --text-muted: #7a92a5;
  --border:     #ccdaeb;
  --red:        #c93030;
  --orange:     #d4780a;
  --yellow:     #b8960a;
  --gap: clamp(24px, 3vw, 64px);
  --pad: clamp(24px, 4vw, 80px);
}

html { scroll-behavior: smooth; }
body {
  font-family: 'DM Sans', sans-serif;
  background: var(--white);
  color: var(--text-dark);
  overflow-x: hidden;
}

/* ══════════════════════════════════════════
   NAV
══════════════════════════════════════════ */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px var(--pad);
  background: var(--white);
  border-bottom: 2px solid var(--blue-light);
  animation: fadeDown .6s ease forwards;
}
@keyframes fadeDown { from{opacity:0;transform:translateY(-14px)} to{opacity:1;transform:none} }

.logo {
  display: flex; align-items: center; gap: 10px;
  font-family: 'DM Serif Display', serif;
  font-size: clamp(1rem, 1.4vw, 1.3rem); color: var(--blue-deep);
  text-decoration: none; white-space: nowrap;
}
.logo-icon {
  width: 32px; height: 32px; flex-shrink: 0;
  background: var(--blue-soft);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: .9rem;
}

.nav-left { display: flex; align-items: center; gap: clamp(10px,1.2vw,20px); }
.nav-right { display: flex; gap: clamp(8px,1.2vw,18px); align-items: center; }

.btn-omne {
  background: transparent;
  border: 1.5px solid var(--blue-mid);
  color: var(--blue-deep);
  padding: clamp(6px,.55vw,9px) clamp(13px,1.2vw,20px);
  border-radius: 50px;
  font-family: 'DM Sans', sans-serif;
  font-size: clamp(.74rem,.74vw,.88rem);
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 6px;
  transition: background .2s, border-color .2s, color .2s;
  white-space: nowrap;
}
.btn-omne:hover { background: var(--blue-light); border-color: var(--blue-soft); }

.nav-soon-wrap { display: flex; flex-direction: column; align-items: center; gap: 3px; }
.soon-tag {
  font-size: clamp(.52rem,.5vw,.65rem); font-weight: 700; letter-spacing: .05em;
  color: var(--green-mid); text-transform: uppercase; line-height: 1;
}
.soon-spacer { height: 13px; }

/* ── Buttons ── */
.btn {
  display: inline-flex; align-items: center;
  padding: clamp(7px,.6vw,10px) clamp(14px,1.4vw,22px);
  border-radius: 50px; font-family: 'DM Sans', sans-serif;
  font-size: clamp(.75rem,.75vw,.9rem); font-weight: 600;
  border: none; transition: all .2s; text-decoration: none; white-space: nowrap;
  cursor: pointer;
}
.btn-outline { background: var(--white); border: 2px solid var(--border); color: var(--text-dark); }
.btn-outline:hover { border-color: var(--blue-soft); color: var(--blue-soft); background: var(--blue-light); }
.btn-primary { background: var(--blue-soft); color: #fff; border: 2px solid var(--blue-soft); }
.btn-primary:hover { background: var(--blue-deep); border-color: var(--blue-deep); transform: translateY(-1px); }
.btn-green   { background: var(--green-soft); color: #fff; border: 2px solid var(--green-soft); }
.btn-green:hover { background: var(--green-mid); border-color: var(--green-mid); transform: translateY(-1px); }
.btn-ghost   { background: transparent; color: rgba(255,255,255,.85); border: 2px solid rgba(255,255,255,.4); cursor: pointer; }
.btn-ghost:hover { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.7); }
.btn-white   { background: var(--white); color: var(--blue-deep); font-weight: 700; border: 2px solid var(--white); }
.btn-white:hover { background: var(--blue-light); border-color: var(--blue-light); transform: translateY(-1px); }
.btn-danger  { background: var(--red); color: #fff; border: 2px solid var(--red); }
.btn-danger:hover { background: #a82626; border-color: #a82626; }

/* ── Nav auth area ── */
.nav-auth-guest { display: flex; gap: clamp(8px,1.2vw,18px); align-items: flex-end; }
.nav-auth-user  { display: flex; align-items: center; gap: 12px; }
.nav-user-chip  {
  display: flex; align-items: center; gap: 8px;
  background: var(--blue-light); border: 2px solid var(--blue-mid); border-radius: 50px;
  padding: 6px 14px 6px 8px; font-size: .82rem; font-weight: 600; color: var(--blue-deep);
}
.nav-user-avatar {
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--blue-soft);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: .72rem; font-weight: 700; flex-shrink: 0;
}
.btn-logout {
  font-size: .78rem; padding: 6px 14px;
  border-radius: 50px; border: 1.5px solid rgba(168,204,232,.6);
  background: transparent; color: var(--text-muted); cursor: pointer;
  transition: all .2s; font-family: 'DM Sans', sans-serif; font-weight: 600;
}
.btn-logout:hover { border-color: var(--red); color: var(--red); }

/* ── Admin panel button ── */
.btn-admin {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--text-dark);
  color: #fff; border: 2px solid var(--text-dark); border-radius: 50px;
  padding: 7px 16px; font-size: .78rem; font-weight: 700;
  cursor: pointer; font-family: 'DM Sans', sans-serif;
  transition: background .18s, border-color .18s, transform .15s; letter-spacing: .03em;
}
.btn-admin:hover { background: var(--blue-deep); border-color: var(--blue-deep); transform: translateY(-1px); }
.btn-admin .admin-badge {
  background: var(--green-soft); border-radius: 4px;
  padding: 1px 5px; font-size: .62rem; letter-spacing: .05em;
}

/* ── Admin Dropdown ── */
.admin-dropdown-wrap { position: relative; }
.admin-dropdown {
  position: absolute; top: calc(100% + 12px); right: 0;
  width: 360px;
  background: var(--white);
  border: 2px solid var(--border);
  border-radius: 16px;
  box-shadow: 0 8px 24px rgba(14,30,46,.12);
  overflow: hidden;
  opacity: 0; visibility: hidden; transform: translateY(-8px);
  transition: opacity .22s, visibility .22s, transform .22s;
  z-index: 999;
}
.admin-dropdown.open { opacity: 1; visibility: visible; transform: none; }

.admin-dropdown-header {
  padding: 16px 20px 12px;
  background: var(--text-dark);
  color: #fff;
}
.admin-dropdown-header h4 { font-size: .88rem; font-weight: 700; margin-bottom: 2px; }
.admin-dropdown-header p  { font-size: .72rem; opacity: .72; }

.admin-section { padding: 14px 20px; }
.admin-section-title {
  font-size: .68rem; font-weight: 700; letter-spacing: .07em;
  text-transform: uppercase; color: var(--text-muted); margin-bottom: 10px;
}

.active-users-list { display: flex; flex-direction: column; gap: 6px; max-height: 220px; overflow-y: auto; }
.active-user-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; border-radius: 10px;
  background: var(--off-white); font-size: .78rem;
}
.active-user-avatar {
  width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, var(--blue-soft), var(--blue-deep));
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: .68rem; font-weight: 700;
}
.active-user-avatar.green { background: linear-gradient(135deg, var(--green-soft), var(--green-mid)); }
.active-user-info { flex: 1; min-width: 0; }
.active-user-name { font-weight: 600; color: var(--text-dark); }
.active-user-meta { font-size: .68rem; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.active-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--green-mid); flex-shrink: 0; animation: pulse 2s infinite; }
.admin-divider { height: 1px; background: rgba(168,204,232,.25); margin: 0 20px; }
.admin-dropdown-footer { padding: 12px 20px; }
.admin-footer-link {
  display: block; text-align: center; font-size: .76rem; color: var(--blue-deep);
  font-weight: 600; text-decoration: none; padding: 7px;
  border-radius: 8px; transition: background .2s;
}
.admin-footer-link:hover { background: var(--blue-light); }
.admin-empty { text-align: center; padding: 16px; color: var(--text-muted); font-size: .8rem; }

/* ── Mobile Nav ── */
@media (max-width: 600px) {
  nav { padding: 11px 16px; }
  .logo-text { display: none; }
  .btn-omne { font-size: .76rem; padding: 7px 13px; gap: 4px; }
  .nav-right { display: none; }
}

/* ══════════════════════════════════════════
   HERO
══════════════════════════════════════════ */
.hero-wrap {
  padding-top: 60px;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: #dce9f6;
  border-bottom: 2px solid #bdd2e8;
  position: relative;
  overflow: hidden;
}

/* blobs removed */
.blob { display: none; }

.hero-grid {
  flex: 1;
  display: grid;
  grid-template-columns: 1fr minmax(240px, 1.1fr) 1fr;
  gap: var(--gap);
  padding: clamp(32px, 5vh, 80px) var(--pad) clamp(32px, 5vh, 72px);
  align-items: center;
  position: relative; z-index: 2;
  width: 100%;
}

.hero-left { animation: fadeUp .8s .2s ease both; }
@keyframes fadeUp { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:none} }

.hero-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--white);
  border: 2px solid var(--green-soft);
  color: var(--green-soft);
  border-radius: 8px;
  padding: clamp(4px,.4vw,6px) clamp(10px,1vw,14px);
  font-size: clamp(.65rem,.6vw,.78rem); font-weight: 700; letter-spacing: .05em;
  margin-bottom: clamp(14px,1.8vw,22px); text-transform: uppercase;
}
.badge-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--green-mid); animation: pulse 2s infinite; flex-shrink: 0;
}
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.5)} }

.hero-left h1 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(2rem, 3.6vw, 4.2rem);
  line-height: 1.1; color: var(--text-dark);
  margin-bottom: clamp(12px,1.4vw,18px);
}
.hero-left h1 em { font-style: italic; color: var(--blue-soft); }

.hero-sub {
  font-size: clamp(.9rem,1vw,1.08rem); line-height: 1.72;
  color: var(--text-body); margin-bottom: clamp(22px,2.5vw,34px);
}

.hero-auth { display: flex; flex-direction: column; gap: 8px; align-items: flex-start; }
.auth-soon-label {
  font-size: clamp(.64rem,.6vw,.76rem); font-weight: 600; color: var(--green-mid);
  letter-spacing: .04em; text-transform: uppercase;
  display: flex; align-items: center; gap: 6px;
}
.auth-soon-label::before {
  content: ''; display: inline-block;
  width: clamp(14px,1.4vw,22px); height: 1.5px;
  background: var(--green-mid); border-radius: 2px;
}
.hero-auth-btns { display: flex; gap: clamp(8px,.8vw,12px); flex-wrap: wrap; }

/* ── Doc Cards (hero middle col) ── */
.hero-cards {
  display: flex; flex-direction: column;
  gap: clamp(10px,1.2vw,18px);
  animation: fadeUp .8s .35s ease both;
}

.doc-card {
  background: var(--white);
  border: 2px solid rgba(255,255,255,.8);
  border-radius: clamp(10px,.9vw,14px);
  padding: clamp(14px,1.3vw,20px) clamp(16px,1.5vw,24px);
  display: flex; align-items: center; gap: clamp(12px,1vw,16px);
  box-shadow: 0 2px 12px rgba(14,30,46,.1);
  cursor: pointer; text-decoration: none; color: inherit;
  transition: border-color .2s, background .2s, transform .2s, box-shadow .2s;
}
.doc-card:hover {
  border-color: var(--blue-soft);
  background: var(--blue-light);
  transform: translateX(4px);
  box-shadow: 0 4px 20px rgba(14,30,46,.15);
}
.doc-card-icon {
  width: clamp(36px,3vw,48px); height: clamp(36px,3vw,48px);
  border-radius: clamp(8px,.8vw,12px); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: clamp(1rem,1.1vw,1.3rem);
}
.ic-blue  { background: var(--blue-light);  border: 2px solid var(--blue-mid); }
.ic-green { background: var(--green-pale); border: 2px solid #b0dfc8; }
.ic-teal  { background: #daf0f2;           border: 2px solid #a8dde2; }
.doc-card-body { flex: 1; min-width: 0; }
.doc-card-title { font-weight: 700; color: var(--text-dark); font-size: clamp(.85rem,.88vw,1.02rem); line-height: 1.3; }
.doc-card:hover .doc-card-title { color: var(--blue-deep); }
.doc-card-sub   { font-size: clamp(.68rem,.65vw,.8rem); color: var(--text-muted); margin-top: 3px; }
.doc-card-arrow { color: var(--text-muted); font-size: clamp(.9rem,.8vw,1.1rem); flex-shrink: 0; transition: transform .2s, color .2s; }
.doc-card:hover .doc-card-arrow { transform: translateX(3px); color: var(--blue-soft); }

/* ── Hero Illustration (right col) ── */
.hero-right {
  display: flex; align-items: center; justify-content: center;
  animation: fadeUp .8s .5s ease both;
  background: transparent;
  padding: clamp(40px,5vw,72px) clamp(32px,4vw,64px);
  position: relative;
}

/* sústredné dekoratívne kruhy na pozadí */
.hero-right::before {
  content: '';
  position: absolute;
  width: min(320px, 75%); height: min(320px, 75%);
  border-radius: 50%;
  border: 1.5px solid rgba(26,106,191,.16);
  top: 50%; left: 50%; transform: translate(-50%,-50%);
  pointer-events: none;
}
.hero-right::after {
  content: '';
  position: absolute;
  width: min(460px, 108%); height: min(460px, 108%);
  border-radius: 50%;
  border: 1px solid rgba(26,106,191,.09);
  top: 50%; left: 50%; transform: translate(-50%,-50%);
  pointer-events: none;
}

/* obal pre celú zostavu kruhov */
.circles-wrap {
  display: flex; flex-direction: column;
  align-items: center; gap: clamp(18px,2vw,28px);
  position: relative; z-index: 2;
}

/* hlavný veľký kruh */
.main-circle {
  width: clamp(148px,14vw,176px); height: clamp(148px,14vw,176px);
  border-radius: 50%;
  background: var(--white);
  border: 2.5px solid var(--border);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 6px;
  text-align: center; padding: 18px;
  position: relative;
  text-decoration: none; color: inherit;
  box-shadow: 0 6px 24px rgba(14,30,46,.1);
  transition: transform .25s, box-shadow .25s, border-color .25s;
}
.main-circle:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 36px rgba(14,30,46,.15);
  border-color: var(--blue-soft);
}
.main-circle .circle-emoji { font-size: clamp(1.6rem,2vw,2.1rem); line-height: 1; }
.main-circle .circle-name {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(.8rem,.86vw,.92rem); line-height: 1.25; color: var(--text-dark);
}
.main-circle .circle-sub {
  font-size: clamp(.58rem,.6vw,.68rem); color: var(--text-muted);
  font-weight: 500; line-height: 1.4;
}

/* odznak na kruhu */
.circle-badge {
  position: absolute; top: 13px; right: 8px;
  background: var(--blue-soft); color: #fff;
  font-size: .6rem; font-weight: 700; letter-spacing: .04em;
  text-transform: uppercase; padding: 3px 8px; border-radius: 20px;
}
.circle-badge.green { background: var(--green-soft); }

/* rad dvoch malých kruhov */
.circles-row {
  display: flex; align-items: center;
  gap: clamp(20px,2.5vw,36px);
  position: relative;
}
.circles-row::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: clamp(28px,3vw,44px); height: 1.5px;
  background: var(--border);
}

/* malý kruh */
.circle-sm {
  width: clamp(112px,11vw,136px); height: clamp(112px,11vw,136px);
  border-radius: 50%;
  background: var(--white);
  border: 2px solid var(--border);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 4px;
  text-align: center; padding: 14px;
  position: relative;
  text-decoration: none; color: inherit;
  box-shadow: 0 4px 14px rgba(14,30,46,.08);
  transition: transform .25s, box-shadow .25s, border-color .25s;
}
.circle-sm:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 28px rgba(14,30,46,.14);
  border-color: var(--blue-soft);
}
.circle-sm .circle-emoji { font-size: clamp(1.3rem,1.6vw,1.7rem); line-height: 1; }
.circle-sm .circle-name {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(.68rem,.72vw,.8rem); line-height: 1.25; color: var(--text-dark);
}
.circle-sm .circle-sub {
  font-size: clamp(.56rem,.56vw,.64rem); color: var(--text-muted);
  font-weight: 500; line-height: 1.35;
}

/* stredový spojovací krúžok */
.circle-connector {
  width: clamp(38px,4vw,50px); height: clamp(38px,4vw,50px);
  border-radius: 50%; background: var(--white);
  border: 2px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  font-size: clamp(.9rem,1vw,1.1rem); flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(14,30,46,.06);
}

/* plávajúce čipy */
.float-chip {
  position: absolute;
  background: var(--white);
  border: 2px solid var(--border);
  border-radius: 50px;
  padding: 7px 13px;
  display: flex; align-items: center; gap: 7px;
  font-size: .74rem; font-weight: 600; color: var(--text-dark);
  box-shadow: 0 3px 12px rgba(14,30,46,.07);
  z-index: 3; white-space: nowrap;
}
.float-chip .chip-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--green-soft); flex-shrink: 0;
  animation: pulse 2s infinite;
}
.float-chip-1 { top: clamp(12px,2vh,22px); right: clamp(12px,2vw,32px); }
.float-chip-2 { bottom: clamp(12px,2vh,22px); left: clamp(12px,2vw,24px); }

/* dekoratívne bodky */
.deco-dot {
  position: absolute; border-radius: 50%;
  background: var(--blue-soft); opacity: .16;
  pointer-events: none;
}

/* skryť starú ilustráciu ak ostane v HTML */
.hero-illustration { display: none; }

/* ══════════════════════════════════════════
   FEATURES
══════════════════════════════════════════ */
.features { padding: clamp(52px,7vh,100px) var(--pad); background: var(--off-white); border-bottom: 2px solid var(--border); }
.section-header { text-align: center; margin-bottom: clamp(36px,4vh,56px); }
.section-label {
  font-size: clamp(.68rem,.68vw,.8rem); font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--green-soft); margin-bottom: 10px;
}
.section-header h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(1.8rem, 2.6vw, 2.8rem); color: var(--text-dark); line-height: 1.2;
}
.features-grid {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: clamp(12px,1.4vw,18px);
  max-width: 1100px; margin: 0 auto;
}
.feature-card {
  background: var(--white);
  border: 2px solid var(--border);
  border-radius: 16px;
  padding: clamp(22px,2.2vw,32px);
  transition: border-color .2s, background .2s, transform .2s;
}
.feature-card:hover {
  border-color: var(--blue-soft);
  background: var(--blue-light);
  transform: translateY(-3px);
}
.feature-icon {
  width: clamp(42px,3.4vw,54px); height: clamp(42px,3.4vw,54px);
  border-radius: clamp(10px,.9vw,13px);
  display: flex; align-items: center; justify-content: center;
  font-size: clamp(1.1rem,1.2vw,1.4rem); margin-bottom: clamp(14px,1.2vw,20px);
  background: var(--white); border: 2px solid var(--blue-mid);
}
.feature-card:nth-child(2) .feature-icon { border-color: #b0dfc8; background: var(--green-pale); }
.feature-card:nth-child(3) .feature-icon { border-color: #f5d8a5; background: #fef3e2; }
.feature-card h3 { font-weight: 700; font-size: clamp(.9rem,.92vw,1.06rem); margin-bottom: 9px; color: var(--text-dark); }
.feature-card p  { font-size: clamp(.8rem,.78vw,.92rem); color: var(--text-body); line-height: 1.68; }

/* ══════════════════════════════════════════
   MODULES
══════════════════════════════════════════ */
.modules { padding: clamp(52px,7vh,100px) var(--pad); background: var(--white); border-bottom: 2px solid var(--border); }
.modules-inner {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(32px,4vw,72px); align-items: center;
}
.modules-text h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(1.8rem, 2.6vw, 2.8rem); line-height: 1.15; margin-bottom: 14px; color: var(--text-dark);
}
.modules-text p { font-size: clamp(.88rem,.9vw,1rem); color: var(--text-body); line-height: 1.72; margin-bottom: clamp(18px,2vw,26px); }
.modules-ctas { display: flex; gap: clamp(8px,.8vw,14px); flex-wrap: wrap; }

.module-cards { display: flex; flex-direction: column; gap: clamp(11px,1.1vw,16px); }
.module-big {
  background: var(--blue-soft);
  border: 2px solid var(--blue-soft);
  border-radius: clamp(12px,1.1vw,18px); padding: clamp(18px,1.8vw,26px);
  color: #fff; position: relative; overflow: hidden;
}
.module-big::after {
  content:''; position:absolute; right:-22px; top:-22px;
  width:clamp(80px,9vw,130px); height:clamp(80px,9vw,130px);
  border-radius:50%; background:rgba(255,255,255,.06);
}
.module-big h3 { font-size: clamp(.88rem,.9vw,1.05rem); font-weight: 700; margin-bottom: 6px; }
.module-big p  { font-size: clamp(.76rem,.75vw,.88rem); opacity: .85; line-height: 1.55; }
.module-chip {
  display: inline-block; background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.3);
  border-radius: 6px; padding: 3px 10px;
  font-size: clamp(.64rem,.62vw,.74rem); font-weight: 700; margin-bottom: 9px;
}
.module-small-row { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(10px,1vw,14px); }
.module-small {
  background: var(--white); border: 2px solid var(--border);
  border-radius: clamp(10px,.9vw,14px); padding: clamp(14px,1.3vw,18px);
  transition: border-color .2s, background .2s;
}
.module-small:hover { border-color: var(--blue-soft); background: var(--blue-light); }
.ms-icon { font-size: clamp(1.1rem,1.2vw,1.4rem); margin-bottom: 6px; }
.module-small h4 { font-size: clamp(.76rem,.75vw,.88rem); font-weight: 600; color: var(--text-dark); margin-bottom: 3px; }
.module-small p  { font-size: clamp(.68rem,.65vw,.78rem); color: var(--text-muted); line-height: 1.5; }

/* ══════════════════════════════════════════
   CTA BANNER
══════════════════════════════════════════ */
.cta-section {
  padding: clamp(52px,7vh,90px) var(--pad);
  background: var(--blue-soft);
  border-top: 2px solid var(--blue-deep);
  text-align: center; color: #fff;
}
.cta-section h2 { font-family: 'DM Serif Display', serif; font-size: clamp(1.8rem, 3vw, 3.2rem); margin-bottom: 10px; }
.cta-section p  { font-size: clamp(.9rem,.95vw,1.05rem); opacity: .82; margin-bottom: 8px; }
.cta-btns { display: flex; gap: 13px; justify-content: center; flex-wrap: wrap; }

/* ══════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
footer { background: var(--text-dark); color: rgba(255,255,255,.5); padding: clamp(36px,5vh,52px) var(--pad) clamp(20px,3vh,28px); border-top: 2px solid #1e3248; }
.footer-inner {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: 2fr 1fr 1fr;
  gap: clamp(28px,3.5vw,56px); margin-bottom: clamp(24px,3vh,36px);
}
.footer-brand .logo { color: var(--white); margin-bottom: 10px; display: flex; }
.footer-brand p { font-size: clamp(.75rem,.72vw,.88rem); line-height: 1.7; }
footer h4 {
  font-size: clamp(.68rem,.65vw,.78rem); font-weight: 700; letter-spacing: .06em;
  text-transform: uppercase; color: rgba(255,255,255,.86); margin-bottom: 11px;
}
footer ul { list-style: none; display: flex; flex-direction: column; gap: 7px; }
footer ul li a { font-size: clamp(.74rem,.72vw,.86rem); color: rgba(255,255,255,.5); text-decoration: none; transition: color .2s; }
footer ul li a:hover { color: #fff; }
.footer-bottom {
  max-width: 1200px; margin: 0 auto; padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,.1);
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 8px;
}
.footer-bottom span { font-size: clamp(.68rem,.65vw,.78rem); }

/* ── Reveal animation ── */
.reveal { opacity:0; transform:translateY(22px); transition: opacity .6s ease, transform .6s ease; }
.reveal.visible { opacity:1; transform:none; }

/* ══════════════════════════════════════════
   AUTH PAGES (register / login)
══════════════════════════════════════════ */
.auth-page {
  min-height: 100vh;
  padding-top: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--off-white);
  position: relative;
  overflow: hidden;
}
.auth-page .blob { display: none; }

.auth-card {
  position: relative; z-index: 2;
  background: var(--white);
  border: 2px solid var(--border);
  border-radius: 20px;
  box-shadow: 0 4px 20px rgba(14,30,46,.08);
  padding: clamp(28px,4vw,48px);
  width: 100%;
  max-width: 520px;
  margin: 24px 16px;
  animation: fadeUp .6s ease both;
}
.auth-card-sm { max-width: 420px; }

.auth-logo-row {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 24px;
}
.auth-logo-row .logo-icon { width: 36px; height: 36px; font-size: 1rem; }
.auth-logo-row span {
  font-family: 'DM Serif Display', serif;
  font-size: 1.1rem; color: var(--blue-deep);
}

.auth-title {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  color: var(--text-dark); margin-bottom: 6px;
}
.auth-subtitle { font-size: .88rem; color: var(--text-muted); margin-bottom: 28px; line-height: 1.55; }

/* ── Form elements ── */
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.form-group label {
  font-size: .78rem; font-weight: 600; color: var(--text-body); letter-spacing: .02em;
}
.form-group label .req { color: var(--blue-soft); margin-left: 2px; }

.form-input, .form-select {
  width: 100%;
  padding: 11px 14px;
  border: 2px solid var(--border);
  border-radius: 10px;
  font-family: 'DM Sans', sans-serif;
  font-size: .9rem; color: var(--text-dark);
  background: var(--white);
  transition: border-color .18s;
  outline: none;
  -webkit-appearance: none;
}
.form-input:focus, .form-select:focus {
  border-color: var(--blue-soft);
  box-shadow: 0 0 0 3px rgba(26,106,191,.1);
}
.form-input.error, .form-select.error { border-color: var(--red); }
.form-input.success { border-color: var(--green-soft); }

.form-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237a9aad' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
  cursor: pointer;
}

.form-hint { font-size: .72rem; color: var(--text-muted); margin-top: 3px; }
.form-error { font-size: .72rem; color: var(--red); margin-top: 3px; display: none; }
.form-error.show { display: block; }

/* ── Password field ── */
.password-wrap { position: relative; }
.password-toggle {
  position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer;
  color: var(--text-muted); font-size: .9rem; padding: 4px;
  transition: color .2s;
}
.password-toggle:hover { color: var(--blue-deep); }

/* ── Password strength ── */
.strength-bar-wrap { margin-top: 8px; display: flex; flex-direction: column; gap: 5px; }
.strength-bar-track {
  height: 4px; border-radius: 4px; background: rgba(168,204,232,.25);
  overflow: hidden;
}
.strength-bar-fill {
  height: 100%; border-radius: 4px; width: 0%;
  transition: width .4s ease, background .4s ease;
}
.strength-label { font-size: .72rem; font-weight: 600; color: var(--text-muted); }
.strength-0 .strength-bar-fill { width: 0%; }
.strength-1 .strength-bar-fill { width: 25%; background: var(--red); }
.strength-2 .strength-bar-fill { width: 50%; background: var(--orange); }
.strength-3 .strength-bar-fill { width: 75%; background: var(--yellow); }
.strength-4 .strength-bar-fill { width: 100%; background: var(--green-mid); }

/* ── Iné pozícia input ── */
.iné-wrap { display: none; margin-top: 10px; }
.iné-wrap.show { display: block; }

/* ── Submit button ── */
.btn-submit {
  width: 100%; padding: 13px;
  background: var(--blue-soft);
  color: #fff; border: 2px solid var(--blue-soft); border-radius: 10px;
  font-family: 'DM Sans', sans-serif; font-size: .97rem; font-weight: 700;
  cursor: pointer; transition: background .18s, border-color .18s, transform .15s;
  margin-top: 6px;
}
.btn-submit:hover { background: var(--blue-deep); border-color: var(--blue-deep); transform: translateY(-1px); }
.btn-submit:active { transform: scale(.99); }
.btn-submit:disabled { opacity: .5; cursor: not-allowed; transform: none; }

/* ── Auth footer ── */
.auth-footer { text-align: center; margin-top: 18px; font-size: .82rem; color: var(--text-muted); }
.auth-footer a { color: var(--blue-deep); font-weight: 600; text-decoration: none; }
.auth-footer a:hover { text-decoration: underline; }

/* ── Toast notifications ── */
.toast-container { position: fixed; bottom: 24px; right: 24px; z-index: 9999; display: flex; flex-direction: column; gap: 10px; }
.toast {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 12px 18px; border-radius: 12px;
  background: var(--white);
  border: 2px solid var(--border);
  border-left: 4px solid var(--blue-soft);
  max-width: 320px;
  animation: slideIn .3s ease;
}
@keyframes slideIn { from{opacity:0;transform:translateX(20px)} to{opacity:1;transform:none} }
.toast.success { border-left-color: var(--green-soft); }
.toast.error   { border-left-color: var(--red); }
.toast-icon { font-size: 1.1rem; flex-shrink: 0; margin-top: 1px; }
.toast-body { flex: 1; }
.toast-title { font-weight: 700; font-size: .84rem; color: var(--text-dark); margin-bottom: 2px; }
.toast-msg   { font-size: .78rem; color: var(--text-body); line-height: 1.45; }

/* ── Page loader ── */
.page-loader {
  position: fixed; inset: 0; z-index: 9999;
  background: var(--white);
  display: flex; align-items: center; justify-content: center;
  opacity: 1; transition: opacity .4s;
}
.page-loader.done { opacity: 0; pointer-events: none; }
.loader-spinner {
  width: 40px; height: 40px; border-radius: 50%;
  border: 3px solid var(--blue-light);
  border-top-color: var(--blue-deep);
  animation: spin .8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media (max-width: 1100px) and (min-width: 861px) {
  .hero-grid { grid-template-columns: 1fr 1fr; }
  .hero-right { display: flex; }
}

@media (max-width: 860px) {
  nav { padding: 13px 18px; }
  .hero-grid { grid-template-columns: 1fr; gap: 24px; padding: 28px 20px 44px; }
  .hero-left  { order: 1; }
  .hero-cards { order: 2; }
  .hero-right {
    display: flex;
    order: 3;
    padding: 32px 20px 40px;
    min-height: 320px;
  }
  .main-circle {
    width: 148px; height: 148px;
  }
  .circle-sm {
    width: 108px; height: 108px;
  }
  .circle-connector {
    width: 36px; height: 36px; font-size: .85rem;
  }
  .features-grid { grid-template-columns: 1fr; }
  .modules-inner { grid-template-columns: 1fr; }
  .footer-inner  { grid-template-columns: 1fr 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .admin-dropdown { width: 300px; right: -60px; }
}

@media (max-width: 480px) {
  .footer-inner { grid-template-columns: 1fr; }
  .auth-card { padding: 24px 18px; }
  .main-circle { width: 130px; height: 130px; }
  .circle-sm   { width:  96px; height:  96px; }
  .circles-row { gap: 14px; }
  .circles-wrap { gap: 18px; }
}
