:root{--bg:#ffffff;--bg-2:#f4f7fa;--bg-3:#e9eef4;--fg:#1e2533;--fg-2:#4a5566;--fg-3:#697282;--line:#e4e8ee;--line-2:#d3d9e2;--accent:#4ba0ff;--accent-2:#3baa87;--blue:#4ba0ff;--blue-dark:#2a87e8;--green:#3baa87;--green-dark:#2f8c6e;--radius:12px;--radius-sm:8px;--radius-lg:20px;--pad:1.25rem;--gap:2rem;--maxw:1280px}[data-theme=dark]{--bg:#0f1419;--bg-2:#161c24;--bg-3:#1e2630;--fg:#e8eaed;--fg-2:#b0b6bf;--fg-3:#7a818c;--line:#242b35;--line-2:#323a46}[data-density=roomy]{--gap:3rem}[data-density=compact]{--gap:1.25rem}*{box-sizing:border-box}body,html{margin:0;padding:0;overflow-x:clip}body{background:var(--bg);color:var(--fg);font-family:"Montserrat","Helvetica Neue",Arial,sans-serif;font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a,button{color:inherit}a{text-decoration:none;transition:color .15s ease}.logo i,a:hover{color:var(--blue)}a:hover{opacity:1}button{font:inherit;background:0 0;border:0;cursor:pointer}img{max-width:100%;display:block}h1,h2,h3,h4,h5,h6{font-weight:700;letter-spacing:-.01em;color:var(--fg);margin:0}.mono,.serif,h1,h2,h3,h4,h5,h6{font-family:"Montserrat",sans-serif}.upper{text-transform:uppercase;letter-spacing:.1em}.tiny{font-size:11px}.small{font-size:13px}.muted{color:var(--fg-3)}.dim,.nav-links .has-sub>a,.nav-links>a{color:var(--fg-2)}.container{max-width:var(--maxw);margin:0 auto;padding:0 2rem}@media (max-width:720px){.container{padding:0 1.25rem}}.rule,.rule-2{height:1px;border:0;margin:0}.rule{background:var(--line)}.rule-2{background:var(--line-2)}.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}[data-theme=dark] .nav{background:rgba(15,20,25,.92)}.nav-inner{justify-content:space-between;padding:16px 0}.logo,.nav-inner,.nav-links{display:flex;align-items:center}.logo{font-family:"Montserrat",sans-serif;font-weight:700;font-size:18px;letter-spacing:-.01em;gap:10px;color:var(--fg)}.logo:hover{color:var(--fg);opacity:1}.logo i{font-style:normal;font-weight:500}.logo .dot{width:34px;height:34px;border-radius:50%;background:url(../uploads/avatar.webp)center/cover no-repeat,var(--bg-2);display:inline-block;box-shadow:0 0 0 2px #fff,0 4px 14px -6px rgba(20,25,35,.35);flex-shrink:0}@media (max-width:720px){.logo .dot{width:28px;height:28px}}.nav-links{gap:22px;font-size:13px;font-weight:500;flex-wrap:nowrap}@media (max-width:1200px){.nav-links{gap:16px;font-size:12.5px}}@media (max-width:1050px){.nav-links{gap:12px;font-size:11.5px}}.nav-links .has-sub>a:hover,.nav-links>a:hover{color:var(--blue);opacity:1}.nav-links .has-sub{position:relative}.nav-links .has-sub>a{display:inline-flex;align-items:center;gap:4px}.nav-links .has-sub .caret{font-size:10px;color:var(--fg-3);transition:transform .2s ease}.nav-links .has-sub:focus-within .caret,.nav-links .has-sub:hover .caret{transform:rotate(180deg);color:var(--fg)}.nav-links .sub{position:absolute;top:calc(100% + 8px);left:-12px;min-width:220px;padding:8px;background:var(--bg);border:1px solid var(--line);border-radius:10px;box-shadow:0 20px 40px -18px rgba(20,25,35,.22);opacity:0;visibility:hidden;transform:translateY(-4px);transition:opacity .18s ease,transform .18s ease,visibility .18s;z-index:60}.nav-links .has-sub:focus-within .sub,.nav-links .has-sub:hover .sub{opacity:1;visibility:visible;transform:translateY(0)}.nav-links .has-sub::after{content:"";position:absolute;top:100%;left:0;right:0;height:12px}.nav-links .sub a{display:block;padding:9px 14px;font-size:13px;font-weight:500;color:var(--fg-2);border-radius:6px;white-space:nowrap}.nav-links .sub a:hover{background:var(--bg-2);color:var(--fg);opacity:1}.burger,.nav-cta{align-items:center}.nav-cta{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:11px 18px;background:var(--green);color:#fff;border:1px solid var(--green);border-radius:var(--radius-sm);display:inline-flex;gap:8px}.nav-cta:hover{background:var(--green-dark);border-color:var(--green-dark);color:#fff;opacity:1}.burger{display:none;flex-direction:column;align-items:center;justify-content:center;gap:0;width:28px;height:28px;padding:0;background:0 0;border:0;cursor:pointer;z-index:60;position:relative}.burger span{display:block;width:22px;height:2px;background:var(--fg);border-radius:2px;position:absolute;left:50%;margin-left:-11px;transition:transform .3s ease,opacity .2s ease}.burger span:nth-child(1){top:6px}.burger span:nth-child(2){top:13px}.burger span:nth-child(3){top:20px}.burger.active span:nth-child(1){top:13px;transform:rotate(45deg)}.burger.active span:nth-child(2){opacity:0}.burger.active span:nth-child(3){top:13px;transform:rotate(-45deg)}.mob-menu{position:fixed;inset:0;z-index:49;background:var(--bg);padding:80px 24px 32px;overflow-y:auto;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}.mob-menu.open{transform:translateX(0)}.mob-menu-inner{display:flex;flex-direction:column;gap:4px}.mob-link,.mob-sub{display:block;font-family:"Montserrat",sans-serif}.mob-link{padding:14px 0;font-weight:500;font-size:18px;color:var(--fg);border-bottom:1px solid var(--line)}.mob-sub{padding:10px 0 10px 24px;font-weight:400;font-size:15px;color:var(--fg-2)}.mob-cta{margin-top:24px}@media (max-width:900px){.nav-links{display:none}.burger{display:flex}}@media (min-width:901px){.mob-menu{display:none!important}}#tweaks-panel,.ph{border-radius:var(--radius)}.ph{position:relative;background:var(--bg-2) center/cover no-repeat;overflow:hidden;color:#fff}.ph::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.55)0,rgba(0,0,0,.15) 40%,transparent 70%);pointer-events:none}.ph .ph-label{position:absolute;left:14px;bottom:12px;font-weight:600;font-size:10px;letter-spacing:.1em;color:rgba(255,255,255,.92);z-index:2;text-shadow:0 1px 4px rgba(0,0,0,.5)}#tweaks-panel h5,.btn,.footer-title,.ph .ph-badge,.ph .ph-label{font-family:"Montserrat",sans-serif;text-transform:uppercase}.ph .ph-badge{position:absolute;top:12px;right:12px;font-weight:600;font-size:10px;letter-spacing:.1em;color:#fff;padding:5px 10px;border-radius:999px;background:rgba(0,0,0,.45);backdrop-filter:blur(4px);z-index:2}#tweaks-panel h5,.btn,.footer-title{font-weight:700}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 26px;background:var(--blue);color:#fff;border:1px solid var(--blue);font-size:12px;letter-spacing:.08em;border-radius:var(--radius-sm);transition:background .15s ease,transform .15s ease,box-shadow .15s ease;cursor:pointer}.btn:hover{background:var(--blue-dark);border-color:var(--blue-dark);color:#fff;opacity:1;transform:translateY(-1px);box-shadow:0 8px 20px -6px rgba(75,160,255,.4)}.btn-ghost{background:0 0;color:#1e6b52;border:1.5px solid var(--green)}.btn-ghost:hover,.btn-green:hover{color:#fff;box-shadow:0 8px 20px -6px rgba(59,170,135,.4)}.btn-ghost:hover,.btn-green{background:var(--green);border-color:var(--green)}.btn-green{color:#fff}.btn-green:hover{background:var(--green-dark);border-color:var(--green-dark)}.btn-outline{background:0 0;color:var(--blue);border:1.5px solid var(--blue)}.btn-outline:hover{background:var(--blue);color:#fff}.footer{background:var(--bg-2);border-top:1px solid var(--line);margin-top:100px;padding:60px 0 32px;font-size:13px;color:var(--fg-2)}.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}#tweaks-panel h5,.footer-title{font-size:11px;letter-spacing:.14em;color:var(--fg);margin:0 0 16px}.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}.footer a:hover{color:var(--blue)}.footer-bottom{margin-top:48px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-size:12px;color:var(--fg-3);flex-wrap:wrap;gap:12px 24px}.footer-legal{display:inline-flex;gap:12px;align-items:center;flex-wrap:wrap}.footer-legal a{color:var(--fg-3);border-bottom:1px solid transparent;padding-bottom:1px}.footer-legal a:hover{color:var(--fg);border-bottom-color:var(--line-2);opacity:1}.footer-legal .sep{color:var(--line-2)}@media (max-width:800px){.footer-grid{grid-template-columns:1fr 1fr}.footer-bottom{flex-direction:column;gap:12px}}@media (max-width:520px){.footer-grid{grid-template-columns:1fr;gap:28px}.footer{padding:40px 0 24px;margin-top:60px}}#tweaks-panel{position:fixed;right:20px;bottom:20px;background:#fff;border:1px solid var(--line-2);padding:16px 18px;font-size:12px;z-index:100;display:none;box-shadow:0 12px 40px rgba(30,37,51,.12);min-width:240px}[data-theme=dark] #tweaks-panel{background:var(--bg-2)}#tweaks-panel.open{display:block}#tweaks-panel h5{margin:0 0 12px;font-size:10px;color:var(--fg-3)}#tweaks-panel .row{display:flex;gap:6px;margin-bottom:10px}#tweaks-panel .row:last-child{margin-bottom:0}#tweaks-panel .chip{flex:1;padding:8px 10px;border:1px solid var(--line-2);border-radius:6px;text-align:center;font-size:11px;font-weight:600;cursor:pointer}#tweaks-panel .chip.active{background:var(--blue);color:#fff;border-color:var(--blue)}.section-label{font-family:"Montserrat",sans-serif;font-weight:700;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);display:flex;align-items:center;gap:12px;margin-bottom:20px}.section-label::before{content:"";display:inline-block;width:24px;height:2px;background:var(--blue)}.card-base{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:box-shadow .2s ease,transform .2s ease}.card-base:hover{box-shadow:0 12px 32px -10px rgba(30,37,51,.12);transform:translateY(-2px)}@media (max-width:520px){.btn{padding:12px 20px;font-size:12px}.btn,.btn-ghost{width:100%;justify-content:center}h1{font-size:clamp(28px,7vw,48px)!important}}::selection{background:var(--blue);color:#fff}
.ph .ph-cover{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 20%;z-index:0}
.lang-switch{display:inline-flex;align-items:center;justify-content:center;padding:5px 10px;font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--fg-2);border:1.5px solid var(--line-2);border-radius:6px;transition:all .15s ease}.lang-switch:hover{color:var(--fg);border-color:var(--fg);background:var(--bg-2);opacity:1}
.blog-content a { color: #2a6dd4; text-decoration: underline; text-underline-offset: 3px; }
.blog-content a:hover { color: #1a4fa0; }

/* === Mobile header fix === */
@media (max-width: 900px) {
  .nav-inner {
    padding-left: 16px !important;
    padding-right: 16px !important;
    padding-top: 14px !important;
    padding-bottom: 14px !important;
    min-height: 64px;
  }
  .logo {
    gap: 10px;
    min-width: 0;
    flex: 1;
  }
  .logo > span:not(.dot) {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
  }
  .burger {
    flex-shrink: 0;
    margin-left: 12px;
    width: 36px;
    height: 36px;
    display: flex !important;
    align-items: center;
    justify-content: center;
    padding: 4px;
  }
  .nav-cta {
    display: none !important;
  }
}

@media (max-width: 520px) {
  .nav-inner {
    padding-left: 16px !important;
    padding-right: 16px !important;
    padding-top: 12px !important;
    padding-bottom: 12px !important;
    min-height: 56px;
  }
  .logo {
    font-size: 16px !important;
    gap: 8px;
  }
  .logo .dot {
    width: 28px !important;
    height: 28px !important;
  }
}

@media (max-width: 375px) {
  .logo {
    font-size: 14px !important;
    gap: 7px;
  }
  .logo .dot {
    width: 26px !important;
    height: 26px !important;
  }
}
/* Index page CSS - extracted from inline */

/* ============ Hero (redesign) ============ */
.hero {
  position: relative;
  padding: 36px 0 96px;
  overflow: hidden;
}
.hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 55% at 88% 18%, rgba(232,176,74,0.10), transparent 62%),
    radial-gradient(ellipse 60% 50% at 12% 82%, rgba(75,160,255,0.07), transparent 62%);
  pointer-events: none; z-index: 0;
}
.hero > .container { position: relative; z-index: 1; }

