/* === FONTS === */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/Inter-400-cyrillic.woff2') format('woff2');unicode-range:U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/Inter-400-latin.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}

@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/Inter-700-cyrillic.woff2') format('woff2');unicode-range:U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/Inter-700-latin.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Inter';font-style:normal;font-weight:800;font-display:swap;src:url('/fonts/Inter-800-cyrillic.woff2') format('woff2');unicode-range:U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F}

@font-face{font-family:'Manrope';font-style:normal;font-weight:800;font-display:swap;src:url('/fonts/Manrope-800-cyrillic.woff2') format('woff2');unicode-range:U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F}

/* === /FONTS === */
/* Openlock — Friendly Neon (04) · mobile-first */

*,*::before,*::after{box-sizing:border-box}
:root{
  --bg:#0d0a1f;
  --surface:#1a1438;
  --surface-2:#241a4a;
  --ink:#f0eafd;
  --muted:#a4a0c8;
  --soft:rgba(255,255,255,.06);
  --line:rgba(255,255,255,.10);
  --accent:#a855f7;     /* purple */
  --accent2:#22d3ee;    /* cyan */
  --accent3:#f472b6;    /* pink */
  --grad: linear-gradient(135deg,var(--accent) 0%,var(--accent3) 100%);
  --grad-2: linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%);
  --shadow-sm: 0 2px 8px rgba(168,85,247,.15);
  --shadow-md: 0 8px 24px rgba(168,85,247,.18);
  --shadow-lg: 0 16px 40px rgba(168,85,247,.30);
  --radius: 14px;
  --radius-sm: 10px;
  --radius-lg: 24px;
}

html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter','SF Pro Text','Segoe UI',Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.55;
  font-size:15px;
  font-feature-settings:'cv11','ss01','ss03';
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  min-height:100vh;
  position:relative;
  overflow-x:hidden;
}
/* Display font for hero/h1/page-head */
.hero h1,.page-head h1,.contact-section h2,.services h2{
  font-family:'Manrope','Inter',sans-serif;
}
/* Background glow blobs */
body::before{content:"";position:fixed;width:300px;height:300px;background:radial-gradient(circle,rgba(168,85,247,.18),transparent 70%);top:-150px;left:-100px;z-index:0;filter:blur(40px);pointer-events:none}
body::after{content:"";position:fixed;width:280px;height:280px;background:radial-gradient(circle,rgba(34,211,238,.15),transparent 70%);bottom:-120px;right:-100px;z-index:0;filter:blur(40px);pointer-events:none}

a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block;border-radius:8px}
button{font-family:inherit}
h1,h2,h3,h4{margin:0 0 .55em;font-weight:800;letter-spacing:-.02em;line-height:1.2}
p{margin:0 0 1em}

.container{max-width:1180px;margin:0 auto;padding:0 18px;position:relative;z-index:1}
.muted{color:var(--muted)}

.text-grad{background:var(--grad);-webkit-background-clip:text;-webkit-background-clip:text;background-clip:text;color:transparent}

