/* ============================================================
   SkaleWell — global stylesheet
   Bold editorial performance-marketing agency
   ============================================================ */

/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Manrope:wght@400;500;600;700;800&display=swap');

/* ---------- Tokens ---------- */
:root{
  /* brand */
  --blue:        #1b5cff;
  --blue-bright: #2d7bff;
  --blue-deep:   #0b3bd6;
  --blue-soft:   #e9efff;
  --blue-glow:   rgba(27,92,255,.35);

  --ink:    #070c1a;   /* near-black navy */
  --navy:   #0b1430;   /* dark surface */
  --navy-2: #111d44;   /* raised dark surface */

  --paper:  #ffffff;
  --bg:     #f5f6fb;   /* light page bg */
  --bg-2:   #eef0f8;

  --text:        #0a1124;
  --text-soft:   #4a546b;
  --text-faint:  #8a93a8;
  --on-dark:     #ffffff;
  --on-dark-soft:#aeb9d6;
  --on-dark-faint:#6b76a0;

  --line:      rgba(10,17,36,.10);
  --line-dark: rgba(255,255,255,.12);

  /* type */
  --display: 'Space Grotesk', 'Manrope', system-ui, sans-serif; /* @kind font */
  --body:    'Manrope', system-ui, sans-serif; /* @kind font */

  /* spacing / radius */
  --r-sm: 8px;
  --r:    14px;
  --r-lg: 22px;
  --r-xl: 32px;

  --shadow:    0 18px 50px -24px rgba(11,20,48,.35);
  --shadow-lg: 0 40px 90px -40px rgba(11,20,48,.5);

  --ease: cubic-bezier(.22,.61,.36,1); /* @kind other */
  --gut: clamp(20px, 5vw, 84px); /* @kind spacing */
  --maxw: 1320px;
}