@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: .35; } }

.hero-issue {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 0 26px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 72px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-3);
  gap: 20px;
}
.hero-issue .left,
.hero-issue .right { display: flex; gap: 28px; align-items: center; flex-wrap: wrap; }
.hero-issue .live-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #2fae7a;
  box-shadow: 0 0 0 4px rgba(47, 174, 122, 0.22);
  animation: pulse 2s ease-in-out infinite;
  display: inline-block;
  margin-right: 10px;
  vertical-align: middle;
}
.hero-issue .num {
  font-size: 12px; letter-spacing: 0.22em;
  color: var(--fg); font-weight: 700;
}
.hero-issue b { color: var(--fg); font-weight: 600; }

.hero-main {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 64px;
  align-items: start;
}

.hero-lockup { position: relative; }
.hero-lockup .vertical-mark {
  position: absolute;
  left: -42px; top: 6px;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-family: 'Montserrat', sans-serif;
  font-weight: 500; font-size: 10px;
  letter-spacing: 0.34em;
  color: var(--fg-3);
  text-transform: uppercase;
}

.hero-title-xl {
  font-family: 'Montserrat', sans-serif;
  font-weight: 300;
  font-size: clamp(60px, 10.5vw, 172px);
  line-height: 0.88;
  letter-spacing: -0.04em;
  margin: 0 0 32px;
  color: var(--fg);
}
.hero-title-xl .l1 { display: block; font-weight: 500; }
.hero-title-xl .l2 { display: block; }
.hero-title-xl .ital { font-style: italic; font-weight: 300; }
.hero-title-xl .mark { position: relative; display: inline-block; }
.hero-title-xl .mark::after {
  content: '';
  position: absolute; left: 3%; right: 3%;
  bottom: 0.10em; height: 0.11em;
  background: linear-gradient(90deg, #e8b04a 0%, #4ba0ff 100%);
  border-radius: 2px;
  opacity: 0.55;
}
.hero-title-xl .dot { color: #e8b04a; font-style: normal; font-weight: 500; }

.hero-lead-xl {
  font-family: 'Montserrat', sans-serif;
  font-weight: 300;
  font-size: clamp(19px, 1.85vw, 25px);
  line-height: 1.38;
  letter-spacing: -0.012em;
  color: var(--fg-2);
  max-width: 48ch;
  margin: 0 0 40px;
}
.hero-lead-xl em {
  font-style: italic;
  color: var(--fg);
  background: linear-gradient(180deg, transparent 62%, rgba(232,176,74,0.28) 62%);
  padding: 0 2px;
}

.hero-cta-row {
  display: flex; align-items: stretch; gap: 14px;
  flex-wrap: wrap;
}
/* Both buttons share the same pill shape, size and weight — equal visual footing */
.hero-cta-primary,
.hero-cta-secondary {
  position: relative;
  display: inline-flex; align-items: center; gap: 14px;
  padding: 16px 24px 16px 22px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.01em;
  border-radius: 60px;
  border: 1px solid transparent;
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease, background .2s;
  isolation: isolate;
}
.hero-cta-primary:hover,
.hero-cta-secondary:hover {
  transform: translateY(-1px);
  opacity: 1;
}

/* Primary — tropical: teal→sunset gradient + palm silhouette */
.hero-cta-primary {
  background: linear-gradient(135deg, #0e6f62 0%, #138776 38%, #e8a24a 100%);
  color: #fff;
}
.hero-cta-primary::before {
  content: ''; position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(circle at 85% 20%, rgba(255, 215, 150, 0.55) 0%, transparent 40%),
    radial-gradient(circle at 10% 100%, rgba(16, 90, 80, 0.6) 0%, transparent 45%);
  pointer-events: none;
}
.hero-cta-primary:hover {
  box-shadow: 0 14px 30px -8px rgba(232, 162, 74, 0.45), 0 8px 18px -10px rgba(14, 111, 98, 0.6);
  color: #fff;
}
.hero-cta-primary .ico,
.hero-cta-secondary .ico {
  width: 30px; height: 30px;
  border-radius: 50%;
  display: inline-grid; place-items: center;
  flex-shrink: 0;
}
.hero-cta-primary .ico {
  background: #f8d9a2; color: #0e3f3a;
}
.hero-cta-primary .ico svg { width: 16px; height: 16px; fill: currentColor; }

/* Secondary — library: warm cream + book icon, equal weight */
.hero-cta-secondary {
  background: #f5ecd9;
  color: #3a2b18;
  border-color: rgba(80, 55, 25, 0.12);
}
.hero-cta-secondary::before {
  content: ''; position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(circle at 15% 10%, rgba(180, 140, 70, 0.28) 0%, transparent 50%),
    radial-gradient(circle at 95% 100%, rgba(220, 180, 120, 0.35) 0%, transparent 55%);
  pointer-events: none;
}
.hero-cta-secondary:hover {
  background: #efe2c7;
  box-shadow: 0 14px 30px -10px rgba(80, 55, 25, 0.28);
  color: #2a1f10;
}
.hero-cta-secondary .ico {
  background: #3a2b18; color: #f5ecd9;
}
.hero-cta-secondary .ico svg { width: 16px; height: 16px; fill: currentColor; }
@media (max-width: 520px) {
  .hero-cta-primary, .hero-cta-secondary { flex: 1 1 100%; justify-content: center; }
}
.hero-cta-hint {
  margin-top: 16px;
  font-family: 'Montserrat', sans-serif;
  font-size: 12px; letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-3); font-weight: 500;
}

/* Photo column */
.hero-card { position: relative; padding: 12px 0 0; }
.hero-card .polaroid {
  position: relative;
  background: var(--bg);
  padding: 14px 14px 54px;
  box-shadow: 0 30px 60px -20px rgba(30,37,51,0.28), 0 0 0 1px var(--line);
  transform: rotate(1.4deg);
  transition: transform .4s ease;
}
.hero-card .polaroid:hover { transform: rotate(0deg) scale(1.012); }
.hero-card .polaroid .img {
  aspect-ratio: 3/4;
  background-size: cover;
  background-position: 22% center;
}
@media (max-width: 960px) {
  .hero-card .polaroid .img { aspect-ratio: 4/3; background-position: 24% center; }
}
@media (max-width: 520px) {
  .hero-card .polaroid .img { aspect-ratio: 4/5; background-position: 28% center; }
  .hero-card .polaroid { padding: 8px 8px 36px; }
  .hero-card .polaroid .cap { left: 12px; right: 12px; bottom: 10px; font-size: 10px; }
  .hero-card .polaroid .cap b { font-size: 12px; }
}
@media (max-width: 390px) {
  .hero-card .polaroid .img { aspect-ratio: 3/4; }
  .hero-card .polaroid { padding: 6px 6px 32px; }
}
.hero-card .polaroid .cap {
  position: absolute; left: 20px; right: 20px; bottom: 18px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px; letter-spacing: 0.08em;
  color: var(--fg-3); text-transform: uppercase;
  display: flex; justify-content: space-between; gap: 10px;
  font-weight: 500;
}
.hero-card .polaroid .cap b { font-weight: 600; color: var(--fg); letter-spacing: 0.04em; text-transform: none; font-size: 13px; }

.hero-float {
  position: absolute;
  background: rgba(15,20,25,0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 14px;
  padding: 10px 14px;
  box-shadow: 0 14px 32px -12px rgba(0,0,0,0.3);
  font-family: 'Montserrat', sans-serif;
  z-index: 2;
  color: #fff;
}
.hero-weather {
  top: -18px; left: -40px;
  transform: rotate(-2.5deg);
  display: flex; align-items: center; gap: 14px;
}
.hero-weather .temp {
  font-weight: 400; font-size: 30px;
  letter-spacing: -0.025em; color: #fff; line-height: 1;
}
.hero-weather .temp sup { font-size: 12px; color: rgba(255,255,255,0.6); font-weight: 500; }
.hero-weather .desc {
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(255,255,255,0.6); font-weight: 500; line-height: 1.6;
}
.hero-weather .desc b { color: #fff; display: block; font-weight: 700; font-size: 11px; }

.hero-note {
  bottom: 6px; right: -34px;
  transform: rotate(2deg);
  max-width: 236px;
  font-size: 13px; line-height: 1.45;
  color: rgba(255,255,255,0.8);
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
}
.hero-note .who {
  font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(255,255,255,0.5); margin-bottom: 6px; font-weight: 600;
  display: flex; align-items: center; gap: 10px;
}
.hero-note .who::before { content: ''; width: 16px; height: 1px; background: #e8b04a; display: inline-block; }
.hero-note em { font-style: italic; color: var(--fg); }

/* Stats row */
.hero-stats-row {
  margin-top: 96px;
  padding-top: 32px;
  border-top: 1px solid var(--line);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.hero-stats-row .cell {
  padding: 4px 28px;
  border-left: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 10px;
}
.hero-stats-row .cell:first-child { border-left: 0; padding-left: 0; }
.hero-stats-row .n {
  font-family: 'Montserrat', sans-serif;
  font-weight: 300;
  font-size: clamp(40px, 4.2vw, 60px);
  line-height: 0.9;
  letter-spacing: -0.035em;
  color: var(--fg);
}
.hero-stats-row .n sup {
  font-size: 0.36em; color: #e8b04a; font-weight: 500; margin-left: 2px;
}
.hero-stats-row .t {
  font-family: 'Montserrat', sans-serif;
  font-weight: 500;
  font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-3);
}

@media (max-width: 960px) {
  .hero { padding-bottom: 72px; }
  .hero-issue { flex-direction: column; align-items: flex-start; gap: 12px; margin-bottom: 48px; }
  .hero-main { grid-template-columns: 1fr; gap: 40px; }
  .hero-lockup .vertical-mark { display: none; }
  .hero-card { padding-top: 36px; }
  .hero-weather { top: -6px; left: 8px; }
  .hero-note { bottom: 14px; right: 8px; max-width: 200px; }
  .hero-stats-row { grid-template-columns: repeat(2, 1fr); row-gap: 32px; margin-top: 64px; }
  .hero-stats-row .cell:nth-child(3) { border-left: 0; padding-left: 0; }
}
@media (max-width: 520px) {
  .hero-weather { position: relative; top: 0; left: 0; transform: none; margin-bottom: 12px; display: inline-flex; }
  .hero-note { position: relative; right: 0; bottom: 0; transform: none; margin-top: 14px; max-width: 100%; }
  .hero-card .polaroid { transform: none; }
}

/* ============ Ticker ============ */
.ticker {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
  padding: 18px 0;
  background: var(--bg-3);
  font-family: 'Montserrat', sans-serif;  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--fg-2);
  background: var(--bg-2);
}
.ticker-track {
  display: flex;
  gap: 48px;
  white-space: nowrap;
  animation: ticker 50s linear infinite;
  width: max-content;
}
.ticker-track span { display: inline-flex; align-items: center; gap: 48px; }
.ticker-track .sep { color: var(--fg-3); }
@keyframes ticker {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ============ Manifest ============ */
.manifest {
  padding: 120px 0;
  border-bottom: 1px solid var(--line);
  background: var(--bg-2);
}
.manifest-grid {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) 1.5fr;
  gap: 64px;
  align-items: start;
}
.manifest-photo {
  position: relative;
  aspect-ratio: 4/5;
  background-color: var(--bg-3);
  background-size: cover;
  background-position: 50% 20%;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 22px 48px -24px rgba(20, 25, 35, 0.35);
}
.manifest-photo::after {
  content: '';
  position: absolute; left: 0; right: 0; bottom: 0;
  height: 38%;
  background: linear-gradient(to top, rgba(0,0,0,0.35), transparent);
  pointer-events: none;
}
.manifest-right { display: flex; flex-direction: column; gap: 28px; }
.manifest h2 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  font-size: clamp(36px, 4.5vw, 64px);
  line-height: 1.02;
  letter-spacing: -0.025em;
  margin: 0;
  text-wrap: balance;
}
.manifest h2 .ital-accent { font-style: italic; font-weight: 300; color: var(--fg-3); }
.manifest-body {
  font-size: 17px; line-height: 1.6;
  color: var(--fg-2);
  max-width: 60ch;
  text-wrap: pretty;
}
.manifest-body p { margin: 0 0 1em; }
.manifest-body p:first-child::first-letter {
  font-family: 'Montserrat', sans-serif;
  font-size: 4em;
  float: left;
  line-height: 0.85;
  margin: 6px 10px 0 0;
  font-weight: 300;
  color: var(--fg);
}
@media (max-width: 900px) {
  .manifest-grid { grid-template-columns: 1fr; gap: 32px; }
  .manifest-photo { aspect-ratio: 4/3; max-height: 420px; background-position: 50% 22%; }
  .manifest-body p:first-child::first-letter { font-size: 3em; }
}
@media (max-width: 520px) {
  .manifest-photo { aspect-ratio: 3/2; background-position: 50% 25%; }
}

/* ============ Curation / как отбираю ============ */
.curation {
  padding: 120px 0;
  border-bottom: 1px solid var(--line);
  background: var(--bg);
}
.curation-head {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 30px;
  margin-bottom: 56px;
}
.curation-head h2 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  font-size: clamp(36px, 4.5vw, 60px);
  line-height: 1.02;
  letter-spacing: -0.025em;
  margin: 0;
  max-width: 18ch;
  text-wrap: balance;
}
.curation-head h2 .ital-accent { font-style: italic; color: var(--fg-3); font-weight: 300; }
.curation-head p {
  max-width: 36ch;
  font-size: 14px;
  color: var(--fg-2);
  line-height: 1.55;
  margin: 0;
  text-wrap: pretty;
}
.curation-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
  background: var(--bg);
}
.curation-cell {
  padding: 32px 28px 28px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 14px;
  min-height: 240px;
}
.curation-cell .step {
  font-family: 'Montserrat', sans-serif; font-weight: 500;
  font-size: 10px; letter-spacing: 0.14em;
  color: var(--blue);
  display: flex; align-items: center; gap: 10px;
}
.curation-cell .step::before {
  content: ''; width: 20px; height: 1px; background: var(--blue);
}
.curation-cell h3 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  font-size: 22px;
  line-height: 1.1;
  letter-spacing: -0.015em;
  margin: 0;
  text-wrap: balance;
}
.curation-cell p {
  font-size: 13px;
  color: var(--fg-2);
  line-height: 1.55;
  margin: 0;
  text-wrap: pretty;
}
.curation-cell .check {
  margin-top: auto;
  font-size: 11px;
  color: var(--fg-3);
  font-family: 'Montserrat', sans-serif; font-weight: 500;
  letter-spacing: 0.06em;
  display: flex; align-items: center; gap: 8px;
}
.curation-cell .check::before {
  content: '✓'; color: var(--green); font-weight: 600;
}
@media (max-width: 900px) { .curation-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .curation-grid { grid-template-columns: 1fr; } }

