/* =============================
   TryToMix — styles.css (consolidated v2)
   Чистый фон, стабильный хедер, резиновая сетка, аккуратный device
   ============================= */

/* ===== Палитры ===== */
:root {
  --lemon-grass:#9b9e7c; --primrose-pink:#f6d6de; --hot-chocolate:#6f4e37; --damson:#7c3a6c;
  --lyons-blue:#005b7f; --poppy-red:#dc3c3c; --chili-oil:#944e36; --brandied-melon:#d99058;
  --bronze-brown:#805a3b; --winterberry:#a23b5f; --desert-sun:#d27d2d; --lavender-blue:#c5cbe1;

  --bg:#0e0d10; --text:#ecebed; --muted:#bfb8c6; --card:#16141b;
  --stroke:rgba(255,255,255,.08); --glass:rgba(255,255,255,.06);
  --radius:18px; --shadow:0 10px 30px rgba(0,0,0,.35);
  --accent:var(--damson); --accent-2:var(--lyons-blue); --accent-3:var(--brandied-melon);

  --bg-grad-from:#0e0d10; --bg-grad-to:#15131a;
  --header-bg:rgba(14,13,16,.86); --header-bg-mobile:rgba(14,13,16,.94);
  --safe-top:env(safe-area-inset-top,0px);
}

/* Тема */
[data-theme="dark"]{
  --bg:#0e0d10; --text:#ecebed; --muted:#bfb8c6; --card:#16141b;
  --stroke:rgba(255,255,255,.08); --glass:rgba(255,255,255,.06); --shadow:0 10px 30px rgba(0,0,0,.35);
  --bg-grad-from:#0e0d10; --bg-grad-to:#15131a;
  --header-bg:rgba(14,13,16,.86); --header-bg-mobile:rgba(14,13,16,.94);
}
[data-theme="light"]{
  --bg:#faf8fb; --text:#1a1522; --muted:#5f5668; --card:#fff;
  --stroke:rgba(0,0,0,.08); --glass:rgba(0,0,0,.04); --shadow:0 8px 24px rgba(0,0,0,.08);
  --bg-grad-from:#faf8fb; --bg-grad-to:#f1eef3;
  --header-bg:rgba(250,248,251,.86); --header-bg-mobile:rgba(250,248,251,.94);
}

*{box-sizing:border-box}
html,body{height:100%}
html{background:var(--bg)}
body{
  margin:0;
  font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu;
  color:var(--text);
  background:transparent;
  overflow-x:hidden;
  min-height:100vh; min-height:100dvh; /* Safari fallback + modern */
}

/* Гладкий фон c поддержкой тем */
body::before{
  content:""; position:fixed; inset:0; z-index:-1;
  background:linear-gradient(180deg,var(--bg-grad-from) 0%,var(--bg-grad-to) 100%);
  will-change:transform;
}

/* Контейнер */
.wrap{max-width:1080px;margin:0 auto;padding:24px clamp(16px,3vw,24px)}

/* ===== Header ===== */
header{
  position:sticky; top:0; z-index:1000; padding-top:var(--safe-top);
  border-bottom:1px solid var(--stroke);
  -webkit-backdrop-filter:saturate(140%) blur(8px);
  backdrop-filter:saturate(140%) blur(8px);
  background:var(--header-bg);
}
.nav{display:flex; align-items:center; justify-content:space-between; gap:16px; min-height:64px; flex-wrap:nowrap}
.brand{display:flex; align-items:center; gap:12px; text-decoration:none; color:var(--text)}
.brand .wordmark{font-weight:700; letter-spacing:.4px; font-size:18px}
.logo-squares{width:36px; height:36px; display:grid; grid-template-columns:repeat(2,1fr); gap:3px}
.logo-squares span{display:block; border-radius:6px}
.sq-1{background:var(--damson)} .sq-2{background:var(--lyons-blue)} .sq-3{background:var(--brandied-melon)} .sq-4{background:var(--lemon-grass)}

