:root{
  --bg:#0b0c10;
  --card:#101218;
  --muted:#9aa3b2;
  --text:#e9eef5;
  --accent:#50c878;
  --accent-2:#2ea97a;
  --border:#1b1f2a;
  --focus:#7fd8a7;
  --error:#ff6b6b;
  --shadow:0 10px 30px rgba(0,0,0,.25);
  --radius:14px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Inter, Arial, sans-serif;
  background:linear-gradient(180deg,#0b0c10 0%, #0e1117 100%);
  color:var(--text);
  line-height:1.55;
}

.container{max-width:1040px;margin:0 auto;padding:0 16px}
.site-header{position:sticky;top:0;z-index:10;background:rgba(16,18,24,.85);backdrop-filter:saturate(150%) blur(8px);border-bottom:1px solid var(--border)}
.header-grid{display:flex;align-items:center;gap:16px;min-height:64px}
.brand{display:inline-flex;align-items:center;gap:10px;color:var(--text);text-decoration:none;font-weight:700}
.main-nav{margin-left:auto;display:flex;gap:18px}
.main-nav a{color:var(--muted);text-decoration:none;padding:8px 10px;border-radius:8px}
.main-nav a:hover{color:var(--text);background:rgba(255,255,255,.06)}

.hero{padding:36px 0 10px}
.lede{color:var(--muted);max-width:720px}

.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:22px;
  margin:18px auto;
  box-shadow:var(--shadow);
}
.card h2{margin-top:0}

.form-grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap:14px;
}
fieldset{
  grid-column:1/-1;
  border:1px solid var(--border);
  border-radius:12px;
  padding:16px;
}
legend{color:var(--muted);padding:0 6px;font-size:.95rem}
.field{display:flex;flex-direction:column;gap:6px}
.field input,.field select{
  background:#0c0f14;
  color:var(--text);
  border:1px solid var(--border);
  border-radius:10px;
  padding:10px 12px;
  outline:none;
}
.field input:focus,.field select:focus{border-color:var(--focus);box-shadow:0 0 0 3px rgba(127,216,167,.15)}
.field small{color:var(--muted)}
.field.checkbox{flex-direction:row;align-items:center;gap:10px}
.custom-size.hidden{display:none}

.actions{display:flex;gap:10px;grid-column:1/-1;margin-top:6px}
.btn{
  appearance:none;border:1px solid var(--border);
  background:#12161f;color:var(--text);
  padding:10px 14px;border-radius:10px;cursor:pointer
}
.btn.primary{background:var(--accent);border-color:var(--accent-2);color:#06140e;font-weight:700}
.btn:hover{filter:brightness(1.06)}

.results{
  margin-top:12px;
  padding:14px;
  border:1px dashed var(--border);
  border-radius:12px;
  background:#0c0f14;
}
.results h3{margin:0 0 10px 0}
.results .grid{
  display:grid;grid-template-columns: repeat(2, minmax(0,1fr));gap:8px
}
.results .kv{
  background:#0f131a;border:1px solid var(--border);
  border-radius:10px;padding:10px
}
.results .kv b{display:block;font-size:1.1rem}
.muted{color:var(--muted)}
.site-footer{padding:30px 0;color:var(--muted)}
.footer-nav{display:flex;gap:16px;margin-bottom:6px}
details{background:#0f131a;border:1px solid var(--border);border-radius:10px;padding:10px 12px;margin:8px 0}

@media (max-width:880px){
  .form-grid{grid-template-columns:1fr}
  .results .grid{grid-template-columns:1fr}
  .main-nav{display:none}
}

/* Печать и PDF: A4-friendly */
@media print {
  body{background:#fff;color:#000}
  .site-header,.hero,.site-footer,.actions{display:none !important}
  .card{box-shadow:none;border:0}
}

/* Доступность */
:focus-visible{outline:2px dashed var(--focus);outline-offset:3px}

/* Схематичные варианты раскладки */
.pattern-wrap{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
.pattern-preview{
  width:100%;
  height:140px;
  border-radius:12px;
  border:1px solid var(--border);
  background-color:#0c0f14;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.02);
}
/* Прямая: полосы вдоль одной оси */
.pattern--straight{
  background-image:
    repeating-linear-gradient(0deg, rgba(80,200,120,.35) 0 6px, transparent 6px 22px);
}
/* Диагональ: диагональные полосы */
.pattern--diagonal{
  background-image:
    repeating-linear-gradient(45deg, rgba(80,200,120,.35) 0 6px, transparent 6px 22px);
}
/* Ёлочка: упрощённая «chevron» */
.pattern--herringbone{
  background-image:
    repeating-linear-gradient(45deg, rgba(80,200,120,.35) 0 10px, transparent 10px 20px),
    repeating-linear-gradient(-45deg, rgba(80,200,120,.35) 0 10px, transparent 10px 20px);
  background-blend-mode:screen;
}
/* Форс-схема для корректного рендера html2canvas/html2pdf */
body.force-pdf-colors {
  /* Переопределяем дизайн-переменные под белый фон */
  --bg:#ffffff;
  --card:#ffffff;
  --text:#000000;
  --muted:#444444;
  --border:#dddddd;
  /* Акценты можно приглушить — опционально */
  --accent:#000000;
  --accent-2:#000000;
  --focus:#000000;
}

/* Гарантируем чёрный текст и отсутствие смешивания/теней */
body.force-pdf-colors,
body.force-pdf-colors * {
  color:#000 !important;
  fill:#000 !important;   /* для SVG */
  stroke:#000 !important; /* для SVG линий/иконок */
  text-shadow:none !important;
  mix-blend-mode:normal !important;
  -webkit-print-color-adjust: exact;
  print-color-adjust: exact;
}

/* Чтобы сам отчёт точно был на белом */
body.force-pdf-colors #report { background:#fff !important; }
html.is-ios input,
html.is-ios select,
html.is-ios textarea {
  font-size: 16px !important;
}
html.is-ios { -webkit-text-size-adjust: 100%; }
/* ссылки в футере — белые во всех состояниях */
.site-footer .footer-nav a,
.site-footer .footer-nav a:visited {
  color: #fff;
}

.site-footer .footer-nav a:hover,
.site-footer .footer-nav a:focus {
  color: #fff;         /* сохраняем белый */
  opacity: .9;         /* лёгкий ховер-эффект (по желанию) */
  text-decoration: underline; /* или убери, если не нужно */
}