/* ============ Help Grid (что я помогаю решить) ============ */
.help {
  padding: 120px 0;
  border-bottom: 1px solid var(--line);
  background: var(--bg-2);
}
.help-head {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  margin-bottom: 60px;
  gap: 30px;
}
.help h2 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  font-size: clamp(36px, 4.5vw, 60px);
  line-height: 1.02;
  letter-spacing: -0.025em;
  margin: 0;
  text-wrap: balance;
}
.help h2 .ital-accent { font-style: italic; font-weight: 300; }
.help-count {
  font-family: 'Montserrat', sans-serif;  font-weight: 500;
  font-size: 11px; letter-spacing: 0.1em;
  color: var(--fg-3);
}
.help-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
}
.help-cell {
  padding: 32px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  display: flex; flex-direction: column;
  min-height: 260px;
  text-decoration: none;
  color: inherit;
  transition: background .2s ease;
  position: relative;
}
.help-cell:hover { background: var(--bg-2); opacity: 1; }
.help-cell .idx {
  font-family: 'Montserrat', sans-serif;  font-weight: 500;
  font-size: 10px; letter-spacing: 0.14em;
  color: var(--fg-3);
  margin-bottom: 32px;
}
.help-cell h3 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  font-size: 28px;
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 0 0 12px;
}
.help-cell p {
  font-size: 14px;
  color: var(--fg-2);
  line-height: 1.5;
  margin: 0;
  text-wrap: pretty;
}
.help-cell .arrow {
  margin-top: auto;
  font-family: 'Montserrat', sans-serif;  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--fg-3);
  padding-top: 20px;
  display: flex; align-items: center; gap: 8px;
}
.help-cell:hover .arrow { color: var(--fg); }
.help-cell:hover .arrow .ar { transform: translateX(4px); }
.help-cell .arrow .ar { transition: transform .2s ease; display: inline-block; }
@media (max-width: 900px) {
  .help-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .help-grid { grid-template-columns: 1fr; }
}