/* ---------- Reset ---------- */
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  font-weight:450;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
ul{ list-style:none; }
::selection{ background:var(--blue); color:#fff; }

/* ---------- Layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
.section{ padding-block:clamp(64px,9vw,140px); }
.section--tight{ padding-block:clamp(48px,6vw,90px); }

/* ---------- Type ---------- */
h1,h2,h3,h4{ font-family:var(--display); font-weight:700; line-height:1.02; letter-spacing:-.02em; }
.display{
  font-family:var(--display); font-weight:700;
  font-size:clamp(2.7rem,8vw,6.6rem);
  line-height:.96; letter-spacing:-.035em;
}
.h-xl{ font-size:clamp(2.1rem,5vw,4rem); line-height:1; letter-spacing:-.03em; }
.h-lg{ font-size:clamp(1.7rem,3.4vw,2.8rem); letter-spacing:-.025em; }
.h-md{ font-size:clamp(1.3rem,2.2vw,1.7rem); letter-spacing:-.02em; line-height:1.1; }
.lead{ font-size:clamp(1.08rem,1.5vw,1.35rem); color:var(--text-soft); font-weight:500; line-height:1.5; }
.eyebrow{
  font-family:var(--display); font-weight:600; font-size:.8rem;
  letter-spacing:.18em; text-transform:uppercase; color:var(--blue);
  display:inline-flex; align-items:center; gap:.55em;
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--blue); display:inline-block; }
.eyebrow.on-dark{ color:var(--blue-bright); }
.eyebrow.center::before{ display:none; }
.grad{ background:linear-gradient(105deg,var(--blue-bright),var(--blue-deep)); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--display); font-weight:600; font-size:.98rem;
  padding:.95em 1.5em; border-radius:100px;
  transition:transform .35s var(--ease), background .3s, color .3s, box-shadow .3s;
  white-space:nowrap; line-height:1;
}
.btn svg{ width:1.05em; height:1.05em; transition:transform .35s var(--ease); }
.btn:hover svg{ transform:translateX(4px); }
.btn--primary{ background:var(--blue); color:#fff; box-shadow:0 10px 30px -10px var(--blue-glow); }
.btn--primary:hover{ background:var(--blue-deep); transform:translateY(-2px); box-shadow:0 16px 40px -12px var(--blue-glow); }
.btn--dark{ background:var(--ink); color:#fff; }
.btn--dark:hover{ background:var(--navy-2); transform:translateY(-2px); }
.btn--ghost{ background:transparent; color:var(--text); box-shadow:inset 0 0 0 1.5px var(--line); }
.btn--ghost:hover{ box-shadow:inset 0 0 0 1.5px var(--ink); transform:translateY(-2px); }
.btn--ghost.on-dark{ color:#fff; box-shadow:inset 0 0 0 1.5px var(--line-dark); }
.btn--ghost.on-dark:hover{ box-shadow:inset 0 0 0 1.5px #fff; }
.btn--white{ background:#fff; color:var(--ink); }
.btn--white:hover{ transform:translateY(-2px); box-shadow:0 16px 40px -16px rgba(0,0,0,.4); }
.btn--lg{ padding:1.15em 1.9em; font-size:1.05rem; }

.link-arrow{ display:inline-flex; align-items:center; gap:.5em; font-family:var(--display); font-weight:600; color:var(--blue); }
.link-arrow svg{ width:1em; height:1em; transition:transform .3s var(--ease); }
.link-arrow:hover svg{ transform:translate(3px,-3px); }

/* ---------- Header ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  padding-block:16px;
  background:#fff; color:var(--ink);
  box-shadow:0 1px 0 var(--line);
  transition:background .4s, color .4s, padding .4s, box-shadow .4s;
}
.site-header.scrolled{
  box-shadow:0 6px 24px -12px rgba(7,12,26,.22), 0 1px 0 var(--line);
  padding-block:12px;
}
.site-header.on-dark-hero:not(.scrolled){ background:var(--ink); color:#fff; box-shadow:none; }
.nav{ display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:nowrap; }
.brand{ display:flex; align-items:center; gap:11px; font-family:var(--display); font-weight:700; font-size:1.32rem; letter-spacing:-.02em; flex:0 0 auto; }
.brand img{ width:34px; height:auto; }
.brand .b-skale{ color:var(--blue); }
.brand .b-well{ color:currentColor; }
.site-header:not(.scrolled).on-dark-hero .brand .b-well{ color:#fff; }
.site-header.scrolled .brand .b-well, body:not(.dark-hero) .brand .b-well{ color:var(--ink); }

.nav-links{ display:flex; align-items:center; gap:6px; flex:0 1 auto; min-width:0; }
.nav-links a{
  font-family:var(--display); font-weight:500; font-size:.96rem;
  padding:.5em .85em; border-radius:100px; position:relative;
  transition:background .25s, color .25s;
}
.nav-links a:hover{ background:rgba(127,140,180,.14); }
.nav-links a.active{ color:var(--blue); }
.nav-right{ display:flex; align-items:center; gap:14px; flex:0 0 auto; }

.burger{ display:none; width:44px; height:44px; border-radius:50%; align-items:center; justify-content:center; }
.burger span{ display:block; width:20px; height:2px; background:currentColor; position:relative; transition:.3s; }
.burger span::before,.burger span::after{ content:""; position:absolute; left:0; width:20px; height:2px; background:currentColor; transition:.3s; }
.burger span::before{ top:-6px; } .burger span::after{ top:6px; }
body.menu-open .burger span{ background:transparent; }
body.menu-open .burger span::before{ top:0; transform:rotate(45deg); }
body.menu-open .burger span::after{ top:0; transform:rotate(-45deg); }

.mobile-menu{
  position:fixed; inset:0; z-index:99; background:var(--ink); color:#fff;
  display:flex; flex-direction:column; justify-content:center; padding:var(--gut);
  transform:translateY(-100%); transition:transform .55s var(--ease), visibility .55s; pointer-events:none; visibility:hidden;
}
body.menu-open .mobile-menu{ transform:translateY(0); pointer-events:auto; visibility:visible; }
.mobile-menu a{ font-family:var(--display); font-weight:600; font-size:clamp(2rem,9vw,3.4rem); padding:.18em 0; letter-spacing:-.03em; opacity:.55; transition:opacity .3s; }
.mobile-menu a:hover{ opacity:1; color:var(--blue-bright); }
.mobile-menu .mm-foot{ margin-top:40px; display:flex; gap:18px; flex-wrap:wrap; }
.mobile-menu .mm-foot a{ font-size:.95rem; opacity:.7; }

/* ---------- Hero (dark) ---------- */
.hero{
  position:relative; background:var(--ink); color:#fff; overflow:hidden;
  padding-top:clamp(140px,18vh,200px); padding-bottom:clamp(70px,9vw,120px);
}
.hero__glow{ position:absolute; border-radius:50%; filter:blur(90px); opacity:.5; pointer-events:none; }
.hero__glow.a{ width:560px; height:560px; background:var(--blue); top:-180px; right:-120px; }
.hero__glow.b{ width:420px; height:420px; background:var(--blue-deep); bottom:-200px; left:-100px; opacity:.4; }
.hero__grid{ position:absolute; inset:0; background-image:linear-gradient(var(--line-dark) 1px,transparent 1px),linear-gradient(90deg,var(--line-dark) 1px,transparent 1px); background-size:64px 64px; mask-image:radial-gradient(ellipse 80% 70% at 60% 0%,#000,transparent 75%); opacity:.5; }
.hero__cursor{ position:absolute; top:0; left:0; width:420px; height:420px; margin:-210px 0 0 -210px; border-radius:50%; pointer-events:none; z-index:1; background:radial-gradient(circle, rgba(45,123,255,.55) 0%, rgba(27,92,255,.28) 36%, transparent 68%); filter:blur(26px); opacity:0; transition:opacity .5s var(--ease); mix-blend-mode:screen; will-change:transform; }
.hero.cursor-on .hero__cursor{ opacity:1; }
@media (hover:none){ .hero__cursor{ display:none; } }

/* ---------- Marquee ---------- */
.marquee{ overflow:hidden; user-select:none; border-block:1px solid var(--line); padding-block:0; }
.marquee.on-dark{ border-color:var(--line-dark); }
.marquee__track{ display:flex; gap:0; width:max-content; animation:marq 32s linear infinite; }
/* marquee runs continuously (no hover pause) */
.marquee__item{ display:inline-flex; align-items:center; gap:.5em; font-family:var(--display); font-weight:600; font-size:clamp(1.4rem,3vw,2.4rem); letter-spacing:-.02em; padding:.55em clamp(20px,3vw,46px); color:var(--text); }
.marquee.on-dark .marquee__item{ color:rgba(255,255,255,.85); }
.marquee__item .dot{ width:.34em; height:.34em; border-radius:50%; background:var(--blue); }
.marquee__item.muted{ color:var(--text-faint); -webkit-text-stroke:0; }
@keyframes marq{ to{ transform:translateX(-50%); } }

/* ---------- Cards ---------- */
.card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(22px,2.4vw,34px); transition:transform .4s var(--ease), box-shadow .4s, border-color .4s; }
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }

.svc-card{ position:relative; overflow:hidden; }
.svc-card .num{ font-family:var(--display); font-weight:700; font-size:.85rem; color:var(--blue); letter-spacing:.1em; }
.svc-card .ico{ width:54px; height:54px; border-radius:14px; background:var(--blue-soft); color:var(--blue); display:grid; place-items:center; margin-bottom:20px; transition:.4s var(--ease); }
.svc-card .ico svg{ width:26px; height:26px; }
.svc-card:hover .ico{ background:var(--blue); color:#fff; transform:scale(1.06) rotate(-4deg); }
.svc-card h3{ margin-bottom:10px; }
.svc-card p{ color:var(--text-soft); font-size:1rem; }
h2[id]{ scroll-margin-top:110px; }
html{ scroll-behavior:smooth; }
a.card{ color:inherit; text-decoration:none; display:block; }
.svc-more{ display:inline-flex; align-items:center; gap:6px; margin-top:16px; font-family:var(--display); font-weight:600; font-size:.92rem; color:var(--blue); }
.svc-more svg{ width:16px; height:16px; transition:transform .3s var(--ease); }
.svc-card:hover .svc-more svg{ transform:translateX(4px); }

/* ---------- WhatsApp float ---------- */
.wa-float{ position:fixed; left:22px; bottom:22px; z-index:120; width:58px; height:58px; border-radius:50%; background:#25D366; display:grid; place-items:center; box-shadow:0 10px 30px -6px rgba(37,211,102,.55); transition:transform .3s var(--ease), box-shadow .3s; }
.wa-float:hover{ transform:scale(1.08); box-shadow:0 14px 38px -6px rgba(37,211,102,.7); }
.wa-float svg{ width:32px; height:32px; }
@media (max-width:520px){ .wa-float{ left:16px; bottom:16px; width:52px; height:52px; } .wa-float svg{ width:28px; height:28px; } }
.wa-float.is-open svg{ display:none; }
.wa-float.is-open::after{ content:""; width:20px; height:20px; background:#fff; -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.6' stroke-linecap='round'%3E%3Cpath d='M6 6l12 12M18 6L6 18'/%3E%3C/svg%3E") center/contain no-repeat; mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.6' stroke-linecap='round'%3E%3Cpath d='M6 6l12 12M18 6L6 18'/%3E%3C/svg%3E") center/contain no-repeat; }

/* ---------- Chat widget panel ---------- */
.chat-panel{
  position:fixed; left:22px; bottom:94px; z-index:121;
  width:min(370px, calc(100vw - 32px));
  height:min(540px, calc(100vh - 140px));
  background:#e7ddd3; border-radius:18px; overflow:hidden;
  display:flex; flex-direction:column;
  box-shadow:0 28px 70px -18px rgba(7,12,26,.5);
  transform:translateY(20px) scale(.94); transform-origin:0 100%;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:transform .38s var(--ease), opacity .3s ease, visibility .38s;
}
.chat-widget.open .chat-panel{ opacity:1; visibility:visible; pointer-events:auto; transform:none; }
.chat-head{ background:#0c6157; color:#fff; display:flex; align-items:center; gap:12px; padding:13px 14px; flex:0 0 auto; }
.chat-head__av{ position:relative; width:42px; height:42px; border-radius:50%; background:#fff; display:grid; place-items:center; flex:0 0 auto; padding:8px; }
.chat-head__av img{ width:100%; height:auto; }
.chat-head__dot{ position:absolute; right:0; bottom:1px; width:11px; height:11px; border-radius:50%; background:#2bd66a; border:2px solid #0c6157; }
.chat-head__meta{ display:flex; flex-direction:column; line-height:1.25; flex:1 1 auto; min-width:0; }
.chat-head__meta strong{ font-family:var(--display); font-weight:600; font-size:1.02rem; }
.chat-head__meta span{ font-size:.76rem; color:rgba(255,255,255,.78); }
.chat-close{ color:#fff; width:34px; height:34px; display:grid; place-items:center; border-radius:50%; flex:0 0 auto; opacity:.85; transition:.25s; }
.chat-close:hover{ background:rgba(255,255,255,.16); opacity:1; }
.chat-close svg{ width:20px; height:20px; }
.chat-body{ flex:1 1 auto; overflow-y:auto; padding:18px 14px 14px; display:flex; flex-direction:column; gap:9px;
  background-color:#e7ddd3;
  background-image:radial-gradient(rgba(11,20,48,.045) 1px, transparent 1px);
  background-size:22px 22px;
}
.chat-stamp{ align-self:center; background:rgba(11,20,48,.07); color:var(--text-soft); font-size:.7rem; font-weight:600; padding:4px 12px; border-radius:100px; margin-bottom:4px; }
.chat-msg{ display:flex; max-width:84%; }
.chat-msg.in{ align-self:flex-start; }
.chat-msg.out{ align-self:flex-end; }
.chat-bubble{ position:relative; padding:8px 12px 16px; border-radius:11px; font-size:.92rem; line-height:1.42; color:var(--text); box-shadow:0 1px 1.5px rgba(0,0,0,.1); overflow-wrap:anywhere; }
.chat-msg.in .chat-bubble{ background:#fff; border-top-left-radius:3px; }
.chat-msg.out .chat-bubble{ background:#d6f3c4; border-top-right-radius:3px; }
.chat-bubble em{ position:absolute; right:9px; bottom:4px; font-style:normal; font-size:.64rem; color:var(--text-faint); }
.chat-typing .chat-bubble{ padding:11px 14px; }
.chat-typing .dots{ display:inline-flex; gap:4px; }
.chat-typing .dots i{ width:7px; height:7px; border-radius:50%; background:#9aa3b5; animation:chatdot 1.1s infinite; }
.chat-typing .dots i:nth-child(2){ animation-delay:.18s; }
.chat-typing .dots i:nth-child(3){ animation-delay:.36s; }
@keyframes chatdot{ 0%,60%,100%{ opacity:.35; transform:translateY(0); } 30%{ opacity:1; transform:translateY(-4px); } }
.chat-input{ display:flex; align-items:center; gap:9px; padding:10px; background:#f4f1ec; flex:0 0 auto; }
.chat-input input{ flex:1 1 auto; min-width:0; border:none; background:#fff; border-radius:100px; padding:.72em 1.05em; font:inherit; font-size:.92rem; color:var(--text); outline:none; box-shadow:0 1px 2px rgba(0,0,0,.06); }
.chat-input input::placeholder{ color:var(--text-faint); }
.chat-input button{ flex:0 0 auto; width:44px; height:44px; border-radius:50%; background:#25D366; color:#fff; display:grid; place-items:center; transition:background .25s, transform .25s; }
.chat-input button:hover{ background:#1cbe5a; transform:scale(1.05); }
.chat-input button svg{ width:20px; height:20px; margin-left:1px; }
@media (max-width:520px){ .chat-panel{ left:16px; right:16px; width:auto; bottom:80px; height:min(72vh,480px); } }

/* ---------- Article ---------- */
.article-hero{ position:relative; background:var(--ink); color:#fff; overflow:hidden; padding-top:clamp(130px,16vh,180px); padding-bottom:clamp(40px,6vw,72px); }
.article-wrap{ width:100%; max-width:760px; margin-inline:auto; padding-inline:var(--gut); }
.article-back{ display:inline-flex; align-items:center; gap:.5em; font-family:var(--display); font-weight:600; font-size:.9rem; color:var(--on-dark-soft); margin-bottom:26px; transition:color .25s; }
.article-back:hover{ color:#fff; }
.article-back svg{ width:1em; height:1em; }
.article-cat{ font-family:var(--display); font-weight:600; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--blue-bright); }
.article-title{ font-family:var(--display); font-weight:700; font-size:clamp(2rem,4.6vw,3.4rem); line-height:1.04; letter-spacing:-.03em; margin:.45em 0 0; text-wrap:balance; }
.article-meta{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-top:24px; color:var(--on-dark-soft); font-size:.92rem; }
.article-meta .sep{ width:4px; height:4px; border-radius:50%; background:var(--on-dark-faint); }
.article-body{ padding-block:clamp(48px,6vw,84px); }
.article-body .article-lead{ font-size:clamp(1.18rem,1.8vw,1.42rem); line-height:1.55; color:var(--text); font-weight:500; margin-bottom:1.4em; }
.article-body p{ color:var(--text-soft); font-size:1.08rem; line-height:1.72; margin-bottom:1.25em; }
.article-body h2{ font-size:clamp(1.4rem,2.4vw,1.9rem); letter-spacing:-.02em; margin:1.9em 0 .6em; color:var(--text); }
.article-body h2:first-child{ margin-top:0; }
.article-body ul{ margin:0 0 1.5em; display:grid; gap:12px; }
.article-body ul li{ position:relative; padding-left:30px; color:var(--text-soft); font-size:1.06rem; line-height:1.6; }
.article-body ul li::before{ content:""; position:absolute; left:4px; top:.62em; width:8px; height:8px; border-radius:50%; background:var(--blue); }
.article-body strong{ color:var(--text); font-weight:600; }
.article-body a{ color:var(--blue); font-weight:500; box-shadow:inset 0 -1px 0 var(--blue); }
.article-pull{ margin:1.8em 0; padding:6px 0 6px 28px; border-left:3px solid var(--blue); font-family:var(--display); font-weight:600; font-size:clamp(1.25rem,2.2vw,1.7rem); line-height:1.32; letter-spacing:-.02em; color:var(--text); text-wrap:balance; }
.article-tags{ display:flex; gap:10px; flex-wrap:wrap; margin-top:clamp(36px,5vw,52px); padding-top:28px; border-top:1px solid var(--line); }

/* ---------- Stat ---------- */
.stat .n{ font-family:var(--display); font-weight:700; font-size:clamp(2.4rem,5vw,4rem); line-height:1; letter-spacing:-.04em; }
.stat .l{ color:var(--text-soft); font-weight:500; margin-top:8px; font-size:.98rem; }
.stat.on-dark .l{ color:var(--on-dark-soft); }

/* ---------- Footer ---------- */
.site-footer{ background:var(--ink); color:#fff; padding-top:clamp(44px,5vw,72px); }
.footer-cta{ text-align:center; padding-bottom:clamp(44px,5vw,72px); border-bottom:1px solid var(--line-dark); }
.footer-grid{ display:grid; grid-template-columns:1.4fr repeat(3,1fr); gap:40px; padding-block:clamp(38px,4vw,56px); }
.footer-grid h4{ font-family:var(--display); font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; color:var(--on-dark-faint); margin-bottom:18px; font-weight:600; }
.footer-grid a{ display:block; color:var(--on-dark-soft); padding-block:6px; transition:color .25s, transform .25s; }
.footer-grid a:hover{ color:#fff; transform:translateX(3px); }
.footer-bottom{ display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; padding-block:30px; border-top:1px solid var(--line-dark); color:var(--on-dark-faint); font-size:.9rem; }
.footer-bottom a:hover{ color:#fff; }
.foot-brand{ display:flex; align-items:center; gap:11px; font-family:var(--display); font-weight:700; font-size:1.4rem; margin-bottom:18px; }
.foot-brand img{ width:36px; }
.foot-brand .b-well{ color:#fff; }
.foot-brand .b-skale{ color:var(--blue-bright); }
.socials{ display:flex; gap:10px; margin-top:22px; }
.socials a{ width:42px; height:42px; border-radius:50%; display:grid; place-items:center; background:rgba(255,255,255,.07); transition:background .3s, transform .3s; }
.socials a:hover{ background:var(--blue); transform:translateY(-3px); }
.socials svg{ width:18px; height:18px; }

/* ---------- Reveal animation ---------- */
[data-reveal]{ opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal][data-delay="1"]{ transition-delay:.08s; }
[data-reveal][data-delay="2"]{ transition-delay:.16s; }
[data-reveal][data-delay="3"]{ transition-delay:.24s; }
[data-reveal][data-delay="4"]{ transition-delay:.32s; }
[data-reveal][data-delay="5"]{ transition-delay:.40s; }
.reveal-line{ display:block; overflow:hidden; padding-bottom:.14em; margin-bottom:-.14em; }
.reveal-line > span{ display:block; transform:translateY(110%); transition:transform .9s var(--ease); }
.reveal-line.in > span{ transform:none; }
@media (prefers-reduced-motion:reduce){
  *{ animation:none!important; transition:none!important; }
  [data-reveal]{ opacity:1; transform:none; }
  .reveal-line>span{ transform:none; }
}

/* ---------- Misc ---------- */
.section-dark{ background:var(--ink); color:#fff; }
.section-navy{ background:var(--navy); color:#fff; }
.tag{ display:inline-block; font-family:var(--display); font-weight:600; font-size:.78rem; letter-spacing:.05em; padding:.45em .9em; border-radius:100px; background:var(--blue-soft); color:var(--blue-deep); }
.tag.on-dark{ background:rgba(255,255,255,.1); color:#fff; }
.divider{ height:1px; background:var(--line); border:0; }
.kicker-grid{ display:grid; gap:8px; }

/* ---------- Forms ---------- */
.field{ margin-bottom:18px; }
.field label{ display:block; font-family:var(--display); font-weight:600; font-size:.85rem; margin-bottom:8px; color:var(--text); }
.field input, .field textarea, .field select{ width:100%; font:inherit; color:var(--text); background:#fff; border:1.5px solid var(--line); border-radius:var(--r); padding:.85em 1em; transition:border-color .25s, box-shadow .25s; }
.field input::placeholder, .field textarea::placeholder{ color:var(--text-faint); }
.field input:focus, .field textarea:focus, .field select:focus{ outline:none; border-color:var(--blue); box-shadow:0 0 0 4px var(--blue-soft); }
.field textarea{ resize:vertical; min-height:130px; }
.form-success{ display:none; background:var(--blue-soft); color:var(--blue-deep); border-radius:var(--r-lg); padding:30px; font-family:var(--display); font-weight:500; font-size:1.1rem; }

/* ---------- Compare table ---------- */
.compare{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); }
.compare > div{ background:#fff; padding:clamp(24px,3vw,40px); }
.compare .col-bad{ background:#f7f8fa; }
.compare h3{ display:flex; align-items:center; gap:10px; margin-bottom:22px; font-size:clamp(1.15rem,1.8vw,1.4rem); }
.compare ul{ display:grid; gap:16px; }
.compare li{ display:flex; gap:12px; color:var(--text-soft); line-height:1.45; }
.compare li b{ color:var(--text); font-weight:600; }
.cmark, .xmark{ flex:0 0 22px; width:22px; height:22px; border-radius:50%; display:grid; place-items:center; margin-top:1px; }
.cmark{ background:var(--blue); color:#fff; }
.xmark{ background:#ecdada; color:#a85b5b; }
@media (max-width:680px){ .compare{ grid-template-columns:1fr; } }

/* ---------- Blog / posts ---------- */
.post-card{ display:flex; flex-direction:column; height:100%; }
.post-card .post-cat{ font-family:var(--display); font-weight:600; font-size:.76rem; letter-spacing:.1em; text-transform:uppercase; color:var(--blue); }
.post-card h3{ margin:12px 0 10px; }
.post-card p{ color:var(--text-soft); font-size:1rem; }
.post-meta{ margin-top:auto; padding-top:20px; color:var(--text-faint); font-size:.9rem; display:flex; align-items:center; gap:8px; }
.contact-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(30px,5vw,72px); align-items:start; }
.info-row{ padding:20px 0; border-top:1px solid var(--line); }
.info-row:first-child{ border-top:0; }
.info-row .k{ font-family:var(--display); font-weight:600; font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-faint); margin-bottom:6px; }
.info-row .v{ font-size:1.08rem; color:var(--text); }
.info-row a.v:hover{ color:var(--blue); }
@media (max-width:760px){ .contact-grid{ grid-template-columns:1fr; } }

/* ---------- Google rating ---------- */
.g-rating{ display:inline-flex; align-items:center; gap:18px; background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:20px 30px; box-shadow:var(--shadow); transition:transform .35s var(--ease), box-shadow .35s; }
.g-rating:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.g-stars{ color:#fbbc04; font-size:1.25rem; letter-spacing:2px; }

/* ---------- Pricing ---------- */
.bill-switch{ display:inline-flex; align-items:center; gap:14px; margin-top:34px; font-family:var(--display); font-weight:500; color:var(--on-dark-soft); }
.bill-label em{ font-style:normal; color:var(--blue-bright); font-weight:600; }
.switch{ position:relative; display:inline-block; width:54px; height:30px; }
.switch input{ opacity:0; width:0; height:0; }
.switch .slider{ position:absolute; inset:0; background:rgba(255,255,255,.16); border-radius:100px; transition:.3s; cursor:pointer; }
.switch .slider::before{ content:""; position:absolute; height:22px; width:22px; left:4px; top:4px; background:#fff; border-radius:50%; transition:.3s var(--ease); }
.switch input:checked + .slider{ background:var(--blue); }
.switch input:checked + .slider::before{ transform:translateX(24px); }

.plan{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(26px,2.6vw,38px); display:flex; flex-direction:column; transition:transform .4s var(--ease), box-shadow .4s; position:relative; }
.plan:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.plan--feature{ background:var(--ink); color:#fff; border-color:transparent; box-shadow:var(--shadow-lg); }
.plan-badge{ position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--blue); color:#fff; font-family:var(--display); font-weight:600; font-size:.78rem; letter-spacing:.04em; padding:.5em 1.1em; border-radius:100px; white-space:nowrap; }
.plan-desc{ color:var(--text-soft); margin:16px 0 22px; min-height:48px; font-size:.98rem; }
.plan--feature .plan-desc{ color:var(--on-dark-soft); }
.plan-price{ font-family:var(--display); font-weight:700; font-size:clamp(2.6rem,4vw,3.4rem); line-height:1; letter-spacing:-.03em; display:flex; align-items:flex-start; gap:2px; }
.plan-price .cur{ font-size:.45em; margin-top:.5em; }
.plan-price .per{ font-size:.28em; font-weight:500; color:var(--text-faint); align-self:flex-end; margin-bottom:.7em; }
.plan--feature .plan-price .per{ color:var(--on-dark-faint); }
.bill-note{ font-size:.85rem; color:var(--text-faint); }
.plan-feats{ margin-top:26px; padding-top:24px; border-top:1px solid var(--line); display:grid; gap:13px; }
.plan-feats li{ position:relative; padding-left:28px; font-weight:500; color:var(--text); }
.plan-feats li::before{ content:""; position:absolute; left:0; top:3px; width:18px; height:18px; border-radius:50%; background:var(--blue-soft); }
.plan-feats li::after{ content:""; position:absolute; left:6px; top:6px; width:5px; height:9px; border-right:2px solid var(--blue); border-bottom:2px solid var(--blue); transform:rotate(45deg); }
.plan-feats--dark{ border-top-color:var(--line-dark); }
.plan-feats--dark li{ color:#fff; }
.plan-feats--dark li::before{ background:rgba(255,255,255,.12); }
.plan-feats--dark li::after{ border-color:var(--blue-bright); }

/* ---------- FAQ ---------- */
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:20px; padding:24px 0; text-align:left; font-family:var(--display); font-weight:600; font-size:clamp(1.1rem,1.7vw,1.35rem); color:var(--text); letter-spacing:-.01em; }
.faq-ico{ position:relative; flex:0 0 22px; width:22px; height:22px; }
.faq-ico::before,.faq-ico::after{ content:""; position:absolute; background:var(--blue); border-radius:2px; transition:.3s var(--ease); }
.faq-ico::before{ top:10px; left:0; width:22px; height:2px; }
.faq-ico::after{ left:10px; top:0; width:2px; height:22px; }
.faq-item.open .faq-ico::after{ transform:rotate(90deg); opacity:0; }
.faq-a{ overflow:hidden; max-height:0; transition:max-height .45s var(--ease); }
.faq-item.open .faq-a{ max-height:340px; }
.faq-a p{ padding:0 0 26px; color:var(--text-soft); max-width:62ch; }

/* service detail list + visual */
.svc-li{ position:relative; padding:14px 0 14px 30px; border-top:1px solid var(--line); font-weight:500; color:var(--text); }
.svc-li:last-child{ border-bottom:1px solid var(--line); }
ul .svc-li::before{ background:var(--blue); box-shadow:none; }
ul .svc-li::after{ border-color:#fff; }
.svc-li::before{ content:""; position:absolute; left:0; top:50%; transform:translateY(-50%); width:16px; height:16px; border-radius:50%; background:var(--blue-soft); box-shadow:inset 0 0 0 2px var(--blue); }
.svc-li::after{ content:""; position:absolute; left:5px; top:50%; transform:translateY(-50%) rotate(45deg); width:5px; height:9px; border-right:2px solid var(--blue); border-bottom:2px solid var(--blue); margin-top:-1px; }
.svc-visual{ aspect-ratio:4/3; border-radius:var(--r-xl); background:linear-gradient(150deg,var(--blue) 0%,var(--blue-deep) 100%); display:grid; place-items:center; box-shadow:var(--shadow); overflow:hidden; position:relative; }
.svc-visual::before{ content:""; position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.14) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.14) 1px,transparent 1px); background-size:38px 38px; opacity:.5; }
.svc-visual svg{ width:34%; height:34%; color:#fff; position:relative; opacity:.92; }

.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(20px,3vw,40px); }
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,30px); }
.grid-4{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(18px,2vw,26px); }
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,80px); align-items:center; }

/* ---------- Responsive ---------- */
body.menu-open{ overflow:hidden; }
@media (max-width:1024px){
  .footer-grid{ grid-template-columns:1fr 1fr; gap:34px; }
  .grid-4{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:1080px){
  .nav-links, .nav-right .btn{ display:none; }
  .burger{ display:flex; }
}
@media (max-width:860px){
  .grid-3{ grid-template-columns:1fr; }
  .grid-2{ grid-template-columns:1fr; }
  .split{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  /* when a service block stacks, keep the heading/text above its visual */
  .split .svc-visual{ order:2 !important; }
  .svc-visual{ aspect-ratio:16/10; }
}
@media (max-width:600px){
  /* long FAQ answers wrap to more lines on narrow screens — don't clip them */
  .faq-item.open .faq-a{ max-height:720px; }
}
@media (max-width:520px){
  .grid-4{ grid-template-columns:1fr 1fr; }
  .footer-grid{ grid-template-columns:1fr; gap:30px; }
  .footer-bottom{ flex-direction:column; gap:8px; }
  .socials a{ width:44px; height:44px; }
  .g-rating{ padding:18px 22px; gap:14px; }
}
@media (max-width:420px){
  /* keep large display headings from overflowing tiny viewports */
  .display{ font-size:clamp(2rem,9.5vw,2.7rem); }
  .wrap{ padding-inline:18px; }
  .btn--lg{ padding:1.05em 1.5em; font-size:1rem; }
  .hero{ padding-top:clamp(118px,16vh,150px); }
}

/* gentle hero motion on touch devices (desktop parallax is pointer-only) */
@media (hover:none) and (prefers-reduced-motion:no-preference){
  .hero__glow.a{ animation:floatGlowA 15s ease-in-out infinite; }
  .hero__glow.b{ animation:floatGlowB 19s ease-in-out infinite; }
}
@keyframes floatGlowA{ 0%,100%{ transform:translate(0,0); } 50%{ transform:translate(-26px,22px); } }
@keyframes floatGlowB{ 0%,100%{ transform:translate(0,0); } 50%{ transform:translate(22px,-20px); } }
