/* ==========================================================================
   ocinka.pro — Помічник для оцінювача нерухомості
   Дизайн-система: спокійний офіційний стиль, синьо-жовта палітра,
   мотив «печатки оцінювача» як фірмовий елемент.
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Golos+Text:wght@400;500;600;700;800&display=swap');

:root{
  /* --- колір --- */
  --bg:            #FFFFFF;
  --bg-soft:       #F4F8FC;
  --bg-navy:       #01154C;
  --blue-900:      #052C5C;
  --blue-800:      #0B3D77;
  --blue-700:      #0057B7; /* прапоровий синій */
  --blue-500:      #1D74D6;
  --blue-100:      #E4EFFC;
  --yellow-500:    #FFD500; /* прапоровий жовтий */
  --yellow-600:    #E8B400;
  --gold-100:      #FFF6DA;
  --ink:           #16202E;
  --muted:         #5B6675;
  --muted-soft:    #8993A2;
  --border:        #E1E7EF;
  --border-soft:   #EDF1F6;
  --success:       #1E9E5A;
  --success-bg:    #E9F8EF;
  --danger:        #D14343;
  --white:         #FFFFFF;

  /* --- колір логотипу (з наданого файлу) --- */
  --logo-navy:     #01154C;
  --logo-navy-soft: #01154C;
  --logo-yellow:   #FDC805;
  --divider-blue:  rgba(29,116,214,.45);

  /* --- типографіка --- */
  --font: 'Golos Text', 'Inter', 'Segoe UI', system-ui, sans-serif;
  --fs-base: 18px;

  /* --- форма/тінь --- */
  --radius-s: 10px;
  --radius-m: 16px;
  --radius-l: 24px;
  --shadow-card: 0 2px 8px rgba(10,42,84,.06), 0 1px 2px rgba(10,42,84,.05);
  --shadow-hover: 0 12px 28px rgba(10,42,84,.12);
  --container: 1180px;
}