/* ============ Excursions ============ */
.excursions {
  padding: 120px 0;
  border-bottom: 1px solid var(--line);
}
.exc-head {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 30px;
  margin-bottom: 60px;
}
.exc-head h2 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  font-size: clamp(36px, 4.5vw, 60px);
  line-height: 1.02;
  letter-spacing: -0.025em;
  margin: 0;
}
.exc-head h2 .ital-accent { font-style: italic; color: var(--fg-3); font-weight: 300; }
.exc-head .btn-catalog {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: 'Montserrat', sans-serif; font-weight: 500;
  font-size: 13px; letter-spacing: 0.06em;
  padding: 13px 22px;
  background: var(--fg); color: var(--bg);
  border-radius: 999px;
  text-decoration: none;
  transition: background .15s ease, transform .15s ease;
  white-space: nowrap;
}
.exc-head .btn-catalog:hover {
  background: #333; opacity: 1; transform: translateY(-1px); color: var(--bg);
}
.exc-head .btn-catalog .ar {
  width: 22px; height: 22px; border-radius: 50%;
  background: #fff; color: var(--fg);
  display: inline-grid; place-items: center;
  font-size: 13px; line-height: 1;
}
@media (max-width: 720px) {
  .exc-head { grid-template-columns: 1fr; gap: 18px; align-items: start; }
}