.nav-links{display:flex; align-items:center; gap:12px; margin-left:auto; position:relative; z-index:10}
.icon-btn{display:none; align-items:center; justify-content:center; width:40px; height:40px; border-radius:10px; border:1px solid var(--stroke); background:var(--card); color:var(--text); cursor:pointer; font-weight:800; user-select:none}
.nav a.btn{padding:10px 16px; border-radius:999px; text-decoration:none; color:#fff; font-weight:600; background:linear-gradient(135deg,var(--accent),var(--accent-2)); box-shadow:0 6px 20px rgba(124,58,108,.35); border:1px solid rgba(255,255,255,.1)}

.menu{display:flex; align-items:center; gap:12px; z-index:20}
.menu a{color:var(--text); text-decoration:none}
.menu-theme{padding:8px 12px; border-radius:999px; border:1px solid var(--stroke); background:var(--card); color:var(--text); cursor:pointer}
.menu[hidden]{display:none !important}

/* Mobile */
@media (max-width:980px){
  header{backdrop-filter:none; -webkit-backdrop-filter:none; background:var(--header-bg-mobile)}
  #menuToggle{display:inline-flex; position:relative; z-index:30}
  .menu{position:absolute; top:calc(100% + 10px); right:0; background:var(--card); border:1px solid var(--stroke); border-radius:14px; padding:10px; box-shadow:var(--shadow); flex-direction:column; min-width:220px}
  .menu a,.menu button{padding:10px 8px; display:block; text-align:left}
}

/* Desktop */
@media (min-width:981px){
  .icon-btn{display:none}
  .menu{display:flex}
}

/* ===== Hero ===== */
.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center;padding:56px 0}
@media (max-width:980px){.hero{grid-template-columns:1fr;padding:32px 0 40px}}
.h1{font-size:clamp(28px,4.5vw,56px);line-height:1.06;letter-spacing:-.5px;margin:0 0 16px}
.lead{font-size:clamp(16px,1.8vw,20px);color:var(--muted);margin:0 0 24px}
.cta{display:flex;flex-wrap:wrap;gap:12px}
.cta a{text-decoration:none}
.btn-primary{padding:14px 18px;border-radius:14px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-2));border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow)}
.btn-secondary{padding:14px 18px;border-radius:14px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--hot-chocolate),var(--bronze-brown));border:1px solid rgba(255,255,255,.08)}

.hero-card{background:var(--glass);border:1px solid var(--stroke);border-radius:22px;padding:18px;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center}
.device{width:min(100%,380px);max-height:62svh;border-radius:18px;background:#0c0b0e;border:1px solid var(--stroke);position:relative;overflow:hidden}
.device:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(197,203,225,.05),transparent 30%);pointer-events:none}
.device img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
@media (min-width:981px){.device{max-height:78vh}}

/* ===== Sections ===== */
.section{padding:56px 0}
.section h2{font-size:clamp(22px,2.8vw,36px);margin:0 0 18px;letter-spacing:-.2px}
.kicker{color:var(--brandied-melon);font-weight:700;text-transform:uppercase;font-size:12px;letter-spacing:.14em}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:980px){.grid-3{grid-template-columns:1fr 1fr}}
@media (max-width:620px){.grid-3{grid-template-columns:1fr}}
.card{background:var(--card);border:1px solid var(--stroke);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.card h3{margin:0 0 8px;font-size:18px}
.card p{margin:0;color:var(--muted)}

/* ===== Steps ===== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media (max-width:980px){.steps{grid-template-columns:1fr 1fr}}
@media (max-width:620px){.steps{grid-template-columns:1fr}}
.step{background:var(--card);border:1px solid var(--stroke);border-radius:var(--radius);padding:16px}
.step b{color:var(--brandied-melon)}

/* ===== CTA band ===== */
.band{background:linear-gradient(135deg,rgba(124,58,108,.35),rgba(0,91,127,.28));border:1px solid var(--stroke);border-radius:22px;padding:22px;box-shadow:var(--shadow)}
.band .row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px}

/* ===== Pricing ===== */
.pricing{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;align-items:stretch}
.plan{background:var(--card);border:1px solid var(--stroke);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);display:flex;flex-direction:column;height:100%}
.plan h3{margin:0 0 8px;font-size:20px}
.price{font-size:32px;font-weight:800;margin:6px 0 12px}
.plan ul{margin:0 0 14px 18px;color:var(--muted)}
.plan .btn-primary{align-self:flex-start;margin-top:auto}

/* ===== Footer ===== */
footer{border-top:1px solid var(--stroke);padding:28px 0 48px;color:var(--muted)}
.footer-grid{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center}
.social a{color:var(--lavender-blue);text-decoration:none;margin-right:14px}

/* ==== Safari-specific fallbacks & tweaks ==== */

/* Make sure we have a stable min-height on Safari (older versions ignore dvh) */
body{ min-height:100vh; min-height:100dvh; }

/* Header blur on Safari needs prefixed property as well */
header{ -webkit-backdrop-filter:saturate(140%) blur(8px); }

/* Elevate z-index layering to avoid click-through issues on Safari */
.nav-links{ position:relative; z-index:10; }
#menuToggle{ position:relative; z-index:30; }
.menu{ z-index:20; }

/* Some Safari builds repaint fixed pseudo-elements oddly.
   Fall back to absolute (scrolling) background on WebKit. */
@supports (-webkit-touch-callout: none) {
  body::before{ position:absolute; }
}

/* Aspect-ratio fallback for older Safari */
@supports not (aspect-ratio: 1 / 1) {
  .device{ height:560px; }
  .device img{ height:100%; width:100%; object-fit:cover; }
}