/* ============ HPACE — Premium Agency CSS ============ */
:root{
  --bg:#f6f6f4;
  --bg-alt:#eeeeea;
  --ink:#0c0c0c;
  --ink-2:#1a1a1a;
  --muted:#6a6a68;
  --line:rgba(12,12,12,.12);
  --accent:#0094FF;
  --card:#ffffff;
  --radius:16px;
  --radius-lg:28px;
  --max:1320px;
  --pad:clamp(20px,4vw,56px);
  --ease:cubic-bezier(.2,.7,.2,1);
}
[data-theme="dark"]{
  --bg:#0b0b0c;
  --bg-alt:#141416;
  --ink:#f4f4f2;
  --ink-2:#e6e6e2;
  --muted:#8a8a86;
  --line:rgba(244,244,242,.14);
  --card:#161618;
}
[data-theme="dark"] .hero-tag,
[data-theme="dark"] .filter-chip,
[data-theme="dark"] .sv-tags span,
[data-theme="dark"] .review-card,
[data-theme="dark"] .marquee,
[data-theme="dark"] .site-header{background:rgba(20,20,22,.6)}

/* Sections that are always dark — keep a fixed palette in both themes */
[data-theme="dark"] .about{background:#141416;color:#f4f4f2}
[data-theme="dark"] .about .about-title{color:#f4f4f2}
[data-theme="dark"] .about .about-title em,
[data-theme="dark"] .about-meta p{color:rgba(244,244,242,.6)}
[data-theme="dark"] .about .btn-ghost{color:#f4f4f2;border-color:rgba(244,244,242,.25)}
[data-theme="dark"] .about .btn-ghost:hover{background:#f4f4f2;color:#0b0b0c}

[data-theme="dark"] .cta{background:#050506;color:#f4f4f2}
[data-theme="dark"] .cta-left h2{color:#f4f4f2}
[data-theme="dark"] .cta-left p,
[data-theme="dark"] .cta-left .contacts a{color:rgba(244,244,242,.75)}
[data-theme="dark"] .cta .field input,
[data-theme="dark"] .cta .field textarea,
[data-theme="dark"] .cta .field select{color:#f4f4f2}

[data-theme="dark"] .footer{background:#050506;color:#f4f4f2}
[data-theme="dark"] .footer-huge{color:#f4f4f2}
[data-theme="dark"] .footer-col a{color:rgba(244,244,242,.75)}

[data-theme="dark"] .trends{background:#141416;color:#f4f4f2}
[data-theme="dark"] .trends-head h2{color:#f4f4f2}
[data-theme="dark"] .trends-head h2 em{color:rgba(244,244,242,.45)}
[data-theme="dark"] .trends-service h4{color:#f4f4f2}

/* Primary dark button stays light with dark text */
[data-theme="dark"] .btn-primary{background:#f4f4f2;color:#0b0b0c}
[data-theme="dark"] .btn-primary:hover{background:var(--accent);color:#fff}

/* Stat numbers in trends — force light */
[data-theme="dark"] .trend-stat .num,
[data-theme="dark"] .chart-card h3{color:#f4f4f2}

[data-theme="dark"] .case-cover{filter:brightness(.9)}
[data-theme="dark"] .map-block{filter:invert(.92) hue-rotate(180deg)}
[data-theme="dark"] .logo-img{filter:brightness(0) invert(1)}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink);
  font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--ink);color:var(--bg)}

.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}

/* ============ Typography ============ */
h1,h2,h3,h4{font-family:'Manrope','Inter',sans-serif;font-weight:700;letter-spacing:-.02em;line-height:1.05}
.display{font-size:clamp(44px,7.8vw,128px);font-weight:800;letter-spacing:-.04em;line-height:.96}
.h1{font-size:clamp(36px,5vw,72px)}
.h2{font-size:clamp(28px,3.4vw,52px)}
.h3{font-size:clamp(20px,1.6vw,26px);font-weight:600}
.eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.22em;color:var(--muted);font-weight:500}
.lead{font-size:clamp(17px,1.3vw,20px);color:var(--muted);max-width:60ch;line-height:1.55}
.mono{font-family:'JetBrains Mono','Menlo',monospace;font-size:12px;letter-spacing:.05em;text-transform:uppercase}

/* ============ Header ============ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px var(--pad);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  background:rgba(246,246,244,.72);
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease),background .3s var(--ease);
}
.site-header.scrolled{border-bottom-color:var(--line)}
.nav-wrap{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:40px}
.logo{font-family:'Manrope',sans-serif;font-weight:800;font-size:22px;letter-spacing:.02em;display:flex;align-items:center;gap:10px}
.logo-mark{width:28px;height:28px;border-radius:8px;background:var(--ink);display:grid;place-items:center;color:var(--bg);font-size:14px;font-weight:800}
.nav-links{display:flex;gap:34px;list-style:none}
.nav-links a{font-size:14px;font-weight:500;position:relative;padding:6px 0;color:var(--ink-2);transition:color .25s}
.nav-links a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--ink);transition:width .35s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-contact-links{display:flex;align-items:center;gap:14px}
a[href="https://t.me/mazaretto"]{display:inline-flex;align-items:center;line-height:0}
a[href="https://t.me/mazaretto"] svg{display:block;width:42px;height:auto}
.nav-telegram{
  font-size:13px;color:var(--muted);border-bottom:1px solid transparent;transition:.25s;white-space:nowrap;
}
.nav-email{
  font-size:13px;color:var(--muted);border-bottom:1px solid transparent;transition:.25s;white-space:nowrap;
}
.nav-telegram:hover{color:var(--ink);border-bottom-color:var(--ink)}
.nav-email:hover{color:var(--ink);border-bottom-color:var(--ink)}
.nav-cta{display:flex;align-items:center;gap:14px}
.burger{display:none;width:40px;height:40px;border:1px solid var(--line);border-radius:50%;align-items:center;justify-content:center;flex-direction:column;gap:4px}
.burger span{width:16px;height:1.5px;background:var(--ink);transition:.3s}

@media (max-width:1360px){
  .nav-wrap{gap:22px}
  .nav-links{gap:22px}
  .nav-contact-links{gap:10px}
  .nav-telegram,.nav-email{font-size:12px}
  .nav-cta .btn{padding:11px 16px;font-size:12px}
}
@media (max-width:1200px){
  .nav-email{display:none}
}
@media (max-width:1120px){
  .nav-contact-links{display:none}
}

/* ============ Buttons ============ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:100px;
  font-size:14px;font-weight:600;letter-spacing:.01em;
  transition:all .35s var(--ease);
  white-space:nowrap;
}
.btn-primary{background:var(--ink);color:var(--bg)}
.btn-primary:hover{background:var(--accent);transform:translateY(-2px)}
.btn-ghost{border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.btn-arrow{width:12px;height:12px;transition:transform .35s var(--ease)}
.btn:hover .btn-arrow{transform:translate(3px,-3px)}

/* ============ Hero ============ */
.hero{padding:160px var(--pad) 80px;position:relative;overflow:hidden}
.hero-inner{max-width:var(--max);margin:0 auto;position:relative}
.hero-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:60px;flex-wrap:wrap;gap:24px}
.hero-tag{display:inline-flex;align-items:center;gap:10px;padding:8px 16px;border:1px solid var(--line);border-radius:100px;background:rgba(255,255,255,.4)}
.hero-tag .dot{width:8px;height:8px;border-radius:50%;background:#16a34a;box-shadow:0 0 0 4px rgba(22,163,74,.18);animation:pulse 2s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 6px rgba(22,163,74,0)}}
.hero-title .line{display:block;overflow:hidden}
.hero-title .word{display:inline-block;transform:translateY(110%);transition:transform .9s var(--ease)}
.hero-title .word.show{transform:translateY(0)}
.hero-title .italic{font-style:italic;font-weight:300;color:var(--muted)}
.hero-meta{display:grid;grid-template-columns:repeat(12,1fr);gap:30px;margin-top:60px;align-items:end}
.hero-meta .lead{grid-column:span 5}
.hero-meta .cta-block{grid-column:span 4;grid-column-start:8;display:flex;flex-direction:column;gap:18px}
.hero-scroll{position:absolute;bottom:30px;right:var(--pad);display:flex;align-items:center;gap:10px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.hero-scroll .line{width:60px;height:1px;background:var(--ink);position:relative;overflow:hidden}
.hero-scroll .line::after{content:'';position:absolute;inset:0;background:var(--accent);transform-origin:left;animation:scrollLine 2.6s infinite var(--ease)}
@keyframes scrollLine{0%{transform:scaleX(0)}50%{transform:scaleX(1);transform-origin:left}50.01%{transform-origin:right}100%{transform:scaleX(0);transform-origin:right}}

/* Upwork banner */
.upwork-banner-section{padding:0 var(--pad) 36px}
.upwork-banner{
  max-width:var(--max);
  margin:0 auto;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:var(--bg-alt);
}
.upwork-banner img{width:100%;height:auto;display:block}

/* Marquee */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;overflow:hidden;background:rgba(255,255,255,.3)}
.marquee-track{display:flex;gap:60px;white-space:nowrap;animation:marquee 38s linear infinite;align-items:center}
.marquee-track span{font-family:'Manrope';font-size:clamp(22px,2.4vw,32px);font-weight:600;color:var(--ink)}
.marquee-track span:nth-child(even){color:var(--muted);font-style:italic;font-weight:300}
.marquee-dot{width:8px;height:8px;background:var(--accent);border-radius:50%;flex-shrink:0}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ============ Stats ============ */
.stats{padding:110px var(--pad)}
.stats-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:40px;border-top:1px solid var(--line);padding-top:50px}
.stat{display:flex;flex-direction:column;gap:8px}
.stat-num{font-family:'Manrope';font-size:clamp(56px,6vw,96px);font-weight:700;letter-spacing:-.04em;line-height:1}
.stat-num sup{font-size:.4em;color:var(--accent);margin-left:4px;vertical-align:top}
.stat-label{color:var(--muted);font-size:14px;max-width:180px}

/* ============ Section headers ============ */
.section{padding:130px var(--pad);position:relative}
.section-head{max-width:var(--max);margin:0 auto 70px;display:grid;grid-template-columns:auto 1fr auto;gap:40px;align-items:end}
.section-head .eyebrow-col{display:flex;align-items:center;gap:10px;white-space:nowrap}
.section-head .title-col{justify-self:start}
.section-head .meta-col{text-align:right;color:var(--muted);font-size:14px;white-space:nowrap}
.section-counter{font-family:'JetBrains Mono';font-size:11px;color:var(--muted);letter-spacing:.1em}

/* ============ Services preview ============ */
.services-list{max-width:var(--max);margin:0 auto;border-top:1px solid var(--line)}
.service-row{
  display:grid;grid-template-columns:80px 1fr 1.4fr 120px;gap:30px;
  padding:34px 0;border-bottom:1px solid var(--line);
  align-items:center;cursor:pointer;
  transition:padding .4s var(--ease);
}
.service-row:hover{padding-left:20px}
.service-row:hover .service-name{color:var(--accent)}
.service-row:hover .service-arrow{transform:rotate(-45deg) translate(6px,-6px);background:var(--ink);color:var(--bg)}
.service-num{font-family:'JetBrains Mono';font-size:13px;color:var(--muted)}
.service-name{font-family:'Manrope';font-size:clamp(24px,2.6vw,40px);font-weight:600;letter-spacing:-.02em;transition:color .35s}
.service-desc{color:var(--muted);font-size:15px;line-height:1.55}
.service-arrow{
  width:52px;height:52px;border-radius:50%;border:1px solid var(--line);
  display:grid;place-items:center;justify-self:end;
  transition:all .45s var(--ease);
  font-size:18px;
}

/* ============ About ============ */
.about{background:var(--ink);color:var(--bg);border-radius:var(--radius-lg);margin:40px var(--pad);padding:clamp(50px,8vw,120px)}
.about-inner{max-width:calc(var(--max) - 80px);margin:0 auto;display:grid;grid-template-columns:repeat(12,1fr);gap:40px}
.about .eyebrow{color:rgba(255,255,255,.5)}
.about-title{grid-column:span 8;font-family:'Manrope';font-size:clamp(32px,4vw,60px);font-weight:600;line-height:1.1;letter-spacing:-.02em}
.about-title em{font-style:italic;font-weight:300;color:#888}
.about-meta{grid-column:span 4;display:flex;flex-direction:column;gap:30px;padding-top:20px}
.about-meta p{color:rgba(255,255,255,.65);font-size:15px;line-height:1.6}
.about-meta .btn-ghost{border-color:rgba(255,255,255,.25);color:var(--bg);align-self:flex-start}
.about-meta .btn-ghost:hover{background:var(--bg);color:var(--ink)}
.about,.about-inner,.about-title,.about-meta,.about-meta p{min-width:0}
.about{overflow:hidden}

/* ============ Tech Stack ============ */
.stack-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:var(--line);border:1px solid var(--line);max-width:var(--max);margin:0 auto;border-radius:var(--radius);overflow:hidden}
.stack-item{
  aspect-ratio:1/.8;background:var(--bg);display:flex;flex-direction:column;justify-content:space-between;
  padding:24px;transition:background .35s,color .35s;cursor:default;
}
.stack-item:hover{background:var(--ink);color:var(--bg)}
.stack-num{font-family:'JetBrains Mono';font-size:11px;color:var(--muted)}
.stack-item:hover .stack-num{color:rgba(255,255,255,.5)}
.stack-name{font-family:'Manrope';font-size:clamp(18px,1.6vw,24px);font-weight:600}

/* ============ Cases ============ */
.cases-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(12,1fr);gap:30px}
.case-card{position:relative;grid-column:span 6;cursor:pointer}
.case-card.wide{grid-column:span 12}
.case-card.tall{grid-column:span 6}
.case-media{
  aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(135deg,#e7e7e3,#d6d6d2);position:relative;
  transition:transform .6s var(--ease);
}
.case-card.wide .case-media{aspect-ratio:21/9}
.case-media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.case-card:hover .case-media img{transform:scale(1.04)}
.case-tag{position:absolute;top:20px;left:20px;z-index:2;background:rgba(255,255,255,.85);backdrop-filter:blur(10px);padding:6px 12px;border-radius:100px;font-size:12px;font-weight:500}
.case-info{padding:24px 4px 0;display:flex;justify-content:space-between;align-items:flex-start;gap:20px}
.case-title{font-family:'Manrope';font-size:clamp(20px,1.8vw,28px);font-weight:600;letter-spacing:-.01em}
.case-sub{color:var(--muted);font-size:14px;margin-top:6px}
.case-arrow{width:44px;height:44px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;transition:all .4s var(--ease);flex-shrink:0}
.case-card:hover .case-arrow{background:var(--ink);color:var(--bg);border-color:var(--ink);transform:rotate(-45deg)}

/* Gradient placeholders for case media */
.grad-1{background:linear-gradient(135deg,#0f766e,#14b8a6,#5eead4)}
.grad-2{background:linear-gradient(135deg,#1e1b4b,#4338ca,#818cf8)}
.grad-3{background:linear-gradient(135deg,#7c2d12,#ea580c,#fdba74)}
.grad-4{background:linear-gradient(135deg,#18181b,#3f3f46,#a1a1aa)}
.grad-5{background:linear-gradient(135deg,#134e4a,#0d9488,#2dd4bf)}
.grad-6{background:linear-gradient(135deg,#701a75,#c026d3,#f0abfc)}

/* Cases page filters */
.filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:50px;max-width:var(--max);margin-left:auto;margin-right:auto}
.filter-chip{padding:10px 18px;border:1px solid var(--line);border-radius:100px;font-size:13px;font-weight:500;background:rgba(255,255,255,.4);transition:.3s;display:inline-flex;align-items:center;gap:8px}
.filter-chip:hover{border-color:var(--ink)}
.filter-chip.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.filter-chip .count{font-size:10px;opacity:.6;font-family:'JetBrains Mono'}

/* ============ Reviews ============ */
.reviews-slider{max-width:var(--max);margin:0 auto;overflow:hidden}
.reviews-track{display:flex;gap:24px;transition:transform .7s var(--ease)}
.review-card{
  flex:0 0 calc(33.333% - 16px);
  padding:36px;border:1px solid var(--line);border-radius:var(--radius);
  background:rgba(255,255,255,.5);
  display:flex;flex-direction:column;gap:24px;min-height:320px;
}
.review-stars{color:var(--accent);letter-spacing:2px;font-size:14px}
.review-text{font-size:17px;line-height:1.55;font-family:'Manrope';font-weight:500;letter-spacing:-.01em;flex:1}
.review-author{display:flex;align-items:center;gap:14px;padding-top:20px;border-top:1px solid var(--line)}
.review-avatar{width:44px;height:44px;border-radius:50%;background:var(--ink);color:var(--bg);display:grid;place-items:center;font-weight:600;font-size:14px}
.review-name{font-weight:600;font-size:14px}
.review-role{color:var(--muted);font-size:12px}
.slider-nav{display:flex;gap:10px;justify-content:flex-end;max-width:var(--max);margin:30px auto 0}
.slider-btn{width:48px;height:48px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;transition:.3s;background:var(--bg)}
.slider-btn:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.slider-btn:disabled{opacity:.3;cursor:not-allowed}

/* ============ Why ============ */
.why-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.why-item{background:var(--bg);padding:40px;display:flex;flex-direction:column;gap:20px;min-height:260px;transition:.3s}
.why-item:hover{background:#fff}
.why-icon{width:46px;height:46px;border-radius:12px;background:var(--ink);color:var(--bg);display:grid;place-items:center;font-size:20px}
.why-title{font-family:'Manrope';font-size:20px;font-weight:600}
.why-desc{color:var(--muted);font-size:14px;line-height:1.6}

/* ============ CTA Form ============ */
.cta{padding:130px var(--pad);background:var(--ink);color:var(--bg);margin:0}
.cta-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.cta-left h2{font-family:'Manrope';font-size:clamp(44px,5vw,84px);font-weight:600;letter-spacing:-.03em;line-height:1}
.cta-left h2 em{font-style:italic;font-weight:300;color:#666}
.cta-left p{color:rgba(255,255,255,.65);margin-top:26px;font-size:17px;max-width:440px;line-height:1.55}
.cta-left .contacts{margin-top:40px;display:flex;flex-direction:column;gap:14px;font-size:15px}
.cta-left .contacts a{border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:4px;display:inline-block;width:fit-content}
.cta-left .contacts a:hover{border-color:var(--accent);color:var(--accent)}
.form{display:flex;flex-direction:column;gap:20px}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-size:12px;text-transform:uppercase;letter-spacing:.15em;color:rgba(255,255,255,.5)}
.field input,.field textarea,.field select{
  background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.2);
  color:var(--bg);padding:12px 0;font-size:16px;font-family:inherit;
  transition:border-color .3s;resize:none;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-bottom-color:var(--accent)}
.field textarea{min-height:90px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.budget-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.chip{padding:8px 14px;border:1px solid rgba(255,255,255,.2);border-radius:100px;font-size:13px;cursor:pointer;transition:.3s}
.chip:hover,.chip.active{background:var(--bg);color:var(--ink);border-color:var(--bg)}
.form .btn-primary{background:var(--accent);color:#fff;align-self:flex-start;margin-top:14px}
.form .btn-primary:hover{background:#fff;color:var(--ink)}
.form-note{font-size:12px;color:rgba(255,255,255,.45);line-height:1.5}
.form-note a{text-decoration:underline}

/* ============ Footer ============ */
.footer{padding:80px var(--pad) 30px;background:var(--ink);color:var(--bg)}
.footer-inner{max-width:var(--max);margin:0 auto}
.footer-huge{font-family:'Manrope';font-size:clamp(80px,18vw,260px);font-weight:800;letter-spacing:-.06em;line-height:.85;margin-bottom:60px;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:50px}
.footer-col h4{font-size:12px;text-transform:uppercase;letter-spacing:.2em;color:rgba(255,255,255,.4);margin-bottom:18px;font-weight:500}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col a{font-size:14px;color:rgba(255,255,255,.8);transition:color .25s}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{display:flex;justify-content:space-between;padding-top:30px;border-top:1px solid rgba(255,255,255,.1);font-size:12px;color:rgba(255,255,255,.4);flex-wrap:wrap;gap:20px}

/* ============ Page Header (inner pages) ============ */
.page-header{padding:160px var(--pad) 80px;border-bottom:1px solid var(--line)}
.page-header-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(12,1fr);gap:30px;align-items:end}
.page-header h1{grid-column:span 8;font-family:'Manrope';font-size:clamp(44px,7vw,110px);font-weight:700;letter-spacing:-.04em;line-height:.95}
.page-header h1 em{font-style:italic;font-weight:300;color:var(--muted)}
.page-header-meta{grid-column:span 4;padding-bottom:20px;color:var(--muted);font-size:16px;line-height:1.55}
.breadcrumbs{display:flex;gap:10px;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.15em;margin-bottom:40px;grid-column:span 12}
.breadcrumbs span:not(:last-child)::after{content:'/';margin-left:10px;color:var(--line)}
.breadcrumbs .current{color:var(--ink)}
.page-header-inner,.page-header h1,.page-header-meta,.breadcrumbs{min-width:0}

/* ============ Services page ============ */
.service-block{padding:80px var(--pad);border-bottom:1px solid var(--line)}
.service-block-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(12,1fr);gap:40px}
.service-block .sv-num{grid-column:span 2;font-family:'Manrope';font-size:clamp(60px,8vw,140px);font-weight:700;line-height:.85;letter-spacing:-.04em}
.service-block .sv-body{grid-column:span 6}
.service-block .sv-body h2{font-family:'Manrope';font-size:clamp(28px,3vw,44px);margin-bottom:20px;letter-spacing:-.02em;font-weight:600}
.service-block .sv-body p{color:var(--muted);font-size:16px;line-height:1.6;margin-bottom:30px;max-width:55ch}
.service-block .sv-list{list-style:none;display:flex;flex-direction:column;gap:12px}
.service-block .sv-list li{padding:14px 0;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:20px;font-size:15px}
.service-block .sv-list li::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}
.service-block .sv-list li span:first-of-type{flex:1}
.service-block .sv-list .sv-arrow{color:var(--muted);font-size:14px}
.service-block .sv-side{grid-column:span 3;grid-column-start:10;padding-top:10px}
.sv-side h4{font-size:12px;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);margin-bottom:16px;font-weight:500}
.sv-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:30px}
.sv-tags span{padding:6px 12px;border:1px solid var(--line);border-radius:100px;font-size:12px;background:rgba(255,255,255,.4)}

/* ============ Single case ============ */
.case-hero{padding:160px var(--pad) 60px}
.case-hero-inner{max-width:var(--max);margin:0 auto}
.case-hero-top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:20px;margin-bottom:60px;font-size:13px;color:var(--muted)}
.case-hero-title{font-family:'Manrope';font-size:clamp(56px,9vw,160px);font-weight:800;line-height:.9;letter-spacing:-.05em;margin-bottom:40px}
.case-hero-lead{font-size:clamp(18px,1.6vw,26px);max-width:760px;color:var(--ink);line-height:1.4;font-family:'Manrope';font-weight:400}
.case-cover{
  max-width:var(--max);margin:60px auto;border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:16/9;background:linear-gradient(135deg,#2dd4bf,#14b8a6);
}
.case-cover img{width:100%;height:100%;object-fit:cover}
.case-meta{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:40px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:40px 0}
.case-meta-item h5{font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:var(--muted);margin-bottom:10px;font-weight:500}
.case-meta-item p{font-family:'Manrope';font-size:18px;font-weight:500}
.case-section{padding:100px var(--pad);border-bottom:1px solid var(--line)}
.case-section-inner{max-width:var(--max);margin:0 auto;display:flex;flex-direction:column;gap:32px}
.case-section .label{color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.15em;padding-bottom:24px;border-bottom:1px solid var(--line)}
.case-section .content{max-width:900px}
.case-section h2{font-family:'Manrope';font-size:clamp(28px,3vw,44px);font-weight:600;margin-bottom:24px;letter-spacing:-.02em;line-height:1.1}
.case-section p{font-size:17px;line-height:1.6;color:var(--ink-2);margin-bottom:20px}
.case-section p.muted{color:var(--muted);font-size:16px}
.case-section ul{list-style:none;margin-top:20px}
.case-section ul li{padding:16px 0;border-top:1px solid var(--line);display:flex;gap:20px;align-items:flex-start}
.case-section ul li::before{content:counter(step,decimal-leading-zero);counter-increment:step;font-family:'JetBrains Mono';font-size:12px;color:var(--accent);padding-top:4px;min-width:28px}
.case-section ul.steps{counter-reset:step}
.case-results{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:40px}
.case-result-item{padding:30px 0;border-top:2px solid var(--ink)}
.case-result-num{font-family:'Manrope';font-size:clamp(48px,5vw,80px);font-weight:700;letter-spacing:-.03em;line-height:1}
.case-result-num sup{font-size:.4em;color:var(--accent)}
.case-result-label{color:var(--muted);font-size:14px;margin-top:10px;max-width:180px}
.gallery{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:60px 0}
.gallery .full{grid-column:span 2}
.gallery-img{border-radius:var(--radius);overflow:hidden;aspect-ratio:16/10}

/* ============ Contacts page ============ */
.contact-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;padding:0 var(--pad)}
.contact-info h2{font-family:'Manrope';font-size:clamp(32px,3.4vw,48px);font-weight:600;letter-spacing:-.02em;margin-bottom:40px}
.contact-block{padding:30px 0;border-top:1px solid var(--line)}
.contact-block h4{font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:var(--muted);margin-bottom:14px;font-weight:500}
.contact-block a,.contact-block p{font-family:'Manrope';font-size:clamp(20px,1.8vw,26px);font-weight:500;letter-spacing:-.01em;transition:color .3s;display:inline-block}
.contact-block a:hover{color:var(--accent)}
.contact-block .small{font-size:14px;color:var(--muted);font-weight:400;margin-top:6px;display:block;font-family:inherit}
.socials-row{display:flex;gap:10px;margin-top:16px}
.socials-row a{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;transition:.3s;font-size:14px}
.socials-row a:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.map-block{aspect-ratio:4/3;border-radius:var(--radius);background:var(--bg-alt) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='600' height='450' viewBox='0 0 600 450'><rect width='600' height='450' fill='%23e7e7e3'/><g stroke='%23d1d1cc' stroke-width='1' fill='none'><path d='M0 100 L600 120'/><path d='M0 180 L600 200'/><path d='M0 260 L600 280'/><path d='M0 340 L600 360'/><path d='M100 0 L120 450'/><path d='M220 0 L240 450'/><path d='M340 0 L360 450'/><path d='M460 0 L480 450'/></g><circle cx='300' cy='225' r='14' fill='%230094FF'/><circle cx='300' cy='225' r='30' fill='%230094FF' opacity='.2'/></svg>") center/cover;position:relative;margin-top:30px;border:1px solid var(--line)}

/* ============ Reviews page ============ */
.reviews-page{padding-top:44px}
.reviews-page-inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.reviews-toolbar{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  margin-bottom:30px;flex-wrap:wrap;
}
.reviews-status{
  font-size:14px;color:var(--muted);font-family:'JetBrains Mono','Menlo',monospace;
  letter-spacing:.03em;
}
.reviews-filters{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.reviews-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:24px;
}
.reviews-item{
  display:flex;flex-direction:column;
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--card);
  min-width:0;
}
.reviews-thumb{
  position:relative;
  aspect-ratio:4/3;
  background:var(--bg-alt);
  overflow:hidden;
}
.reviews-thumb img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .35s var(--ease);
}
.reviews-item:hover .reviews-thumb img{transform:scale(1.04)}
.reviews-thumb-fallback{
  width:100%;height:100%;
  display:grid;place-items:center;
  color:var(--muted);
  font-size:13px;text-transform:uppercase;letter-spacing:.08em;
}
.reviews-badge{
  position:absolute;left:12px;top:12px;
  padding:6px 10px;border-radius:100px;
  font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:#fff;background:rgba(12,12,12,.7);backdrop-filter:blur(6px);
}
.reviews-body{
  display:flex;flex-direction:column;gap:10px;
  padding:16px;
}
.reviews-name{
  font-family:'Inter',sans-serif;
  font-size:14px;font-weight:600;line-height:1.4;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.reviews-date{font-size:12px;color:var(--muted)}
.reviews-open{
  margin-top:auto;
  font-size:13px;font-weight:600;
  color:var(--ink);
  display:inline-flex;align-items:center;gap:8px;
}
.reviews-open:hover{color:var(--accent)}
.reviews-open::after{
  content:'\2197';
  font-size:12px;line-height:1;
}
.reviews-actions{
  margin-top:34px;
  display:flex;justify-content:center;
}
.reviews-empty{
  grid-column:1 / -1;
  border:1px dashed var(--line);
  border-radius:var(--radius);
  padding:32px;
  text-align:center;
  color:var(--muted);
  font-size:15px;
}

/* ============ Animations ============ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal-stagger>*{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal-stagger.in>*{opacity:1;transform:none}
.reveal-stagger.in>*:nth-child(1){transition-delay:.05s}
.reveal-stagger.in>*:nth-child(2){transition-delay:.15s}
.reveal-stagger.in>*:nth-child(3){transition-delay:.25s}
.reveal-stagger.in>*:nth-child(4){transition-delay:.35s}
.reveal-stagger.in>*:nth-child(5){transition-delay:.45s}
.reveal-stagger.in>*:nth-child(6){transition-delay:.55s}

/* Cursor / magnetic helpers */
.curzr{
  box-sizing:border-box;
  position:fixed;
  top:-11px;
  left:-11px;
  width:22px;
  height:22px;
  z-index:2147483647;
  pointer-events:none;
  user-select:none;
  will-change:transform;
  transform-origin:50% 50%;
  opacity:0;
  transition:opacity .2s ease, filter .2s ease;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,.35));
}
.curzr__svg{
  width:100%;
  height:100%;
  display:block;
  transform-origin:50% 50%;
  transition:none;
}
.curzr.active{opacity:1}
.curzr.hover .curzr__svg{transform:scale(1.18)}
.curzr.press .curzr__svg{transform:scale(.86)}
[data-theme="dark"] .curzr{filter:drop-shadow(0 2px 8px rgba(255,255,255,.25))}
.has-custom-cursor body,
.has-custom-cursor a,
.has-custom-cursor button,
.has-custom-cursor input,
.has-custom-cursor textarea,
.has-custom-cursor select,
.has-custom-cursor .chip,
.has-custom-cursor .contact-method,
.has-custom-cursor .case-card,
.has-custom-cursor .service-row{cursor:none !important}

/* ============ Preloader ============ */
.preloader{
  position:fixed;inset:0;background:var(--bg);z-index:10000;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;
  transition:opacity .7s var(--ease),visibility .7s var(--ease);
}
.preloader.hide{opacity:0;visibility:hidden;pointer-events:none}
.preloader-logo{width:120px;height:auto;animation:logoPulse 1.6s ease-in-out infinite}
.preloader-logo .bar{transform-origin:center;animation:barStretch 1.4s ease-in-out infinite}
.preloader-logo .bar:nth-child(2){animation-delay:.12s}
.preloader-logo .bar:nth-child(3){animation-delay:.24s}
.preloader-logo .bar:nth-child(4){animation-delay:.36s}
@keyframes logoPulse{0%,100%{opacity:1}50%{opacity:.6}}
@keyframes barStretch{0%,100%{transform:scaleY(1)}50%{transform:scaleY(.55)}}
.preloader-progress{width:220px;height:2px;background:var(--line);position:relative;overflow:hidden;border-radius:2px}
.preloader-progress::after{content:'';position:absolute;inset:0;background:var(--ink);transform-origin:left;animation:loadBar 1.6s var(--ease) forwards}
@keyframes loadBar{0%{transform:scaleX(0)}100%{transform:scaleX(1)}}
.preloader-text{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}

/* ============ Logo image ============ */
.logo-img{height:26px;width:auto;display:block}
.preloader-logo .logo-img{height:auto;width:100%}

/* ============ Theme toggle ============ */
.theme-toggle{
  width:40px;height:40px;border-radius:50%;border:1px solid var(--line);
  display:grid;place-items:center;transition:.3s;background:transparent;color:var(--ink);
  cursor:pointer;
}
.theme-toggle:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.theme-toggle svg{width:16px;height:16px}
.theme-toggle .sun{display:none}
[data-theme="dark"] .theme-toggle .sun{display:block}
[data-theme="dark"] .theme-toggle .moon{display:none}

/* ============ Team section ============ */
.team{padding:130px var(--pad)}
.team-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center}
.team-photo{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;background:var(--bg-alt);position:relative}
.team-photo img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.team-photo:hover img{transform:scale(1.03)}
.team-badge{position:absolute;bottom:20px;left:20px;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);padding:10px 16px;border-radius:100px;font-size:12px;font-weight:600;display:flex;align-items:center;gap:10px}
.team-badge .dot-sm{width:8px;height:8px;border-radius:50%;background:#16a34a}
.team-text .eyebrow{margin-bottom:20px;display:block}
.team-text h2{font-family:'Manrope';font-size:clamp(32px,3.4vw,52px);font-weight:600;letter-spacing:-.02em;line-height:1.05;margin-bottom:26px}
.team-text h2 em{font-style:italic;font-weight:300;color:var(--muted)}
.team-text p{color:var(--muted);font-size:16px;line-height:1.65;margin-bottom:30px;max-width:52ch}
.founder-card{
  display:grid;grid-template-columns:112px 1fr;gap:18px;align-items:center;
  padding:16px;border:1px solid var(--line);border-radius:16px;background:var(--card);margin:0 0 26px;
}
.founder-card img{width:112px;height:112px;border-radius:14px;object-fit:cover;display:block}
.founder-card.no-photo{grid-template-columns:1fr}
.founder-role{
  display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;
  border:1px solid var(--line);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);
}
.founder-info h3{font-size:22px;line-height:1.1;letter-spacing:-.01em;margin:10px 0 8px}
.founder-info p{font-size:14px;line-height:1.55;color:var(--muted);margin:0 0 14px;max-width:62ch}
.founder-meta{display:flex;flex-wrap:wrap;gap:8px}
.founder-meta span{padding:6px 10px;border-radius:999px;border:1px solid var(--line);font-size:12px;background:var(--bg)}
.team-roles{display:flex;flex-wrap:wrap;gap:8px;margin-top:30px}
.team-roles span{padding:8px 14px;border:1px solid var(--line);border-radius:100px;font-size:13px;background:var(--card)}

/* ============ Service pages ============ */
.service-card-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.service-card{
  display:flex;flex-direction:column;gap:10px;padding:22px;border:1px solid var(--line);border-radius:18px;
  background:var(--card);color:var(--ink);transition:.3s;
}
.service-card h3{font-family:'Manrope';font-size:22px;line-height:1.1}
.service-card p{font-size:14px;line-height:1.55;color:var(--muted)}
.service-card span{margin-top:auto;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
.service-card:hover{transform:translateY(-2px);border-color:var(--ink)}

.service-detail-hero{padding:0 var(--pad) 70px}
.service-detail-inner{
  max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.05fr .95fr;gap:26px;align-items:center;
}
.service-detail-content{padding:24px 0}
.service-detail-content h2{font-family:'Manrope';font-size:clamp(32px,4vw,58px);line-height:1;letter-spacing:-.03em;margin:12px 0 16px}
.service-detail-content p{color:var(--muted);font-size:16px;line-height:1.65;max-width:58ch;margin-bottom:20px}
.service-detail-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.service-detail-tags span{
  padding:7px 12px;border-radius:999px;border:1px solid var(--line);font-size:12px;background:var(--card);
}
.service-detail-media{
  border:1px solid var(--line);border-radius:22px;overflow:hidden;aspect-ratio:1/1;background:var(--bg-alt);
}
.service-detail-media img{width:100%;height:100%;object-fit:cover}
.service-scope-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.scope-card{border:1px solid var(--line);background:var(--card);border-radius:18px;padding:22px}
.scope-card h3{font-family:'Manrope';font-size:24px;letter-spacing:-.02em;margin-bottom:12px}
.scope-card ul{display:flex;flex-direction:column;gap:8px}
.scope-card li{color:var(--muted);font-size:14px;line-height:1.55}
.sv-body h2 a{color:inherit;border-bottom:1px solid transparent;transition:.25s}
.sv-body h2 a:hover{border-color:currentColor}
.sv-list li span a{color:inherit}

/* ============ AI / Blockchain section ============ */
.trends{padding:130px var(--pad);background:var(--ink);color:var(--bg);border-radius:var(--radius-lg);margin:40px var(--pad)}
.trends-inner{max-width:calc(var(--max) - 80px);margin:0 auto}
.trends-head{display:grid;grid-template-columns:auto 1fr auto;gap:40px;align-items:end;margin-bottom:70px}
.trends-head .eyebrow{color:rgba(255,255,255,.5)}
.trends-head h2{font-family:'Manrope';font-size:clamp(36px,4.2vw,64px);font-weight:600;letter-spacing:-.03em;line-height:1;max-width:18ch}
.trends-head h2 em{font-style:italic;font-weight:300;color:#777}
.trends-head .counter{color:rgba(255,255,255,.4);font-family:'JetBrains Mono';font-size:11px;white-space:nowrap}
.trends-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;margin-bottom:60px}
.chart-card{background:#161618;border-radius:var(--radius);padding:34px;border:1px solid rgba(255,255,255,.08)}
.chart-card h3{font-size:18px;font-weight:600;margin-bottom:6px}
.chart-card .chart-sub{color:rgba(255,255,255,.5);font-size:13px;margin-bottom:30px}
.chart-legend{display:flex;gap:20px;margin-bottom:24px;flex-wrap:wrap}
.chart-legend span{display:flex;align-items:center;gap:8px;font-size:12px;color:rgba(255,255,255,.7)}
.chart-legend i{width:10px;height:10px;border-radius:3px}
.chart-legend .l1{background:var(--accent)}
.chart-legend .l2{background:#14b8a6}
.chart-legend .l3{background:#8b5cf6}
.chart-svg{width:100%;height:260px;overflow:visible}
.chart-bars{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;height:240px;align-items:end;margin-top:10px}
.chart-bar-col{display:flex;gap:4px;align-items:end;justify-content:center;height:100%;position:relative}
.chart-bar{width:14px;border-radius:4px 4px 0 0;transition:transform .6s var(--ease);transform-origin:bottom;transform:scaleY(0)}
.chart-bar.in{transform:scaleY(1)}
.chart-bar.a{background:linear-gradient(to top,var(--accent),#ff8f60)}
.chart-bar.b{background:linear-gradient(to top,#14b8a6,#5eead4)}
.chart-bar.c{background:linear-gradient(to top,#8b5cf6,#c4b5fd)}
.chart-xlabel{position:absolute;bottom:-24px;left:0;right:0;text-align:center;font-family:'JetBrains Mono';font-size:10px;color:rgba(255,255,255,.45)}
.chart-xaxis{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;padding-top:30px;font-family:'JetBrains Mono';font-size:10px;color:rgba(255,255,255,.45);text-align:center}

.trends-stats{display:flex;flex-direction:column;gap:14px}
.trend-stat{background:#161618;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:26px;transition:.3s;cursor:default}
.trend-stat:hover{border-color:var(--accent)}
.trend-stat .tag{font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:var(--accent);margin-bottom:10px;font-weight:500}
.trend-stat .num{font-family:'Manrope';font-size:42px;font-weight:700;letter-spacing:-.02em;line-height:1}
.trend-stat .num sup{font-size:.4em;color:rgba(255,255,255,.4);margin-left:3px;vertical-align:top}
.trend-stat .desc{color:rgba(255,255,255,.55);font-size:13px;margin-top:10px;line-height:1.5}

.trends-services{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);overflow:hidden}
.trends-service{background:#0b0b0c;padding:36px;transition:background .3s}
.trends-service:hover{background:#161618}
.trends-service .icon{width:44px;height:44px;border-radius:12px;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:20px;margin-bottom:20px}
.trends-service h4{font-family:'Manrope';font-size:22px;font-weight:600;margin-bottom:12px;letter-spacing:-.01em}
.trends-service p{color:rgba(255,255,255,.55);font-size:14px;line-height:1.55}
.trends-service .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:20px}
.trends-service .tags span{padding:4px 10px;border:1px solid rgba(255,255,255,.15);border-radius:100px;font-size:11px;color:rgba(255,255,255,.7)}

/* ============ Modal ============ */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);
  z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;
  opacity:0;visibility:hidden;transition:.3s;
}
.modal-overlay.open{opacity:1;visibility:visible}
.modal{
  background:var(--bg);color:var(--ink);border-radius:var(--radius-lg);
  max-width:520px;width:100%;padding:44px;position:relative;
  transform:translateY(20px) scale(.98);transition:transform .45s var(--ease);
  max-height:90vh;overflow-y:auto;
}
.modal-overlay.open .modal{transform:none}
.modal-close{
  position:absolute;top:18px;right:18px;width:40px;height:40px;border-radius:50%;
  border:1px solid var(--line);display:grid;place-items:center;font-size:18px;
  transition:.3s;
}
.modal-close:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.modal .eyebrow{display:block;margin-bottom:14px}
.modal h3{font-family:'Manrope';font-size:clamp(26px,2.6vw,36px);font-weight:600;letter-spacing:-.02em;line-height:1.1;margin-bottom:14px}
.modal p.modal-lead{color:var(--muted);font-size:15px;margin-bottom:26px;line-height:1.55}
.modal .form{gap:16px}
.modal .form .field input,.modal .form .field textarea{color:var(--ink);border-bottom-color:var(--line)}
.modal .form .field label{color:var(--muted)}
.modal .contact-methods{display:flex;gap:8px;margin-top:4px;flex-wrap:wrap}
.contact-method{
  flex:1;min-width:120px;padding:14px 16px;border:1px solid var(--line);border-radius:12px;
  cursor:pointer;transition:.3s;display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;
  background:var(--card);
}
.contact-method:hover{border-color:var(--ink)}
.contact-method.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.contact-method .ico{font-size:18px}

/* Floating CTA button */
.floating-cta{
  position:fixed;bottom:30px;right:30px;z-index:500;
  width:60px;height:60px;border-radius:50%;background:var(--ink);color:var(--bg);
  display:grid;place-items:center;box-shadow:0 10px 30px rgba(0,0,0,.25);
  cursor:pointer;transition:.3s;font-size:22px;
}
.floating-cta:hover{background:var(--accent);transform:scale(1.08)}

/* ============ Responsive ============ */
@media (max-width:1024px){
  .curzr{display:none !important}
  .has-custom-cursor body,
  .has-custom-cursor a,
  .has-custom-cursor button,
  .has-custom-cursor input,
  .has-custom-cursor textarea,
  .has-custom-cursor select,
  .has-custom-cursor .chip,
  .has-custom-cursor .contact-method,
  .has-custom-cursor .case-card,
  .has-custom-cursor .service-row{cursor:auto !important}
  .display{font-size:clamp(34px,8.8vw,64px)}
  .lead{font-size:16px}
  .section{padding:96px var(--pad)}
  .stats{padding:80px var(--pad)}
  .hero{padding:136px var(--pad) 56px}
  .hero-top{margin-bottom:32px;gap:16px}
  .hero-meta{margin-top:36px;gap:22px}
  .hero-tag{font-size:11px;padding:7px 12px}
  .mono{font-size:10px}
  .nav-wrap{gap:16px}
  .nav-wrap{position:relative}
  .nav-contact-links{display:none}
  .nav-cta{gap:8px}
  .nav-cta .btn{padding:10px 14px;font-size:12px}
  .upwork-banner-section{padding:0 var(--pad) 24px}
  .marquee{padding:14px 0}
  .marquee-track{gap:34px}
  .marquee-track span{font-size:clamp(16px,2.3vw,22px)}
  .team-inner{grid-template-columns:1fr;gap:30px}
  .founder-card{grid-template-columns:92px 1fr;padding:14px}
  .founder-card img{width:92px;height:92px}
  .founder-info h3{font-size:20px}
  .trends-head{grid-template-columns:1fr;gap:20px}
  .trends-grid{grid-template-columns:1fr}
  .trends-grid > *{min-width:0;max-width:100%}
  .trends-services{grid-template-columns:1fr}
  .trends{margin:20px var(--pad);padding:60px 30px;overflow:hidden}
  .trends-inner{max-width:100%}
  .chart-card{padding:22px;min-width:0}
  .chart-bars{gap:8px;height:200px;grid-template-columns:repeat(6,minmax(0,1fr))}
  .chart-bar{width:10px}
  .chart-xlabel{bottom:-20px;font-size:9px}
  .trend-stat{padding:20px;min-width:0}
  .trend-stat .num{font-size:34px}
  .modal{padding:30px}
  .floating-cta{bottom:20px;right:20px;width:52px;height:52px}
  .nav-links{display:none}
  .nav-links.open{
    display:flex;position:absolute;top:calc(100% + 10px);left:0;right:0;z-index:120;
    flex-direction:column;gap:0;background:var(--bg);border:1px solid var(--line);
    border-radius:16px;overflow:hidden;box-shadow:0 18px 40px rgba(0,0,0,.12);
  }
  .nav-links.open li{border-bottom:1px solid var(--line)}
  .nav-links.open li:last-child{border-bottom:none}
  .nav-links.open a{display:block;padding:14px 16px}
  .burger{display:flex}
  .burger.active span:first-child{transform:translateY(3px) rotate(45deg)}
  .burger.active span:last-child{transform:translateY(-3px) rotate(-45deg)}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:30px}
  .stack-grid{grid-template-columns:repeat(3,1fr)}
  .service-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .service-scope-grid{grid-template-columns:1fr}
  .service-detail-inner{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
  .cta-inner{grid-template-columns:1fr;gap:40px}
  .case-meta{grid-template-columns:repeat(2,1fr)}
  .case-results{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .section-head{grid-template-columns:1fr;gap:14px;text-align:left}
  .section-head .title-col,.section-head .eyebrow-col,.section-head .meta-col{grid-column:span 12;text-align:left}
  .section-head .eyebrow-col,.section-head .meta-col{white-space:normal}
  .case-card{grid-column:span 12!important}
  .hero-meta{grid-template-columns:1fr}
  .hero-meta .lead,.hero-meta .cta-block{grid-column:span 1}
  .service-row{grid-template-columns:50px 1fr 60px;gap:20px}
  .service-desc{display:none}
  .service-block-inner{grid-template-columns:1fr;gap:20px}
  .service-block .sv-num,.service-block .sv-body,.service-block .sv-side{grid-column:span 1}
  .about{margin:20px var(--pad);padding:50px 30px}
  .about-inner{grid-template-columns:1fr}
  .about-title,.about-meta{grid-column:span 1}
  .why-grid{grid-template-columns:1fr}
  .review-card{flex:0 0 calc(100% - 16px)}
  .reviews-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
  .reviews-toolbar{align-items:flex-start}
  .reviews-filters{width:100%}
  .page-header-inner{display:flex;flex-direction:column;align-items:flex-start;gap:14px}
  .page-header h1,.page-header-meta{grid-column:span 1;width:100%}
  .page-header h1{line-height:1.02}
  .page-header h1 em{display:block;margin-top:6px;line-height:1.02}
  .case-section-inner{grid-template-columns:1fr}
  .case-section .label,.case-section .content{grid-column:span 1}
  .gallery{grid-template-columns:1fr}
  .gallery .full{grid-column:span 1}
  .form-row{grid-template-columns:1fr}
  .footer-huge{font-size:80px}
}
@media (max-width:600px){
  :root{--pad:14px}
  body{font-size:15px}
  .page-header{padding:112px var(--pad) 42px}
  .page-header-inner{gap:10px}
  .page-header h1{font-size:clamp(28px,10vw,42px);line-height:1.03;letter-spacing:-.02em}
  .page-header h1 em{font-size:.9em;margin-top:4px}
  .page-header-meta{font-size:14px;padding-bottom:0}
  .breadcrumbs{font-size:10px;letter-spacing:.08em;gap:6px;flex-wrap:wrap;margin-bottom:18px}
  .breadcrumbs span:not(:last-child)::after{margin-left:6px}
  .display{font-size:clamp(26px,11.5vw,44px);letter-spacing:-.03em}
  .h2{font-size:clamp(24px,7.5vw,34px)}
  .hero{padding-top:112px;padding-bottom:42px}
  .hero-scroll{display:none}
  .hero-meta{margin-top:24px}
  .hero-tag{font-size:10px;padding:6px 10px}
  .nav-cta .btn{padding:9px 12px;font-size:11px}
  .nav-cta .btn .btn-arrow{display:none}
  .btn{padding:11px 16px;font-size:12px}
  .hero-meta .cta-block{width:100%}
  .hero-meta .cta-block .btn{width:100%;justify-content:center}
  .section{padding:72px var(--pad)}
  .section-head .title-col br,.about-title br{display:none}
  .about{margin:12px var(--pad);padding:28px 16px;border-radius:20px}
  .about-inner{gap:16px}
  .about-title{font-size:clamp(24px,8.4vw,34px);line-height:1.14;overflow-wrap:anywhere}
  .about-meta{padding-top:0;gap:16px}
  .about-meta p{font-size:14px;overflow-wrap:anywhere}
  .about-meta .btn-ghost{width:100%;justify-content:center}
  .service-row{grid-template-columns:36px 1fr 42px;gap:12px}
  .service-name{font-size:clamp(18px,7.5vw,28px);line-height:1.05}
  .stats{padding:60px var(--pad)}
  .stat-num{font-size:clamp(42px,14vw,64px)}
  .stat-label{font-size:13px}
  .founder-card{grid-template-columns:1fr;gap:12px}
  .founder-card img{width:100%;height:auto;max-height:260px}
  .founder-info h3{font-size:18px}
  .founder-info p{font-size:13px}
  .founder-role{font-size:10px}
  .trends{margin:12px var(--pad);padding:20px var(--pad);border-radius:20px;overflow:hidden}
  .trends-inner{width:100%;max-width:100%;min-width:0}
  .trends-grid{display:flex;flex-direction:column;gap:14px;width:100%;max-width:100%;min-width:0}
  .trends-grid > *{width:100%;max-width:100%;min-width:0}
  .trends-head{margin-bottom:28px}
  .trends-head h2{font-size:clamp(28px,9vw,40px);max-width:100%}
  .trends-head .counter{display:none}
  .chart-card{padding:16px;width:100%;max-width:100%;min-width:0}
  .chart-card h3{font-size:16px;line-height:1.3}
  .chart-card .chart-sub{font-size:12px;margin-bottom:18px}
  .chart-legend{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:14px}
  .chart-legend span{font-size:11px;min-width:0}
  .chart-bars{gap:6px;height:170px;grid-template-columns:repeat(6,minmax(0,1fr))}
  .chart-bar{width:8px}
  .chart-bar-col{min-width:0}
  .trends-stats{width:100%;max-width:100%;min-width:0}
  .trend-stat{padding:16px;width:100%;max-width:100%;min-width:0}
  .trend-stat .num{font-size:30px}
  .trend-stat .desc{font-size:12px}
  .trends-service{padding:24px}
  .reviews-grid{grid-template-columns:1fr}
  .reviews-status{font-size:12px}
  .reviews-body{padding:14px}
  .reviews-name{font-size:13px}
  .footer-huge{font-size:64px}
  .stats-grid{grid-template-columns:1fr}
  .stack-grid{grid-template-columns:repeat(2,1fr)}
  .service-card-grid{grid-template-columns:1fr}
  .service-detail-content h2{font-size:clamp(26px,9.3vw,42px)}
  .service-detail-content p{font-size:14px}
  .scope-card{padding:18px}
  .scope-card h3{font-size:20px}
  .footer-grid{grid-template-columns:1fr}
  .case-meta{grid-template-columns:1fr}
  .case-results{grid-template-columns:1fr}
}