.exc-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.exc-card {
  display: flex; flex-direction: column;
  gap: 14px;
  color: inherit;
  transition: transform .25s ease;
}
.exc-card:hover { opacity: 1; transform: translateY(-4px); }
.exc-img {
  aspect-ratio: 3/4;
  position: relative;
}
.exc-tag {
  position: absolute; top: 12px; left: 12px;
  font-family: 'Montserrat', sans-serif;  font-weight: 500;
  font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 5px 9px;
  background: var(--fg); color: var(--bg);
  border-radius: 2px;
}
.exc-number {
  font-family: 'Montserrat', sans-serif;  font-weight: 500;
  font-size: 10px; letter-spacing: 0.14em; color: var(--fg-3);
  display: flex; justify-content: space-between;
  padding-top: 4px;
  border-top: 1px solid var(--line);
}
.exc-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 22px; font-weight: 400;
  letter-spacing: -0.02em; line-height: 1.1;
  margin: 0;
}
.exc-meta {
  font-size: 13px; color: var(--fg-3);
  display: flex; gap: 14px; flex-wrap: wrap;
}
.exc-meta span + span::before {
  content: "·"; margin-right: 14px; color: var(--line-2);
}
@media (max-width: 1100px) { .exc-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 800px) { .exc-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .exc-grid { grid-template-columns: 1fr; } }
.exc-more {
  display: flex; justify-content: center;
  margin-top: 60px;
}

/* ============ Services strip ============ */
.services {
  padding: 120px 0;
  border-bottom: 1px solid var(--line);
}
.services-head { margin-bottom: 60px; }
.services-head h2 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  font-size: clamp(36px, 4.5vw, 60px);
  line-height: 1.02;
  letter-spacing: -0.025em;
  margin: 0;
  max-width: 18ch;
}
.services-head h2 .ital-accent { font-style: italic; color: var(--fg-3); font-weight: 300; }
.services-list { border-top: 1px solid var(--line); }
.service-row {
  display: grid;
  grid-template-columns: 80px 1fr 2fr 1fr auto;
  gap: 30px;
  align-items: center;
  padding: 28px 8px;
  border-bottom: 1px solid var(--line);
  transition: padding .2s ease, background .2s ease;
  color: inherit;
}
.service-row:hover { background: var(--bg-2); padding-left: 20px; opacity: 1; }
.service-num {
  font-family: 'Montserrat', sans-serif;  font-weight: 500;
  font-size: 11px; letter-spacing: 0.14em; color: var(--fg-3);
}
.service-name {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(22px, 2.2vw, 32px);
  font-weight: 400; letter-spacing: -0.02em;
  line-height: 1.1;
}
.service-desc {
  font-size: 14px; color: var(--fg-2);
  max-width: 50ch;
  text-wrap: pretty;
}
.service-tags { font-size: 12px; color: var(--fg-3); font-family: 'Montserrat', sans-serif;  font-weight: 500; letter-spacing: 0.05em; }
.service-arrow {
  font-family: 'Montserrat', sans-serif;
  font-style: italic;
  font-size: 18px;
  color: var(--fg-3);
}
.service-row:hover .service-arrow { color: var(--fg); }
@media (max-width: 900px) {
  .service-row { grid-template-columns: 60px 1fr auto; }
  .service-desc, .service-tags { display: none; }
}