*,*::before,*::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  font-family: var(--font);
  font-size: var(--fs-base);
  line-height: 1.6;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  overflow-wrap: break-word;
}
img,svg{ max-width:100%; display:block; }
a{ color: inherit; }
h1,h2,h3,h4{ font-family: var(--font); font-weight:800; line-height:1.18; margin:0 0 .5em; color: var(--blue-900); letter-spacing: -.01em; }
h1{ font-size: clamp(2.1rem, 3.6vw, 3.1rem); }
h2{ font-size: clamp(1.6rem, 2.6vw, 2.2rem); }
h3{ font-size: 1.3rem; }
p{ margin:0 0 1em; }
.container{ max-width: var(--container); margin: 0 auto; padding: 0 24px; }
.section{ padding: 88px 0; }
.section--soft{ background: var(--bg-soft); }
.section--navy{ background: linear-gradient(180deg,var(--bg-navy),#082246); color: #fff; }
.section--navy h2, .section--navy h3{ color:#fff; }
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-weight:700; font-size:.85rem; letter-spacing:.06em; text-transform:uppercase;
  color: var(--blue-700); margin-bottom: 14px;
}
.eyebrow::before{ content:""; width:8px; height:8px; border-radius:50%; background: var(--yellow-500); box-shadow: 0 0 0 3px var(--blue-100); }
.lede{ font-size: 1.15rem; color: var(--muted); max-width: 62ch; }
.center{ text-align:center; margin-left:auto; margin-right:auto; }

/* --- кнопки --- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family: var(--font); font-weight:700; font-size:1rem;
  padding: 15px 28px; border-radius: var(--radius-s); border: 2px solid transparent;
  cursor:pointer; text-decoration:none; transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
  white-space: nowrap;
}
.btn:focus-visible{ outline: 3px solid var(--yellow-500); outline-offset: 2px; }
.btn--primary{ background: var(--blue-700); color:#fff; box-shadow: var(--shadow-card); }
.btn--primary:hover{ background: var(--blue-800); transform: translateY(-1px); box-shadow: var(--shadow-hover); }
.btn--accent{ background: var(--yellow-500); color: var(--blue-900); }
.btn--accent:hover{ background: var(--yellow-600); transform: translateY(-1px); }
.btn--ghost{ background: transparent; border-color: var(--border); color: var(--blue-900); }
.btn--ghost:hover{ border-color: var(--blue-700); color: var(--blue-700); }
.btn--navy-ghost{ background: transparent; border-color: rgba(255,255,255,.35); color:#fff; }
.btn--navy-ghost:hover{ border-color:#fff; }
.btn--block{ width:100%; }
.btn[disabled], .btn--disabled{
  background: #EEF1F5 !important; color: var(--muted-soft) !important; border-color: #EEF1F5 !important;
  cursor: not-allowed; box-shadow:none; transform:none !important;
}
.btn--sm{ padding: 10px 18px; font-size:.92rem; }

/* --- бейджі / стани --- */
.badge{ display:inline-flex; align-items:center; gap:6px; font-size:.78rem; font-weight:700; padding: 5px 12px; border-radius: 999px; }
.badge--active{ background: var(--success-bg); color: var(--success); }
.badge--soon{ background: #F1F3F6; color: var(--muted); }
.badge--beta{ background: var(--gold-100); color:#8A6900; }

/* ==========================================================================
   Верхня бігуча стрічка бета-тестування
   ========================================================================== */
.beta-bar{
  background: var(--blue-900); color:#fff; overflow:hidden; position:relative;
  height: 38px; display:flex; align-items:center;
}
.beta-bar__track{
  display:flex; white-space:nowrap; animation: marquee 26s linear infinite;
}
.beta-bar__track span{
  display:inline-flex; align-items:center; gap:10px;
  font-size:.85rem; font-weight:600; letter-spacing:.03em;
  padding-right: 56px;
}
.beta-bar__track span::before{ content:"●"; color: var(--yellow-500); font-size:.6rem; }
@keyframes marquee{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }
@media (prefers-reduced-motion: reduce){ .beta-bar__track{ animation:none; } }

/* ==========================================================================
   Хедер
   ========================================================================== */
.site-header{
  position: sticky; top:0; z-index: 60;
  background: var(--logo-navy-soft);
  border-bottom: 1px solid var(--divider-blue);
}
.site-header__inner{
  display:flex; align-items:center; justify-content:space-between;
  padding: 10px 24px; max-width: var(--container); margin:0 auto; gap: 20px;
}
.brand{ display:flex; align-items:center; gap:12px; text-decoration:none; flex: 0 0 auto; line-height:0; }
.brand__logo{ height:60px; width:auto; display:block; border-radius:6px; }
.brand__mark{
  width:44px; height:44px; border-radius:12px; flex:none;
  background: var(--blue-700); color:#fff; display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:1.1rem;
}
.brand__name{ display:none; }
.site-title{
  flex:1; min-width:0; text-align:center; font-weight:700; font-size:1.02rem; color:#fff;
  letter-spacing:-.01em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; padding:0 12px;
}
.header-right{ display:flex; align-items:center; gap:16px; flex:0 0 auto; }
.main-nav{ display:flex; align-items:center; gap: 6px; flex:0 0 auto; }
.main-nav a{
  text-decoration:none; color: rgba(255,255,255,.82); font-weight:600; font-size:.95rem;
  padding: 10px 14px; border-radius: 8px; transition: background .15s, color .15s;
}
.main-nav a:hover{ background: rgba(255,255,255,.1); color:#fff; }
.main-nav a.is-active{ color: var(--logo-navy); background: var(--logo-yellow); }
.header-cta{ display:flex; align-items:center; gap:10px; flex:0 0 auto; }
.header-cta .btn--ghost{ border-color: rgba(255,255,255,.4); color:#fff; }
.header-cta .btn--ghost:hover{ border-color:#fff; background: rgba(255,255,255,.08); color:#fff; }
.header-cta .btn--primary{ background: var(--logo-yellow); color: var(--logo-navy); box-shadow:none; }
.header-cta .btn--primary:hover{ background:#fff; }
.nav-toggle{
  display:none; background:none; border:2px solid rgba(255,255,255,.35); border-radius:8px;
  width:40px; height:40px; align-items:center; justify-content:center; cursor:pointer;
}
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after{
  content:""; display:block; width:18px; height:2px; background:#fff; position:relative; transition: all .2s;
}
.nav-toggle span::before{ position:absolute; top:-6px; }
.nav-toggle span::after{ position:absolute; top:6px; }

@media (min-width: 900px){ .brand__name{ display:block; font-weight:800; color:#fff; } }

@media (max-width: 980px){
  .site-title{ display:none; }
  .main-nav{
    position: fixed; inset: 56px 0 0 0; background: var(--logo-navy); flex-direction:column; align-items:stretch;
    padding: 18px; gap:4px; transform: translateY(-8px); opacity:0; pointer-events:none; transition: all .18s ease;
    overflow-y:auto; border-top:1px solid var(--divider-blue);
  }
  .main-nav.is-open{ opacity:1; transform:none; pointer-events:auto; }
  .main-nav a{ padding:14px 12px; font-size:1.05rem; border-bottom:1px solid rgba(255,255,255,.1); border-radius:0; color:rgba(255,255,255,.88); }
  .nav-toggle{ display:flex; }
  .header-cta .btn--ghost{ display:none; }
}

@media (max-width: 600px){
  .site-header__inner{ padding: 8px 16px; }
  .brand__logo{ height:32px; }
  .header-cta .btn--primary{ padding:9px 14px; font-size:.86rem; }
  .beta-bar{ height:30px; }
}

/* ==========================================================================
   Герой
   ========================================================================== */
.hero{
  position:relative; overflow:hidden;
  background:
    radial-gradient(650px 320px at 85% -10%, var(--blue-100), transparent 60%),
    var(--bg);
  padding: 76px 0 60px;
}
.hero__grid{
  position:absolute; inset:0; opacity:.5; pointer-events:none;
  background-image:
    linear-gradient(var(--border-soft) 1px, transparent 1px),
    linear-gradient(90deg, var(--border-soft) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: linear-gradient(180deg, black, transparent 78%);
}
.hero__inner{ position:relative; display:grid; grid-template-columns: 1.15fr .85fr; gap: 56px; align-items:center; }
.hero__stamp{ position:relative; display:flex; align-items:center; justify-content:center; }
.hero p.lede{ margin-top: 14px; }
.hero__actions{ display:flex; gap:14px; flex-wrap:wrap; margin-top: 30px; }
.hero__facts{ display:flex; gap: 28px; margin-top: 42px; flex-wrap:wrap; }
.hero__fact b{ display:block; font-size:1.5rem; color: var(--blue-800); font-weight:800; }
.hero__fact span{ color: var(--muted); font-size:.92rem; }
@media (max-width: 900px){ .hero__inner{ grid-template-columns: 1fr; } .hero__stamp{ order:-1; max-width:220px; margin:0 auto; } }

/* фірмовий елемент — печатка */
.seal{ color: var(--blue-700); }
.seal .seal-ring{ animation: seal-spin 40s linear infinite; transform-origin: 110px 110px; }
@keyframes seal-spin{ from{ transform: rotate(0deg);} to{ transform: rotate(360deg);} }
@media (prefers-reduced-motion: reduce){ .seal .seal-ring{ animation:none; } }

/* ==========================================================================
   Мітки процесу / картки
   ========================================================================== */
.steps{ display:grid; grid-template-columns: repeat(4,1fr); gap: 22px; margin-top: 46px; }
.step{ background:#fff; border:1px solid var(--border); border-radius: var(--radius-m); padding: 26px; }
.step__num{
  width:38px; height:38px; border-radius:10px; background: var(--blue-100); color: var(--blue-700);
  display:flex; align-items:center; justify-content:center; font-weight:800; margin-bottom:16px;
}
.step h3{ font-size:1.05rem; margin-bottom:8px; }
.step p{ color: var(--muted); font-size:.95rem; margin:0; }
@media (max-width: 980px){ .steps{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 620px){ .steps{ grid-template-columns: 1fr; } }

.cards{ display:grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 46px; }
.card{ background:#fff; border:1px solid var(--border); border-radius: var(--radius-m); padding: 30px; box-shadow: var(--shadow-card); }
.card h3{ display:flex; align-items:center; gap:10px; }
.card p{ color: var(--muted); }
.card__icon{ width:46px; height:46px; border-radius:12px; background: var(--blue-100); display:flex; align-items:center; justify-content:center; margin-bottom: 18px; }
@media (max-width: 980px){ .cards{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 620px){ .cards{ grid-template-columns: 1fr; } }

.compare{ display:grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 44px; }
.compare__col{ border-radius: var(--radius-m); padding: 30px; }
.compare__col--old{ background: #FBF4F0; border: 1px solid #F0DED4; }
.compare__col--new{ background: var(--logo-navy); color:#fff; }
.compare__col--new h3{ color:#fff; }
.compare__time{ font-size: 2.4rem; font-weight:800; margin: 6px 0 2px; }
.compare__col--old .compare__time{ color:#B15533; }
.compare__col--new .compare__time{ color: var(--yellow-500); }
.compare ul{ margin:16px 0 0; padding-left: 20px; color: inherit; opacity:.9; font-size:.95rem; }
.compare ul li{ margin-bottom:6px; }
@media (max-width: 780px){ .compare{ grid-template-columns:1fr; } }

/* ==========================================================================
   Ціни
   ========================================================================== */
.pricing-grid{ display:grid; grid-template-columns: repeat(4,1fr); gap: 20px; margin-top: 44px; }
.plan{ background:#fff; border:1px solid var(--border); border-radius: var(--radius-m); padding: 28px 24px; display:flex; flex-direction:column; gap: 14px; }
.plan--highlight{ border-color: var(--blue-700); box-shadow: var(--shadow-hover); position:relative; }
.plan--highlight::before{
  content:"Популярний"; position:absolute; top:-13px; left:24px; background: var(--yellow-500);
  color: var(--blue-900); font-size:.72rem; font-weight:800; padding: 5px 12px; border-radius:999px;
}
.plan__name{ font-weight:800; font-size:1.15rem; color: var(--blue-900); }
.plan__quota{ color: var(--muted); font-size:.9rem; }
.plan__price{ margin: 8px 0; padding: 14px; border: 1.5px dashed var(--border); border-radius: 10px; text-align:center; color: var(--muted-soft); font-weight:700; font-size:.95rem; background: var(--bg-soft); }
.plan hr{ border:none; border-top:1px solid var(--border-soft); margin: 4px 0; }
.plan ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:9px; font-size:.92rem; color: var(--muted); flex:1; }
.plan ul li{ display:flex; gap:8px; align-items:flex-start; }
.plan ul li::before{ content:"✓"; color: var(--success); font-weight:800; flex:none; }
@media (max-width: 980px){ .pricing-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 620px){ .pricing-grid{ grid-template-columns: 1fr; } }

/* ==========================================================================
   Форми
   ========================================================================== */
.form-card{ background:#fff; border:1px solid var(--border); border-radius: var(--radius-l); padding: 40px; box-shadow: var(--shadow-card); }
.form-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 22px 24px; }
.form-grid--wide{ grid-template-columns: 1fr; }
.field{ display:flex; flex-direction:column; gap:7px; }
.field.span-2{ grid-column: 1 / -1; }
.field label{ font-weight:700; font-size:.92rem; color: var(--blue-900); }
.field label .opt{ font-weight:500; color: var(--muted-soft); }
.field .hint{ font-size:.82rem; color: var(--muted-soft); }
.field input[type=text],
.field input[type=email],
.field input[type=tel],
.field input[type=password],
.field input[type=date],
.field input[type=number],
.field select,
.field textarea{
  font-family: var(--font); font-size: 1rem; color: var(--ink);
  padding: 13px 14px; border-radius: var(--radius-s); border: 1.5px solid var(--border);
  background: var(--bg-soft); transition: border-color .15s, background .15s;
}
.field textarea{ resize: vertical; min-height: 110px; }
.field input::placeholder, .field textarea::placeholder{ color: var(--muted-soft); opacity:.6; font-style: italic; }
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color: var(--blue-700); background:#fff; box-shadow: 0 0 0 4px var(--blue-100);
}
.checkline{ display:flex; align-items:flex-start; gap:10px; font-size:.92rem; color: var(--muted); }
.checkline input{ margin-top:4px; flex:none; width:18px; height:18px; accent-color: var(--blue-700); }
.form-foot{ display:flex; align-items:center; justify-content:space-between; gap: 16px; margin-top: 30px; flex-wrap:wrap; }
fieldset{ border:1px solid var(--border); border-radius: var(--radius-m); padding: 20px 22px 22px; margin: 0; }
fieldset legend{ font-weight:800; color: var(--blue-900); padding: 0 8px; font-size:.98rem; }
.chip-group{ display:flex; flex-wrap:wrap; gap:10px; margin-top:6px; }
.chip{ display:inline-flex; align-items:center; gap:6px; border:1.5px solid var(--border); border-radius:999px; padding:8px 15px; font-size:.9rem; font-weight:600; cursor:pointer; background:#fff; }
.chip input{ accent-color: var(--blue-700); }
@media (max-width: 720px){ .form-grid{ grid-template-columns:1fr; } .form-card{ padding: 26px; } }

/* ==========================================================================
   Робочий кабінет (workspace)
   ========================================================================== */
.option-grid{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.option-grid--2{ grid-template-columns: repeat(2,1fr); }
.option{
  position:relative; border:1.5px solid var(--border); border-radius: var(--radius-m);
  padding: 20px 16px; text-align:center; cursor:pointer; background:#fff; transition: border-color .15s, background .15s;
}
.option input{ position:absolute; opacity:0; inset:0; cursor:pointer; }
.option__icon{ font-size:1.6rem; margin-bottom:8px; }
.option__label{ font-weight:700; font-size:.95rem; color: var(--blue-900); }
.option:has(input:checked){ border-color: var(--blue-700); background: var(--blue-100); }
.option:has(input:checked) .option__label{ color: var(--blue-700); }
.option--locked{ cursor:not-allowed; opacity:.55; background: var(--bg-soft); }
.option--locked input{ pointer-events:none; }
.option__soon{ position:absolute; top:10px; right:10px; }
@media (max-width: 780px){ .option-grid{ grid-template-columns: repeat(2,1fr); } }

.dropzone{
  border: 2px dashed var(--border); border-radius: var(--radius-m); padding: 40px 24px;
  text-align:center; background: var(--bg-soft); transition: border-color .15s, background .15s;
}
.dropzone.is-drag{ border-color: var(--blue-700); background: var(--blue-100); }
.dropzone__icon{ font-size:2.2rem; margin-bottom: 10px; }
.filelist{ list-style:none; margin: 16px 0 0; padding:0; display:flex; flex-direction:column; gap:8px; }
.filelist li{ display:flex; align-items:center; justify-content:space-between; gap:10px; background:#fff; border:1px solid var(--border); border-radius:10px; padding:10px 14px; font-size:.9rem; }
.filelist li .remove{ color: var(--danger); cursor:pointer; font-weight:700; background:none; border:none; font-size:.85rem; }

.source-row{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding: 16px 0; border-bottom:1px solid var(--border-soft); }
.source-row:last-child{ border-bottom:none; }
.source-row__meta b{ display:block; color: var(--blue-900); }
.source-row__meta span{ color: var(--muted); font-size:.88rem; }
.switch{ position:relative; width:48px; height:28px; flex:none; }
.switch input{ opacity:0; width:100%; height:100%; margin:0; position:absolute; cursor:pointer; }
.switch .track{ position:absolute; inset:0; background: var(--border); border-radius:999px; transition:.15s; }
.switch .track::before{ content:""; position:absolute; width:22px; height:22px; left:3px; top:3px; background:#fff; border-radius:50%; transition:.15s; box-shadow: 0 1px 3px rgba(0,0,0,.25); }
.switch input:checked + .track{ background: var(--blue-700); }
.switch input:checked + .track::before{ transform: translateX(20px); }
.switch input:disabled + .track{ background:#EEF1F5; }

.range-block{ background: var(--bg-soft); border:1px solid var(--border); border-radius: var(--radius-m); padding: 24px; }
.range-block input[type=range]{ width:100%; accent-color: var(--blue-700); margin: 14px 0 6px; }
.range-block__scale{ display:flex; justify-content:space-between; font-size:.82rem; color: var(--muted-soft); }
.range-block__value{ text-align:center; font-weight:800; font-size:1.5rem; color: var(--blue-800); margin: 4px 0; }

.stepper{ counter-reset: step; display:flex; flex-direction:column; gap:0; }
.stepper__item{ display:grid; grid-template-columns: 40px 1fr; gap:16px; padding-bottom: 34px; position:relative; }
.stepper__item:not(:last-child)::before{ content:""; position:absolute; left:19px; top:38px; bottom:0; width:2px; background: var(--border); }
.stepper__num{ counter-increment: step; width:40px; height:40px; border-radius:50%; background: var(--blue-700); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:800; }
.stepper__num::before{ content: counter(step); }
.stepper__body h3{ margin-bottom:6px; font-size:1.05rem; }
.stepper__body{ padding-top:6px; }

/* ==========================================================================
   Таблиці / сховище звітів
   ========================================================================== */
.table-wrap{ overflow-x:auto; border:1px solid var(--border); border-radius: var(--radius-m); background:#fff; }
table.reports{ width:100%; border-collapse: collapse; min-width: 720px; }
table.reports th{ text-align:left; font-size:.82rem; text-transform:uppercase; letter-spacing:.04em; color: var(--muted); padding: 14px 18px; background: var(--bg-soft); border-bottom:1px solid var(--border); }
table.reports td{ padding: 16px 18px; border-bottom:1px solid var(--border-soft); font-size:.94rem; vertical-align:middle; }
table.reports tr:last-child td{ border-bottom:none; }
.status-pill{ display:inline-flex; align-items:center; gap:6px; padding:5px 12px; border-radius:999px; font-size:.8rem; font-weight:700; }
.status-pill--done{ background: var(--success-bg); color: var(--success); }
.status-pill--processing{ background: var(--gold-100); color:#8A6900; }
.status-pill--draft{ background:#F1F3F6; color: var(--muted); }
.filebtns{ display:flex; gap:8px; }
.filebtns a{ font-size:.82rem; font-weight:700; padding: 7px 12px; border-radius:8px; border:1.5px solid var(--border); text-decoration:none; color: var(--blue-700); }
.filebtns a:hover{ border-color: var(--blue-700); background: var(--blue-100); }
.watermark-note{ display:flex; gap:12px; align-items:flex-start; background: var(--gold-100); border:1px solid #F0DE9A; border-radius: var(--radius-m); padding:18px 20px; margin-bottom: 30px; }
.storage-note{ display:flex; gap:12px; align-items:flex-start; background: var(--blue-100); border-radius: var(--radius-m); padding:18px 20px; margin-top: 30px; font-size:.92rem; color: var(--blue-900); }

/* ==========================================================================
   Стрічка вимог / CTA / Футер
   ========================================================================== */
.cta-band{ background: var(--blue-700); border-radius: var(--radius-l); padding: 52px 46px; display:flex; align-items:center; justify-content:space-between; gap: 30px; color:#fff; flex-wrap:wrap; }
.cta-band h2{ color:#fff; margin-bottom:6px; }
.cta-band p{ color: rgba(255,255,255,.85); margin:0; }

.site-footer{ background: var(--logo-navy); color: rgba(255,255,255,.85); padding: 60px 0 26px; border-top: 1px solid var(--divider-blue); }
.footer-grid{ display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; }
.footer-brand{ display:flex; align-items:center; gap:10px; color:#fff; font-weight:800; margin-bottom: 14px; text-decoration:none; line-height:0; }
.footer-brand__logo{ height:38px; width:auto; border-radius:5px; }
.footer-brand .brand__mark{ background: var(--yellow-500); color: var(--blue-900); }
.site-footer h4{ color:#fff; font-size:.88rem; text-transform:uppercase; letter-spacing:.05em; margin-bottom: 16px; }
.site-footer ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
.site-footer a{ text-decoration:none; color: rgba(255,255,255,.75); font-size:.94rem; }
.site-footer a:hover{ color:#fff; }
.footer-bottom{ margin-top: 46px; padding-top: 24px; border-top:1px solid var(--divider-blue); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:.85rem; color: rgba(255,255,255,.55); }
@media (max-width: 900px){ .footer-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .footer-grid{ grid-template-columns: 1fr; } .cta-band{ flex-direction:column; align-items:flex-start; } }

/* ==========================================================================
   Кукі-банер
   ========================================================================== */
.cookie-banner{
  position: fixed; left:16px; right:16px; bottom:16px; z-index: 100;
  max-width: 760px; margin: 0 auto; background:#fff; border:1px solid var(--border);
  border-radius: var(--radius-m); box-shadow: var(--shadow-hover); padding: 22px 24px;
  display:flex; gap: 18px; align-items:center; flex-wrap:wrap;
  transform: translateY(140%); opacity:0; transition: all .35s ease;
}
.cookie-banner.is-visible{ transform: translateY(0); opacity:1; }
.cookie-banner p{ margin:0; font-size:.92rem; color: var(--muted); flex:1; min-width:220px; }
.cookie-banner__actions{ display:flex; gap:10px; flex-wrap:wrap; }

/* ==========================================================================
   Сторінка входу в адмінку
   ========================================================================== */
.admin-shell{ min-height: 100vh; display:flex; align-items:center; justify-content:center; background: var(--logo-navy); padding: 24px; }
.admin-card{ background:#fff; border-radius: var(--radius-l); padding: 44px; max-width: 420px; width:100%; box-shadow: 0 24px 60px rgba(0,0,0,.35); }
.admin-card .brand{ justify-content:center; margin-bottom: 8px; }
.admin-note{ background: var(--bg-soft); border-radius:10px; padding: 14px 16px; font-size:.85rem; color: var(--muted); margin-top: 20px; }

/* ==========================================================================
   Юридичні сторінки
   ========================================================================== */
.legal-layout{ display:grid; grid-template-columns: 260px 1fr; gap: 48px; align-items:start; }
.legal-toc{ position:sticky; top: 100px; background: var(--bg-soft); border-radius: var(--radius-m); padding: 22px; }
.legal-toc h4{ margin: 0 0 12px; font-size:.85rem; text-transform:uppercase; letter-spacing:.04em; color: var(--muted); }
.legal-toc ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:9px; }
.legal-toc a{ text-decoration:none; font-size:.9rem; color: var(--muted); }
.legal-toc a:hover{ color: var(--blue-700); }
.legal-body h2{ margin-top: 44px; scroll-margin-top: 100px; }
.legal-body h2:first-child{ margin-top:0; }
.legal-body p, .legal-body li{ color: var(--muted); }
.legal-body ul{ padding-left: 20px; }
@media (max-width: 900px){ .legal-layout{ grid-template-columns:1fr; } .legal-toc{ position:static; } }

/* ==========================================================================
   Утиліти
   ========================================================================== */
.mt-0{ margin-top:0 !important; }
.text-center{ text-align:center; }
.stack-gap{ display:flex; flex-direction:column; gap: 18px; }
.skip-link{ position:absolute; left:-999px; top:0; background:var(--blue-700); color:#fff; padding:10px 16px; border-radius:0 0 8px 0; z-index:200; }
.skip-link:focus{ left:0; }
.divider{ height:1px; width:100%; background: var(--divider-blue); border:none; margin:0; }