/* ============== TOPBAR ============== */
.topbar{padding:8px 0;font-size:12px;color:var(--muted);border-bottom:1px solid var(--line)}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:12px}
.topbar .t-info{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.topbar a{color:var(--accent2);padding:0 4px}

/* ============== HEADER ============== */
.site-header{
  padding:14px 0;
  position:-webkit-sticky;position:sticky;top:0;z-index:50;
  background:rgba(13,10,31,.72);
  -webkit-backdrop-filter: blur(16px) saturate(140%);backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:12px}
.logo{
  display:flex;gap:8px;align-items:center;
  font-weight:900;font-size:20px;letter-spacing:-.02em;
  color:var(--ink);
}
.logo .badge{
  width:34px;height:34px;
  background:var(--grad);
  color:#fff;border-radius:10px;
  display:grid;place-items:center;
  font-size:18px;
  box-shadow:var(--shadow-sm);
}
.logo-text{background:var(--grad);-webkit-background-clip:text;-webkit-background-clip:text;background-clip:text;color:transparent}
.logo-light{color:#fff}
.logo-light .logo-text{background:var(--grad-2);-webkit-background-clip:text;-webkit-background-clip:text;background-clip:text;color:transparent}

.main-nav ul{
  list-style:none;margin:0;padding:0;
  display:none;
}
.main-nav a{
  color:var(--ink);padding:8px 14px;border-radius:20px;font-size:14px;font-weight:500;
  transition:.2s;
}
.main-nav a:hover{background:rgba(168,85,247,.15);color:#fff}
.main-nav a.active{background:rgba(168,85,247,.18);color:var(--ink);font-weight:700}

.menu-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;
  background:rgba(255,255,255,.06);
  border:1px solid var(--line);
  border-radius:10px;
  cursor:pointer;
  font-size:18px;color:var(--ink);
  transition:.2s;
}
.menu-toggle:hover{background:rgba(168,85,247,.18)}

.header-cta{
  display:none;
  background:var(--grad);color:#fff;
  padding:10px 18px;border-radius:24px;
  font-weight:700;font-size:14px;
  box-shadow:var(--shadow-md);
  transition:.2s;
}
.header-cta:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}

/* Mobile menu (open) */
body.menu-open .main-nav ul{
  display:flex;flex-direction:column;gap:0;
  position:absolute;top:100%;left:0;right:0;
  background:rgba(13,10,31,.96);
  -webkit-backdrop-filter: blur(16px);backdrop-filter: blur(16px);
  border-bottom:1px solid var(--line);
  padding:6px 0;
  box-shadow:0 16px 48px rgba(0,0,0,.4);
}
body.menu-open .main-nav ul li{padding:0 18px}
body.menu-open .main-nav ul li a{display:block;padding:14px 16px;border-radius:8px;border-bottom:1px solid rgba(255,255,255,.05)}
body.menu-open .main-nav ul li:last-child a{border-bottom:none}

/* ============== HERO ============== */
.hero{padding:36px 0 28px;position:relative}
.hero-grid{display:grid;grid-template-columns:1fr;gap:28px}
.hero-badge{
  display:inline-flex;gap:8px;align-items:center;
  padding:6px 12px;
  background:rgba(34,211,238,.12);color:var(--accent2);
  border-radius:24px;font-size:12px;font-weight:700;
  margin-bottom:16px;
}
.hero-badge::before{
  content:"";width:8px;height:8px;background:var(--accent2);border-radius:50%;
  box-shadow:0 0 12px var(--accent2);animation:pulse 1.6s infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero h1{font-size:32px;line-height:1.1;margin-bottom:14px;font-weight:900}
.hero h1 .grad{background:var(--grad);-webkit-background-clip:text;-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-lead{font-size:16px;color:var(--muted);margin:0 0 22px;line-height:1.65}

.btn-row{display:flex;gap:10px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:14px 22px;
  border:1px solid transparent;border-radius:24px;
  font-weight:700;font-size:15px;
  cursor:pointer;transition:.2s;
  text-align:center;min-height:48px;line-height:1.2;
}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--shadow-md)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}
.btn-secondary{background:rgba(255,255,255,.06);color:var(--ink);border-color:var(--line)}
.btn-secondary:hover{background:rgba(168,85,247,.15);border-color:var(--accent)}
.btn-block{display:block;width:100%;margin-top:14px}

.stats{
  margin-top:32px;
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px 12px;
}
.stat .n{font-size:28px;font-weight:900;line-height:1;background:var(--grad);-webkit-background-clip:text;-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .l{font-size:12px;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.06em;font-weight:700}

/* Hero side card */
.hero-card{
  background:rgba(255,255,255,.04);
  -webkit-backdrop-filter: blur(16px);backdrop-filter: blur(16px);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px;
  box-shadow:var(--shadow-md);
}
.hc-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.hc-head .t{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-weight:700}
.hc-head .live{display:inline-flex;gap:6px;align-items:center;font-size:11px;color:#86efac;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.hc-head .live::before{content:"";width:7px;height:7px;background:#86efac;border-radius:50%;box-shadow:0 0 8px #86efac;animation:pulse 1.6s infinite}
.hero-card h3{font-size:17px;margin:0 0 12px;font-weight:700}
.hc-ph{
  display:block;font-size:22px;font-weight:800;
  padding:10px 0;border-bottom:1px solid var(--line);
  background:var(--grad);-webkit-background-clip:text;-webkit-background-clip:text;background-clip:text;color:transparent;
  word-break:break-all;
}
.hc-ph:last-of-type{border-bottom:none}
.hc-ph:hover{filter:brightness(1.15)}
.hc-meta{margin:12px 0 0;font-size:13px;color:var(--muted)}

/* ============== SERVICES GRID ============== */
.services{padding:36px 0;border-top:1px solid var(--line)}
.services h2{font-size:28px;font-weight:900;margin:0 0 8px;letter-spacing:-.02em}
.services .lead{color:var(--muted);font-size:15px;margin:0 0 24px}
.grid{display:grid;gap:14px}
.svc-grid{grid-template-columns:1fr}
.card{
  display:block;color:inherit;
  padding:22px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
  border-radius:var(--radius);
  transition:.25s;
}
.card:hover{transform:translateY(-2px);background:rgba(255,255,255,.06);border-color:var(--accent)}
.card .ico{
  width:46px;height:46px;border-radius:14px;
  display:grid;place-items:center;
  font-size:22px;
  background:linear-gradient(135deg,rgba(168,85,247,.22),rgba(34,211,238,.18));
  margin-bottom:14px;
}
.card h3{font-size:17px;margin:0 0 6px;font-weight:800}
.card p{margin:0 0 10px;color:var(--muted);font-size:14px}
.card .more{font-size:13px;font-weight:700;color:var(--accent3)}

/* ============== WHY-US + CONTACT BLOCK ============== */
.contact-section{padding:36px 0;border-top:1px solid var(--line)}
.contact-grid{display:grid;grid-template-columns:1fr;gap:24px;align-items:start}
.contact-section h2{font-size:28px;margin:0 0 12px;letter-spacing:-.02em;font-weight:900}
.contact-section .muted{font-size:15px;margin:0 0 22px}
.features{list-style:none;margin:0;padding:0}
.features li{padding:12px 0;border-bottom:1px solid var(--line);display:flex;gap:12px;align-items:flex-start}
.features li:last-child{border-bottom:none}
.features .dot{
  width:24px;height:24px;flex-shrink:0;margin-top:1px;
  background:var(--grad);color:#fff;border-radius:50%;
  display:grid;place-items:center;font-size:12px;font-weight:800;
}
.features b{display:block;font-size:14px;margin-bottom:2px;color:var(--ink)}
.features li>span:last-child>span{font-size:13px;color:var(--muted);display:block;line-height:1.5}

.contact-card{
  background:linear-gradient(135deg,rgba(168,85,247,.22),rgba(34,211,238,.16));
  border:1px solid rgba(168,85,247,.3);
  border-radius:var(--radius-lg);
  padding:28px 22px;
  position:relative;overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.contact-card::before{content:"";position:absolute;width:200px;height:200px;background:radial-gradient(circle,rgba(244,114,182,.3),transparent 60%);top:-80px;right:-80px;filter:blur(20px)}
.cc-label{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent3);font-weight:700;margin-bottom:8px;position:relative}
.contact-card h3{font-size:22px;margin:0 0 18px;color:#fff;font-weight:900;position:relative}
.cc-ph{
  display:block;font-size:24px;font-weight:900;
  color:#fff;padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,.18);
  word-break:break-all;
  position:relative;
}
.cc-ph:last-of-type{border-bottom:none}
.cc-ph:hover{color:#fff;filter:brightness(1.15)}
.cc-meta{margin-top:18px;font-size:13px;color:rgba(255,255,255,.92);line-height:1.8;position:relative}

/* ============== INNER PAGE HEAD ============== */
.page-head{padding:28px 0 16px;border-bottom:1px solid var(--line)}
.page-head h1{font-size:26px;margin:0;line-height:1.2}
.crumbs{font-size:12px;color:var(--muted);margin-bottom:10px}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--accent3)}
.crumbs .sep{margin:0 6px;color:rgba(255,255,255,.25)}

/* ============== ARTICLE + SIDEBAR ============== */
.page-body{padding:24px 0 36px}
.article-grid{display:grid;grid-template-columns:1fr;gap:22px;align-items:start}
.article{
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px 18px;
  font-size:15px;
  letter-spacing:-.005em;
}
/* Override Joomla legacy inline justify/font-family/font-size that breaks mobile layout */
.article p[style],.article h2[style],.article h3[style],.article span[style]{
  text-align:left !important;
  font-family:inherit !important;
  font-size:inherit !important;
  line-height:inherit !important;
  letter-spacing:normal !important;
}
.article h2{font-size:18px;margin:22px 0 10px;color:var(--ink);font-weight:800;line-height:1.3;letter-spacing:-.01em}
.article h2:first-child{margin-top:0}
.article h2 strong{background:var(--grad);-webkit-background-clip:text;-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:inherit}
.article h3{font-size:16px;margin:18px 0 10px;font-weight:800}
.article p{margin:0 0 14px;line-height:1.65;color:rgba(240,234,253,.92);text-align:left;-webkit-hyphens: auto;hyphens: auto;-webkit-hyphens:auto;word-break:break-word;overflow-wrap:break-word}
.article strong,.article b{color:var(--ink);font-weight:700}
.article a{color:var(--accent3);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.article a:hover{color:var(--accent2)}
.article ul,.article ol{padding-left:22px;margin:0 0 14px}
.article li{margin-bottom:6px}
.article blockquote{
  border-left:3px solid var(--accent);
  background:rgba(168,85,247,.08);
  padding:14px 18px;margin:18px 0;
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
}
.article blockquote p:last-child{margin-bottom:0}
/* Price table — desktop: clean rows with nowrap price column */
.article table{
  width:100%;
  border-collapse:separate;border-spacing:0;
  margin:18px 0;font-size:14px;
  border:1px solid var(--line);
  border-radius:12px;
  overflow:hidden;
  background:rgba(13,10,31,.45);
}
.article table th,
.article table td{
  padding:12px 14px;
  border:none;
  border-bottom:1px solid var(--line);
  vertical-align:middle;
  text-align:left;
  color:var(--ink);
  line-height:1.45;
}
.article table tbody tr:last-child td,
.article table tfoot tr:last-child td{border-bottom:none}
.article table th{background:rgba(168,85,247,.20);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:12px}
.article table tbody tr{transition:background .15s}
.article table tbody tr:hover td{background:rgba(168,85,247,.06)}
.article table tbody tr:nth-child(even) td{background:rgba(255,255,255,.025)}
.article table tbody tr:nth-child(even):hover td{background:rgba(168,85,247,.08)}
.article table td:first-child{font-weight:500}
.article table td:last-child{
  text-align:right;
  white-space:nowrap;
  width:1%;            /* shrink to content */
  font-weight:800;
  color:var(--accent3);
  font-size:15px;
  letter-spacing:-.01em;
}
.article table tfoot td{
  background:rgba(244,114,182,.08) !important;
  font-style:italic;font-size:12px;
  color:var(--muted);
  text-align:right;
}

/* Price table — mobile: card-style rows */
@media (max-width:700px){
  .article table{display:block;background:none;border:none;border-radius:0;font-size:14px;margin:14px 0}
  .article table thead{display:none}
  .article table tbody,.article table tfoot{display:block}
  .article table tr{
    display:flex;justify-content:space-between;align-items:flex-start;
    gap:12px;
    padding:12px 14px;
    background:rgba(255,255,255,.03);
    border:1px solid var(--line);
    border-radius:10px;
    margin-bottom:6px;
    transition:.15s;
  }
  .article table tbody tr:hover{background:rgba(168,85,247,.07);border-color:rgba(168,85,247,.3)}
  .article table tr td{
    border:none !important;
    padding:0 !important;
    background:none !important;
  }
  .article table td:first-child{
    flex:1;min-width:0;
    font-size:13.5px;line-height:1.45;
    font-weight:500;
  }
  .article table td:last-child{
    flex-shrink:0;
    width:auto;
    text-align:right;
    color:var(--accent3);
    font-weight:800;
    font-size:15px;
    white-space:nowrap;
  }
  .article table tfoot tr{
    background:rgba(244,114,182,.06);
    border-color:rgba(244,114,182,.2);
    flex-direction:column;
    align-items:flex-end;
  }
  .article table tfoot td{
    text-align:right !important;
    font-size:11.5px;
    color:var(--muted);
    font-style:italic;
  }
}
.article .phones{
  text-align:center;margin:24px 0 0;padding:22px;
  background:linear-gradient(135deg,rgba(168,85,247,.25),rgba(244,114,182,.18));
  border:1px solid rgba(168,85,247,.3);
  border-radius:var(--radius);
}
.article .phones h2{margin:6px 0;font-size:24px;font-weight:900;background:var(--grad-2);-webkit-background-clip:text;-webkit-background-clip:text;background-clip:text;color:transparent}
.article .phones a{color:#fff;text-decoration:none;font-weight:900;background:var(--grad-2);-webkit-background-clip:text;-webkit-background-clip:text;background-clip:text;color:transparent}
.article img{margin:12px 0;border-radius:var(--radius-sm)}

/* ============== CONTACT PAGE ============== */
.contact-page{display:grid;grid-template-columns:1fr;gap:18px}
.contact-info{display:grid;grid-template-columns:1fr;gap:14px}
.ci-card{
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px 20px;
  position:relative;
  transition:.2s;
}
.ci-card:hover{background:rgba(168,85,247,.06);border-color:rgba(168,85,247,.3);transform:translateY(-1px)}
.ci-icon{
  width:46px;height:46px;border-radius:14px;
  background:linear-gradient(135deg,rgba(168,85,247,.22),rgba(34,211,238,.18));
  display:grid;place-items:center;
  font-size:22px;margin-bottom:14px;
}
.ci-label{font-size:11px;color:var(--accent3);text-transform:uppercase;letter-spacing:.12em;font-weight:700;margin-bottom:8px}
.ci-value{margin:0 0 6px;font-size:17px;font-weight:700;color:var(--ink);word-break:break-word}
.ci-phone{
  display:block;font-size:22px;font-weight:800;
  padding:6px 0;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  -webkit-text-fill-color:transparent;
}
.ci-phone+.ci-phone{border-top:1px solid var(--line);margin-top:6px;padding-top:10px}
.ci-phone:hover{filter:brightness(1.15)}
a.ci-value{color:var(--accent2);text-decoration:none;font-size:16px;font-weight:700;display:inline-block;word-break:break-all}
a.ci-value:hover{color:var(--accent3)}
.ci-note{margin:8px 0 0;font-size:13px;color:var(--muted);line-height:1.5}
.ci-hours .ci-value{font-size:32px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;font-weight:900;letter-spacing:-.02em}

.contact-map{
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  position:relative;
}
.contact-map iframe{
  width:100%;height:340px;display:block;border:0;
  filter:invert(.92) hue-rotate(180deg);
}
.map-link{
  display:block;text-align:center;padding:12px;font-size:14px;font-weight:700;
  color:var(--accent3);border-top:1px solid var(--line);
  background:rgba(13,10,31,.5);
}
.map-link:hover{color:var(--accent2);background:rgba(168,85,247,.08)}

.contact-cta{
  text-align:center;padding:32px 20px;
  background:linear-gradient(135deg,rgba(168,85,247,.18),rgba(34,211,238,.14));
  border:1px solid rgba(168,85,247,.3);
  border-radius:var(--radius-lg);
  position:relative;overflow:hidden;
}
.contact-cta::before{content:"";position:absolute;width:280px;height:280px;background:radial-gradient(circle,rgba(244,114,182,.25),transparent 60%);top:-100px;right:-80px;filter:blur(20px)}
.contact-cta h2{font-size:22px;margin:0 0 10px;font-weight:900;letter-spacing:-.01em;color:#fff;position:relative}
.contact-cta p{margin:0 auto 22px;max-width:520px;color:rgba(240,234,253,.92);font-size:15px;position:relative}
.contact-cta .btn{position:relative;font-size:16px;padding:16px 32px}

@media (min-width:600px){
  .contact-info{grid-template-columns:1fr 1fr}
}
@media (min-width:900px){
  .contact-page{grid-template-columns:1fr 1.1fr;gap:28px;align-items:start}
  .contact-info{grid-template-columns:1fr 1fr}
  .contact-map{position:sticky;top:90px;align-self:start}
  .contact-map iframe{height:480px}
  .contact-cta{grid-column:1/-1;padding:40px 32px}
  .contact-cta h2{font-size:30px}
}

/* Sidebar (mobile = goes after content) */
.aside{position:static;display:flex;flex-direction:column;gap:14px}
.aside-card{
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:20px;
}
.aside-call{
  background:linear-gradient(135deg,rgba(168,85,247,.25),rgba(34,211,238,.18));
  border:1px solid rgba(168,85,247,.3);
  position:relative;overflow:hidden;
}
.aside-call::before{content:"";position:absolute;width:160px;height:160px;background:radial-gradient(circle,rgba(244,114,182,.25),transparent 60%);top:-60px;right:-60px;filter:blur(20px)}
.ac-label{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent3);font-weight:700;margin-bottom:8px;position:relative}
.ac-ph{
  display:block;font-size:22px;font-weight:900;
  color:#fff;padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,.2);
  word-break:break-all;position:relative;
}
.ac-ph:last-of-type{border-bottom:none}
.aside-call .muted{color:rgba(240,234,253,.85);margin:12px 0 0;font-size:12px;position:relative}
.aside-call .btn-primary{background:#fff;color:var(--accent);box-shadow:0 8px 24px rgba(0,0,0,.18);position:relative}
.aside-call .btn-primary:hover{background:#f3f4f6}
.aside-related h4{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:0 0 12px;font-weight:700}
.aside-related ul{list-style:none;padding:0;margin:0}
.aside-related li{padding:8px 0;border-bottom:1px solid var(--line);font-size:14px}
.aside-related li:last-child{border-bottom:none}
.aside-related a:hover{color:var(--accent3)}

/* ============== FOOTER ============== */
.site-footer{
  padding:36px 0 80px;
  background:rgba(0,0,0,.4);
  border-top:1px solid var(--line);
  margin-top:0;
}
.footer-grid{
  display:grid;grid-template-columns:1fr;gap:28px;
  padding-bottom:24px;border-bottom:1px solid var(--line);
}
.site-footer h4{font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:var(--accent3);margin:0 0 14px;font-weight:700}
.site-footer .muted{color:var(--muted);font-size:13.5px;line-height:1.7}
.site-footer .footer-list{list-style:none;padding:0;margin:0;font-size:14px;line-height:2}
.site-footer .footer-list a{color:var(--ink)}
.site-footer .footer-list a:hover{color:var(--accent3)}
.site-footer .footer-phone{font-size:18px;font-weight:900;color:#fff;margin:4px 0;background:var(--grad-2);-webkit-background-clip:text;-webkit-background-clip:text;background-clip:text;color:transparent}
.site-footer .footer-phone a{color:transparent;-webkit-text-fill-color:transparent;background:inherit}
.site-footer a:hover{color:var(--accent3)}
.footer-bottom{padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--muted)}

/* ============== STICKY MOBILE CTA BAR ============== */
.mobile-cta-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:100;
  background:rgba(13,10,31,.96);
  -webkit-backdrop-filter: blur(16px);backdrop-filter: blur(16px);
  border-top:1px solid var(--line);
  padding:8px 12px;
  display:flex;gap:8px;align-items:center;
  box-shadow:0 -8px 32px rgba(0,0,0,.4);
}
.mobile-cta-bar .ph{
  flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 12px;
  background:var(--grad);color:#fff;
  border-radius:24px;font-weight:800;font-size:15px;
  box-shadow:var(--shadow-md);
  min-height:48px;
}
.mobile-cta-bar .ph2{
  width:48px;height:48px;flex-shrink:0;
  display:grid;place-items:center;
  background:rgba(255,255,255,.08);border:1px solid var(--line);
  border-radius:50%;font-size:20px;color:var(--accent2);
}

/* ============== TABLETS ============== */
@media (min-width:600px){
  .container{padding:0 24px}
  body{font-size:16px}
  .hero{padding:48px 0 36px}
  .hero h1{font-size:40px}
  .hero-lead{font-size:17px}
  .stats{grid-template-columns:repeat(4,1fr);gap:24px}
  .stat .n{font-size:34px}
  .svc-grid{grid-template-columns:1fr 1fr}
  .services h2,.contact-section h2{font-size:32px}
  .article{padding:32px}
  .page-head h1{font-size:32px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}

/* ============== DESKTOP ============== */
@media (min-width:900px){
  .container{padding:0 32px;max-width:1240px}
  /* No mobile bar on desktop */
  .mobile-cta-bar{display:none}
  .site-footer{padding-bottom:36px}
  body{font-size:16px;line-height:1.6}
  .hero{padding:80px 0 60px}
  .hero-grid{grid-template-columns:1.4fr 1fr;gap:48px;align-items:center}
  .hero-badge{font-size:13px}
  .hero h1{font-size:54px}
  .hero-lead{font-size:18px}
  .hero-card{padding:28px}
  .hero-card h3{font-size:19px}
  .hc-ph{font-size:28px}
  .stat .n{font-size:40px}
  .stat .l{font-size:13px;letter-spacing:.08em}

  .menu-toggle{display:none}
  .main-nav ul{display:flex !important;position:static;flex-direction:row;background:none;-webkit-backdrop-filter: none;backdrop-filter: none;padding:0;border:none;box-shadow:none;gap:8px}
  .main-nav ul li{padding:0}
  .main-nav ul li a{display:inline-block;padding:8px 14px;border:none;border-radius:20px}
  .header-cta{display:inline-flex;align-items:center;gap:6px}

  .services{padding:80px 0}
  .services h2{font-size:36px}
  .svc-grid{grid-template-columns:repeat(4,1fr);gap:20px}
  .grid{gap:20px}

  .contact-section{padding:80px 0}
  .contact-section h2{font-size:42px}
  .contact-grid{grid-template-columns:1fr 1.1fr;gap:48px;align-items:center}
  .contact-card{padding:48px}
  .contact-card h3{font-size:28px}
  .cc-ph{font-size:32px}

  .page-head{padding:48px 0 28px}
  .page-head h1{font-size:42px}
  .page-body{padding:56px 0 80px}
  .article-grid{grid-template-columns:1fr 320px;gap:48px}
  .article{padding:40px;font-size:17px}
  .article h2{font-size:22px}
  .article p{line-height:1.75}
  .article table{display:table;font-size:15px}
  .aside{position:-webkit-sticky;position:sticky;top:84px;display:block}
  .aside-card{margin-bottom:18px}

  .site-footer{padding:60px 0 24px}
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px}
}

/* ============== BIG DESKTOP ============== */
@media (min-width:1200px){
  .hero h1{font-size:60px}
}

/* ============== ACCESSIBILITY / MOTION ============== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
}

/* Focus states (keyboard / accessibility) */
a:focus-visible,button:focus-visible,.btn:focus-visible{outline:2px solid var(--accent2);outline-offset:3px;border-radius:6px}

/* iOS Safari: tel: link colors */
a[href^="tel:"]{-webkit-text-fill-color:inherit}

/* ============== PHONE MASK ============== */
.ph-mask{
  display:inline-flex;align-items:baseline;gap:.32em;
  font-variant-numeric:tabular-nums;
  font-feature-settings:'tnum' 1, 'lnum' 1;
  letter-spacing:.01em;
  white-space:nowrap;
}
.ph-cc{font-weight:600;opacity:.65;font-size:.82em;letter-spacing:.04em}
.ph-op{
  font-weight:800;
  padding:0 .22em;
  border-radius:6px;
  background:rgba(168,85,247,.18);
  color:var(--accent3);
}
.ph-num{font-weight:700;letter-spacing:.04em}

/* On gradient surfaces (contact-card, hero-card, sidebar-call) — kill gradient text + use white */
.cc-ph,.hc-ph,.ac-ph,.ci-phone{
  background:none !important;
  -webkit-text-fill-color:initial !important;
  color:#fff !important;
}
.cc-ph .ph-cc,.hc-ph .ph-cc,.ac-ph .ph-cc,.ci-phone .ph-cc{opacity:.7;color:rgba(255,255,255,.85)}
.cc-ph .ph-op,.hc-ph .ph-op,.ac-ph .ph-op,.ci-phone .ph-op{
  background:rgba(255,255,255,.18);
  color:#fff;
  -webkit-text-fill-color:#fff;
}
.cc-ph .ph-num,.hc-ph .ph-num,.ac-ph .ph-num,.ci-phone .ph-num{color:#fff;-webkit-text-fill-color:#fff}

/* Footer phone mask: keep gradient, but op chip transparent */
.footer-phone .ph-mask{background:var(--grad-2);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent}
.footer-phone .ph-op{background:transparent;color:inherit;padding:0}
.footer-phone .ph-cc{opacity:.55}

/* Mobile bottom CTA bar phone */
.mobile-cta-bar .ph .ph-mask{gap:.25em}
.mobile-cta-bar .ph .ph-op{background:rgba(255,255,255,.20);color:#fff;-webkit-text-fill-color:#fff}

/* Article phones block */
.article .phones .ph-mask{background:var(--grad-2);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent}
.article .phones .ph-op{background:transparent;color:inherit;padding:0}

/* Selection */
::selection{background:var(--accent);color:#fff}