/* ============ Blog / Feed ============ */
.feed {
  padding: 120px 0;
  border-bottom: 1px solid var(--line);
  background: var(--bg-2);
}
.feed-head {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 30px;
  margin-bottom: 60px;
}
.feed-head h2 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  font-size: clamp(36px, 4.5vw, 60px);
  line-height: 1.02;
  letter-spacing: -0.025em;
  margin: 0;
}
.feed-head h2 .ital-accent { font-style: italic; color: var(--fg-3); font-weight: 300; }
.feed-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 40px;
}
.feed-main {
  display: flex; flex-direction: column; gap: 40px;
}
.post-lead {
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 20px;
}
.post-lead .ph { aspect-ratio: 16/10; }
.post-lead h3 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 0;
  text-wrap: balance;
}
.post-meta {
  font-family: 'Montserrat', sans-serif;  font-weight: 500;
  font-size: 11px; letter-spacing: 0.1em;
  color: var(--fg-3); text-transform: uppercase;
  display: flex; gap: 14px;
}
.post-excerpt { color: var(--fg-2); font-size: 15px; max-width: 55ch; line-height: 1.6; }

.feed-side {
  display: flex; flex-direction: column;
  border-top: 1px solid var(--line);
}
.feed-item {
  padding: 20px 0;
  border-bottom: 1px solid var(--line);
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 20px;
  color: inherit;
}
.feed-item:hover { opacity: 1; background: var(--bg-2); }
.feed-item .ph { aspect-ratio: 1/1; }
.feed-item h4 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  font-size: 18px;
  line-height: 1.15;
  letter-spacing: -0.015em;
  margin: 0 0 6px;
}
.feed-item .post-meta { font-size: 10px; }

@media (max-width: 900px) {
  .feed-grid { grid-template-columns: 1fr; }
}

/* ============ Weather section ============ */
.weather-sec {
  padding: 100px 0;
  background: var(--bg);
  border-bottom: 1px solid var(--line);
}
.weather-head {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 20px; flex-wrap: wrap;
  margin-bottom: 40px;
}
.weather-head h2 {
  font-family: 'Montserrat', sans-serif; font-weight: 400;
  font-size: clamp(34px, 4.5vw, 52px);
  line-height: 1.02; letter-spacing: -0.025em; margin: 0;
  text-wrap: balance;
}
.weather-head h2 .ital-accent { font-style: italic; color: var(--fg-3); font-weight: 300; }
.weather-head .weather-webcam-cta {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 11px 18px;
  background: #0f1a28; color: #fff;
  border-radius: 999px;
  font-family: 'Montserrat', sans-serif; font-weight: 500;
  font-size: 13px; letter-spacing: 0.02em;
  transition: transform .15s ease, box-shadow .2s ease, background .15s;
  white-space: nowrap;
}
.weather-head .weather-webcam-cta:hover {
  transform: translateY(-1px);
  background: #1d2a40;
  box-shadow: 0 12px 28px -10px rgba(15, 23, 35, 0.4);
  color: #fff; opacity: 1;
}
.weather-head .weather-webcam-cta svg {
  width: 16px; height: 16px; fill: #e8b04a;
}
.weather-head .weather-webcam-cta b { font-weight: 700; color: #e8b04a; }
@media (max-width: 680px) {
  .weather-head { flex-direction: column; align-items: flex-start; }
}
.weather-meta {
  font-family: 'Montserrat', sans-serif; font-weight: 500;
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--fg-3);
}
.weather-card {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 2.2fr;
  gap: 40px;
  padding: 36px 40px;
  border-radius: 18px;
  background:
    radial-gradient(ellipse 70% 60% at 90% 15%, rgba(232, 176, 74, 0.14), transparent 60%),
    radial-gradient(ellipse 60% 50% at 10% 90%, rgba(75, 160, 255, 0.10), transparent 60%),
    linear-gradient(180deg, #f6fbfa, #eaf4f1);
  border: 1px solid var(--line);
  box-shadow: 0 22px 50px -28px rgba(20, 25, 35, 0.25);
  align-items: center;
}
.wx-big { display: flex; flex-direction: column; gap: 8px; }
.wx-temp {
  font-family: 'Montserrat', sans-serif;
  font-weight: 300;
  font-size: clamp(72px, 12vw, 128px);
  line-height: 0.9;
  letter-spacing: -0.04em;
  color: var(--fg);
}
.wx-temp sup {
  font-size: 0.36em; color: var(--fg-3); font-weight: 400; margin-left: 4px;
}
.wx-cond {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(16px, 1.6vw, 20px);
  color: var(--fg-2);
  letter-spacing: -0.005em;
}
.wx-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
}
.wx-stat {
  padding: 18px 20px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.55);
}
.wx-stat .v {
  font-family: 'Montserrat', sans-serif;
  font-size: 24px; font-weight: 400;
  letter-spacing: -0.02em; line-height: 1.1;
  color: var(--fg);
}
.wx-stat .k {
  font-family: 'Montserrat', sans-serif; font-weight: 500;
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--fg-3);
  margin-top: 6px;
}
@media (max-width: 900px) {
  .weather-sec { padding: 72px 0; }
  .weather-card { grid-template-columns: 1fr; gap: 28px; padding: 28px 24px; }
  .wx-stats { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 420px) {
  .wx-stat { padding: 14px 16px; }
  .wx-stat .v { font-size: 20px; }
}

/* ============ Telegram live ============ */
.tg {
  padding: 120px 0;
  background: var(--bg-2);
  border-bottom: 1px solid var(--line);
}
.tg-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 80px;
  align-items: start;
}
.tg-intro h2 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  font-size: clamp(36px, 4.5vw, 56px);
  line-height: 1.02;
  letter-spacing: -0.025em;
  margin: 0 0 24px;
  text-wrap: balance;
}
.tg-intro h2 .ital-accent { font-style: italic; color: var(--fg-3); font-weight: 300; }
.tg-intro p {
  color: var(--fg-2); font-size: 16px;
  line-height: 1.6; max-width: 45ch; text-wrap: pretty;
  margin: 0 0 24px;
}
.tg-intro-cards {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
  margin-top: 28px;
}
.tg-intro-card {
  padding: 18px;
  border: 1px solid var(--line-2);
  background: var(--bg);
  color: inherit;
}
.tg-intro-card:hover { opacity: 1; background: var(--bg); border-color: var(--fg-3); }
.tg-intro-card .h {
  font-family: 'Montserrat', sans-serif;  font-weight: 500;
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--fg-3); margin-bottom: 10px;
}
.tg-intro-card .n {
  font-family: 'Montserrat', sans-serif;
  font-size: 18px; letter-spacing: -0.015em;
  margin-bottom: 4px;
}
.tg-intro-card .c { font-size: 12px; color: var(--fg-3); }

