/* =============================
   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);

  --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); }
[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); }

*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu;color:var(--text);background:var(--bg);overflow-x:hidden}
/* ФОН — гладкий линейный градиент без «блоков» */
body::before{content:"";position:fixed;inset:0;z-index:-1;background:linear-gradient(180deg,#0e0d10 0%,#15131a 100%)}

.wrap{max-width:1080px;margin:0 auto;padding:24px clamp(16px,3vw,24px)}

/* ===== Header ===== */
header{position:sticky;top:0;z-index:50;padding-top:var(--safe-top);border-bottom:1px solid var(--stroke);background:rgba(14,13,16,.86);backdrop-filter:saturate(140%) blur(8px)}
.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}
.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}
.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}
.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}

@media (max-width:980px){
  header{backdrop-filter:none;background:rgba(14,13,16,.94)}
  #menuToggle{display:inline-flex}
  .menu{display:none;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.open{display:flex}
  .menu a,.menu button{padding:10px 8px;display:block;text-align:left}
}
@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; }
}