.tg-feed {
  background: var(--bg);
  border: 1px solid var(--line);
  padding: 8px;
  display: flex; flex-direction: column;
  max-height: 560px;
  overflow: hidden;
}
.tg-head {
  padding: 14px 16px;
  border-bottom: 1px solid var(--line);
  display: flex; justify-content: space-between; align-items: center;
  font-family: 'Montserrat', sans-serif;  font-weight: 500;
  font-size: 11px; color: var(--fg-3); letter-spacing: 0.08em;
}
.tg-head .live { display: flex; align-items: center; gap: 8px; }
.tg-head .live .d {
  width: 7px; height: 7px; border-radius: 50%; background: #e8b04a;
  box-shadow: 0 0 0 3px color-mix(in oklab, #e8b04a 18%, transparent);
  animation: pulse 2.2s ease-in-out infinite;
}
.tg-messages { padding: 16px; display: flex; flex-direction: column; gap: 18px; overflow-y: auto; }
.tg-msg { display: grid; grid-template-columns: 36px 1fr; gap: 12px; }
.tg-av {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--bg-3);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Montserrat', sans-serif;
  font-size: 16px; color: var(--fg-2);
}
.tg-body .meta {
  font-size: 11px; color: var(--fg-3);
  display: flex; gap: 10px; margin-bottom: 6px;
  font-family: 'Montserrat', sans-serif;  font-weight: 500; letter-spacing: 0.05em;
}
.tg-body .meta .name { color: var(--fg); }
.tg-body .text {
  font-size: 14px; line-height: 1.5; color: var(--fg-2);
  text-wrap: pretty;
}
.tg-body .text b { color: var(--fg); font-weight: 500; }
@media (max-width: 900px) {
  .tg-grid { grid-template-columns: 1fr; gap: 40px; }
}

/* ============ Video ============ */
.video-sec {
  padding: 120px 0;
  border-bottom: 1px solid var(--line);
}
.video-head {
  display: grid; grid-template-columns: 1fr auto; align-items: end;
  gap: 30px; margin-bottom: 60px;
}
.video-head h2 {
  font-family: 'Montserrat', sans-serif; font-weight: 400;
  font-size: clamp(36px, 4.5vw, 60px);
  line-height: 1.02; letter-spacing: -0.025em; margin: 0;
}
.video-head h2 .ital-accent { font-style: italic; color: var(--fg-3); font-weight: 300; }
/* .video-grid: только позиционная обёртка для карусели и стрелок —
   реальная сетка карточек живёт в shared/youtube.js (.yt-track). */

/* ============ Contact CTA ============ */
/* Social links — replaces old contact-cta */
.social-cta { padding: 100px 0; border-top: 1px solid var(--line); }
.social-cta h2 {
  font-family: 'Montserrat', sans-serif; font-weight: 400;
  font-size: clamp(34px, 4.5vw, 56px);
  line-height: 1.02; letter-spacing: -0.025em;
  margin: 0 0 14px; text-wrap: balance;
}
.social-cta h2 .ital-accent { font-style: italic; font-weight: 300; color: var(--fg-3); }
.social-lead {
  font-family: 'Montserrat', sans-serif; font-weight: 400;
  font-size: 16px; line-height: 1.55;
  color: var(--fg-2); max-width: 56ch;
  margin: 0 0 44px;
}
.social-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
@media (max-width: 960px) { .social-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .social-grid { grid-template-columns: 1fr; } }
.soc-card {
  display: grid; grid-template-columns: 56px 1fr; gap: 18px;
  align-items: center;
  padding: 22px 26px; border-radius: 16px;
  background: var(--bg); border: 1px solid var(--line);
  color: inherit; text-decoration: none;
  transition: transform .2s ease, box-shadow .25s ease, border-color .2s;
}
.soc-card:hover {
  transform: translateY(-3px);
  border-color: transparent;
  box-shadow: 0 22px 48px -26px rgba(20, 25, 35, 0.28);
  opacity: 1;
}
.soc-ico {
  width: 56px; height: 56px; border-radius: 14px;
  display: grid; place-items: center;
  color: #fff;
}
.soc-ico svg { width: 28px; height: 28px; fill: currentColor; }
.soc-card.soc-tg-ch .soc-ico { background: #27a8e9; }
.soc-card.soc-yt .soc-ico { background: #ff0033; }
.soc-card.soc-ig .soc-ico {
  background: radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%, #d6249f 60%, #285AEB 90%);
}
.soc-label {
  font-family: 'Montserrat', sans-serif; font-weight: 600;
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--fg-3);
}
.soc-handle {
  font-family: 'Montserrat', sans-serif; font-weight: 600;
  font-size: 17px; letter-spacing: -0.01em;
  color: var(--fg); margin: 2px 0 4px;
}
.soc-desc {
  font-family: 'Montserrat', sans-serif; font-size: 13px; line-height: 1.45;
  color: var(--fg-2);
}

.contact-cta {
  padding: 140px 0;
  border-bottom: 1px solid var(--line);
  position: relative;
  background:
    radial-gradient(ellipse 60% 50% at 20% 20%, rgba(232, 176, 74, 0.10), transparent 60%),
    radial-gradient(ellipse 70% 60% at 85% 80%, rgba(75, 160, 255, 0.08), transparent 60%),
    var(--bg);
}
.contact-cta h2 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  font-size: clamp(44px, 7vw, 120px);
  line-height: 0.96;
  letter-spacing: -0.03em;
  margin: 0 0 60px;
  text-wrap: balance;
}
.contact-cta h2 .ital-accent { font-style: italic; font-weight: 300; color: var(--fg-3); }
.contact-cta .row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  border-top: 1px solid var(--line);
}
.contact-cta .col {
  padding: 32px 24px 32px 0;
  border-right: 1px solid var(--line);
}
.contact-cta .col:last-child { border-right: 0; padding-right: 0; }
.contact-cta .col .lbl {
  font-family: 'Montserrat', sans-serif;  font-weight: 500;
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--fg-3); margin-bottom: 10px;
}
.contact-cta .col a {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(20px, 2vw, 28px);
  letter-spacing: -0.015em;
  line-height: 1.2;
  display: block;
}
.contact-cta .col .sub { font-size: 13px; color: var(--fg-3); margin-top: 6px; }
@media (max-width: 800px) {
  .contact-cta .row { grid-template-columns: 1fr; }
  .contact-cta .col { border-right: 0; border-bottom: 1px solid var(--line); padding: 24px 0; }
}

  .site-cookie, .site-chatpop {
    position: fixed;
    z-index: 200;
    font-family: 'Montserrat', sans-serif;
    
    color: var(--fg);
  }

  /* Cookie banner — bottom, full width, thin strip */
  .site-cookie {
    left: 0; right: 0; bottom: 0;
    background: var(--bg);
    border-top: 1px solid var(--line);
    padding: 18px 28px;
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 24px;
    transform: translateY(120%);
    transition: transform .45s cubic-bezier(.22,.61,.36,1);
  }
  .site-cookie.show { transform: translateY(0); }
  .site-cookie .txt {
    font-size: 14px;
    line-height: 1.55;
    color: var(--fg-2);
    max-width: 88ch;
    text-wrap: pretty;
  }
  .site-cookie .txt b {
    font-weight: 500;
    color: var(--fg);
    
  }
  .site-cookie .txt a {
    border-bottom: 1px solid var(--line-2);
    padding-bottom: 1px;
    color: var(--fg);
  }
  .site-cookie .btns { display: flex; gap: 8px; flex-shrink: 0; }
  .site-cookie button {
    font-family: 'Montserrat', sans-serif;
    
    font-weight: 500;
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 11px 20px;
    border: 1px solid var(--line-2);
    background: var(--bg);
    color: var(--fg);
    cursor: pointer;
    transition: background .15s ease, color .15s ease;
  }
  .site-cookie button.primary {
    background: var(--fg);
    color: var(--bg);
    border-color: var(--fg);
  }
  .site-cookie button:hover { background: var(--bg-2); }
  .site-cookie button.primary:hover { background: var(--fg-2); color: var(--bg); opacity: 1; }
  @media (max-width: 720px) {
    .site-cookie { grid-template-columns: 1fr; padding: 16px 18px; gap: 14px; }
    .site-cookie .btns { justify-content: flex-end; }
  }

  /* Chat pop-up — bottom-right card, bigger, editorial */
  .site-chatpop {
    right: 28px;
    bottom: 28px;
    width: 380px;
    max-width: calc(100vw - 40px);
    background: var(--bg);
    border: 1px solid var(--line-2);
    box-shadow: 0 30px 60px -20px rgba(0,0,0,.45);
    padding: 28px 28px 24px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    transform: translateY(24px) scale(.96);
    opacity: 0;
    pointer-events: none;
    transition: transform .5s cubic-bezier(.22,.61,.36,1), opacity .4s ease;
  }
  [data-theme="light"] .site-chatpop {
    box-shadow: 0 30px 60px -20px rgba(0,0,0,.18);
  }
  .site-chatpop.show {
    transform: translateY(0) scale(1);
    opacity: 1;
    pointer-events: auto;
  }
  .site-chatpop .chatpop-head {
    display: flex; align-items: center; justify-content: space-between;
    font-family: 'Montserrat', sans-serif;
    
    font-weight: 500;
    font-size: 10px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--fg-3);
  }
  .site-chatpop .chatpop-head .live {
    display: inline-flex; align-items: center; gap: 8px;
  }
  .site-chatpop .chatpop-head .live::before {
    content: '';
    width: 6px; height: 6px; border-radius: 50%;
    background: #7cc67a;
    box-shadow: 0 0 0 3px color-mix(in oklab, #7cc67a 20%, transparent);
  }
  .site-chatpop .close {
    background: none; border: 0; cursor: pointer;
    color: var(--fg-3);
    font-size: 18px; line-height: 1;
    padding: 2px 4px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 300;
  }
  .site-chatpop .close:hover { color: var(--fg); }
  .site-chatpop h3 {
    margin: 0;
    font-family: 'Montserrat', sans-serif;
    
    
    font-weight: 400;
    font-size: 30px;
    line-height: 1.05;
    letter-spacing: -0.02em;
    text-wrap: balance;
  }
  .site-chatpop h3 em {
    font-style: italic;
    font-weight: 300;
    color: var(--fg-3);
    
  }
  .site-chatpop p {
    margin: 0;
    font-size: 14px;
    line-height: 1.55;
    color: var(--fg-2);
    text-wrap: pretty;
  }
  .site-chatpop .chatpop-stats {
    display: flex; gap: 18px;
    padding: 14px 0 4px;
    border-top: 1px solid var(--line);
    margin-top: 2px;
  }
  .site-chatpop .chatpop-stats .s {
    display: flex; flex-direction: column; gap: 2px;
  }
  .site-chatpop .chatpop-stats .n {
    font-family: 'Montserrat', sans-serif;
    font-size: 22px;
    font-weight: 400;
    line-height: 1;
    letter-spacing: -0.02em;
  }
  .site-chatpop .chatpop-stats .l {
    font-family: 'Montserrat', sans-serif;
    
    font-weight: 500;
    font-size: 9px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--fg-3);
  }
  .site-chatpop .chatpop-btns {
    display: flex; gap: 8px; margin-top: 4px;
  }
  .site-chatpop a.btn-primary, .site-chatpop button.btn-ghost {
    flex: 1;
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    font-family: 'Montserrat', sans-serif;
    
    font-weight: 500;
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 13px 16px;
    border: 1px solid var(--line-2);
    text-decoration: none;
    cursor: pointer;
    transition: background .15s ease, opacity .15s ease;
  }
  .site-chatpop a.btn-primary {
    background: var(--fg);
    color: var(--bg);
    border-color: var(--fg);
  }
  .site-chatpop a.btn-primary:hover { opacity: .85; }
  .site-chatpop button.btn-ghost {
    background: var(--bg);
    color: var(--fg);
    flex: 0 0 auto;
    padding: 13px 14px;
  }
  .site-chatpop button.btn-ghost:hover { background: var(--bg-2); }
  @media (max-width: 720px) {
    .site-chatpop {
      right: 12px; left: 12px; bottom: 12px;
      width: auto; padding: 22px 22px 20px;
    }
    .site-chatpop h3 { font-size: 26px; }
  }

.hero-services { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.hs-card {
  position:relative; height:280px; border-radius:22px; overflow:hidden;
  text-decoration:none; cursor:pointer;
  transition:transform .3s cubic-bezier(.22,.61,.36,1), box-shadow .3s;
}
.hs-card:hover { transform:scale(1.03); z-index:10; box-shadow:0 16px 40px -8px rgba(0,0,0,0.4); opacity:1; }
.hs-img { position:absolute; inset:0; background:center/cover no-repeat; transition:transform .4s; }
.hs-card:hover .hs-img { transform:scale(1.06); }
.hs-overlay { position:absolute; inset:0; background:linear-gradient(to top, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.15) 55%, transparent 100%); }
.hs-text { position:absolute; bottom:0; left:0; right:0; padding:28px 32px; z-index:2; }
.hs-title { display:block; font-family:'Montserrat',sans-serif; font-weight:700; font-size:24px; letter-spacing:0.02em; color:#fff; text-shadow:0 2px 6px rgba(0,0,0,0.5); }
.hs-sub { display:block; font-size:15px; color:rgba(255,255,255,0.85); margin-top:6px; text-shadow:0 1px 4px rgba(0,0,0,0.5); }
@media(max-width:520px) {
  .hero-services { grid-template-columns:1fr; gap:14px; }
  .hs-card { height:200px; border-radius:16px; }
  .hs-title { font-size:20px; }
  .hs-sub { font-size:13px; }
  .hs-text { padding:20px 22px; }
}
.hs-wide{grid-column:1/-1}
