:root{
  --bg-dark:#090c14;
  --bg-card:#0d1120;
  --bg-card2:#111827;
  --bg-input:#0a0e1a;
  --text:#e2e8f0;
  --text-muted:#64748b;
  --text-dim:#94a3b8;
  --border:#1e2840;
  --success:#10b981;
  --accent:#06b6d4;
  --blue:#1d6ae5;
  --blue-light:#3b82f6;
  --radius:8px;
  --max:1160px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:var(--bg-dark);
  line-height:1.55;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}
.skip-link{position:absolute;left:-999px;top:12px;background:var(--accent);color:#001018;padding:10px 14px;border-radius:var(--radius);z-index:20}
.skip-link:focus{left:12px}
.site-header{
  position:sticky;
  top:0;
  z-index:10;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  min-height:78px;
  padding:10px max(18px,calc((100vw - var(--max))/2));
  background:rgba(9,12,20,.86);
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(14px);
}
.brand{display:flex;align-items:center}
.brand img{display:block;width:170px;max-height:62px;object-fit:contain}
.nav{display:flex;align-items:center;gap:22px;color:var(--text-dim);font-size:14px}
.nav a{transition:color .2s ease}
.nav a:hover{color:var(--text)}
.header-cta,.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 18px;
  border-radius:var(--radius);
  font-weight:800;
  border:1px solid transparent;
  transition:transform .18s ease,border-color .18s ease,background .18s ease;
}
.header-cta{color:#001018;background:var(--accent)}
.btn:hover,.header-cta:hover{transform:translateY(-2px)}
.btn-primary{color:#001018;background:var(--success)}
.btn-secondary{color:var(--text);border-color:var(--border);background:rgba(255,255,255,.02)}
.hero{
  position:relative;
  min-height:calc(100vh - 78px);
  display:grid;
  grid-template-columns:minmax(280px,440px) minmax(0,1fr);
  align-items:center;
  gap:44px;
  padding:74px max(18px,calc((100vw - var(--max))/2)) 46px;
  isolation:isolate;
}
.hero:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-2;
  background:
    linear-gradient(rgba(30,40,64,.45) 1px,transparent 1px),
    linear-gradient(90deg,rgba(30,40,64,.45) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:linear-gradient(to bottom,#000 0%,rgba(0,0,0,.7) 58%,transparent 100%);
}
.hero:after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:120px;
  z-index:-1;
  background:linear-gradient(to bottom,transparent,var(--bg-dark));
}
.hero-backdrop span{
  position:absolute;
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 18px var(--accent);
  animation:floatPoint 8s linear infinite;
  opacity:.72;
}
.hero-backdrop span:nth-child(1){left:18%;top:24%;animation-delay:-1s}
.hero-backdrop span:nth-child(2){left:64%;top:18%;animation-delay:-3s}
.hero-backdrop span:nth-child(3){left:78%;top:66%;animation-delay:-5s}
.hero-backdrop span:nth-child(4){left:34%;top:76%;animation-delay:-7s}
.hero-content{grid-column:2;grid-row:1}
.device-stage{grid-column:1;grid-row:1}
.eyebrow{
  margin:0 0 10px;
  color:var(--accent);
  font-size:12px;
  font-weight:900;
  letter-spacing:2px;
  text-transform:uppercase;
}
h1,h2,h3,p{margin-top:0}
h1{
  max-width:680px;
  margin-bottom:18px;
  font-size:clamp(42px,4.4vw,64px);
  line-height:.95;
  letter-spacing:0;
}
h1 span{white-space:nowrap}
h2{font-size:clamp(30px,4vw,48px);line-height:1.08;margin-bottom:12px}
h3{font-size:20px;margin-bottom:8px}
.hero-copy{max-width:650px;color:var(--text-dim);font-size:18px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin:28px 0}
.trust-row{display:flex;gap:10px;flex-wrap:wrap;color:var(--text-dim);font-size:13px}
.trust-row span{padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);background:rgba(13,17,32,.78)}
.device-stage{
  position:relative;
  min-height:430px;
  display:grid;
  place-items:center;
  overflow:visible;
  transform:scale(.88);
  transform-origin:center;
}
.phone{
  width:min(210px,100%);
  aspect-ratio:9/18;
  border-radius:32px;
  background:linear-gradient(145deg,#121a2b,#070a12);
  border:1px solid #2a385a;
  box-shadow:0 30px 80px rgba(0,0,0,.5),inset 0 0 0 8px #050812;
  transform:rotate(-7deg);
  animation:phoneLift 5s ease-in-out infinite;
  margin-top:18px;
}
.speaker{width:72px;height:8px;border-radius:99px;background:#293653;margin:20px auto}
.screen-lines{padding:54px 34px;display:grid;gap:16px}
.screen-lines i{display:block;height:13px;border-radius:99px;background:linear-gradient(90deg,var(--blue),var(--accent));opacity:.88}
.screen-lines i:nth-child(2){width:78%}
.screen-lines i:nth-child(3){width:56%;background:var(--success)}
.screen-lines i:nth-child(4){width:86%;opacity:.45}
.laptop{
  position:absolute;
  right:8%;
  bottom:14%;
  width:min(210px,44%);
  animation:laptopLift 5.6s ease-in-out infinite;
}
.laptop-screen{
  height:116px;
  padding:24px 22px;
  border:1px solid #2a385a;
  border-radius:16px 16px 8px 8px;
  background:linear-gradient(145deg,#101827,#060911);
  box-shadow:0 22px 54px rgba(0,0,0,.42),inset 0 0 0 7px #050812;
}
.laptop-screen i{
  display:block;
  height:11px;
  margin-bottom:12px;
  border-radius:99px;
  background:linear-gradient(90deg,var(--blue),var(--accent));
}
.laptop-screen i:nth-child(2){width:72%;background:var(--success)}
.laptop-screen i:nth-child(3){width:86%;opacity:.48}
.laptop-base{
  width:112%;
  height:28px;
  margin-left:-6%;
  border-radius:5px 5px 18px 18px;
  background:linear-gradient(180deg,#162033,#0a0e19);
  border:1px solid #2a385a;
  box-shadow:0 14px 28px rgba(0,0,0,.36);
}
.tool-card{
  position:absolute;
  padding:12px 16px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:rgba(17,24,39,.9);
  color:var(--text);
  font-weight:900;
  box-shadow:0 16px 38px rgba(0,0,0,.35);
}
.tool-one{left:8%;top:24%;animation:floatCard 4s ease-in-out infinite}
.tool-two{right:8%;bottom:26%;animation:floatCard 4s ease-in-out infinite reverse}
.tool-three{left:34%;bottom:14%;animation:floatCard 4.3s ease-in-out infinite}
.signal-ring{
  position:absolute;
  width:360px;
  aspect-ratio:1;
  border:1px solid rgba(6,182,212,.34);
  border-radius:50%;
  animation:pulseRing 3.5s ease-out infinite;
  z-index:-1;
}
.section,.horizontal-section{
  max-width:var(--max);
  margin:0 auto;
  padding:82px 18px;
}
.intro{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:38px;
  border-top:1px solid var(--border);
}
.intro p:last-child{align-self:start;margin-top:2.35rem;color:var(--text-dim);font-size:18px}
.section-head{max-width:790px;margin-bottom:28px}
.services-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.service-card,.timeline div,.faq details,.horizontal-scroll article{
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--bg-card);
}
.service-card{
  padding:24px;
  min-height:220px;
  transition:transform .18s ease,border-color .18s ease;
}
.service-card:hover{transform:translateY(-4px);border-color:rgba(6,182,212,.7)}
.service-card p,.timeline p,.faq p{color:var(--text-dim)}
.service-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  margin-bottom:22px;
  border-radius:var(--radius);
  background:rgba(6,182,212,.14);
  color:var(--accent);
  font-weight:900;
}
.horizontal-section{overflow:hidden}
.horizontal-scroll{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(270px,360px);
  gap:14px;
  overflow-x:auto;
  overscroll-behavior-inline:contain;
  scroll-snap-type:inline mandatory;
  padding:4px 0 18px;
}
.horizontal-scroll::-webkit-scrollbar{height:8px}
.horizontal-scroll::-webkit-scrollbar-thumb{background:var(--accent);border-radius:99px}
.horizontal-scroll article{
  min-height:180px;
  scroll-snap-align:start;
  padding:24px;
  background:linear-gradient(180deg,var(--bg-card2),var(--bg-card));
}
.horizontal-scroll strong{display:block;font-size:22px;margin-bottom:12px}
.horizontal-scroll span{color:var(--text-dim)}
.notebook-repairs{
  border-top:1px solid var(--border);
}
.notebook-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.notebook-grid article{
  min-height:210px;
  padding:22px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:linear-gradient(180deg,var(--bg-card2),var(--bg-card));
}
.notebook-grid p{color:var(--text-dim)}
.location-section{padding-top:46px}
.location-layout{
  display:grid;
  grid-template-columns:minmax(260px,380px) minmax(0,1fr);
  gap:24px;
  align-items:stretch;
}
.info-cards{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
.info-card{
  min-height:auto;
  padding:20px 18px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:linear-gradient(180deg,var(--bg-card2),var(--bg-card));
  text-align:left;
  box-shadow:0 18px 42px rgba(0,0,0,.18);
}
.info-icon{
  display:inline-grid;
  place-items:center;
  width:38px;
  height:38px;
  margin:0 0 12px;
  border:2px solid rgba(6,182,212,.65);
  border-radius:50%;
  color:var(--accent);
  font-size:22px;
  font-weight:900;
  line-height:1;
}
.info-card h3{color:var(--text);font-size:18px}
.info-card p{margin-bottom:8px;color:var(--text)}
.info-card small{display:block;color:var(--text-dim);font-size:14px}
.google-review-card{border-color:rgba(6,182,212,.42)}
.google-review-card strong{color:var(--accent);font-size:22px}
.map-panel{
  overflow:hidden;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--bg-card);
}
.map-panel iframe{
  display:block;
  width:100%;
  height:100%;
  min-height:520px;
  border:0;
  filter:saturate(.88) contrast(1.02);
}
.map-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:14px;
}
.timeline{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.timeline div{padding:22px}
.timeline span{
  display:inline-grid;
  place-items:center;
  width:34px;
  height:34px;
  margin-bottom:18px;
  border-radius:50%;
  color:#001018;
  background:var(--accent);
  font-weight:900;
}
.faq-list{display:grid;gap:12px}
.faq details{padding:0 20px}
.faq summary{
  cursor:pointer;
  padding:20px 0;
  font-weight:900;
  list-style:none;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary:after{content:"+";float:right;color:var(--accent)}
.faq details[open] summary:after{content:"-"}
.faq p{padding-bottom:20px}
.footer{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  flex-wrap:wrap;
  padding:28px 18px 110px;
  border-top:1px solid var(--border);
  color:var(--text-muted);
  text-align:center;
}
.footer img{display:block;width:132px;max-height:64px;object-fit:contain}
.footer a{color:var(--accent);font-weight:800}
.whatsapp-float{
  position:fixed;
  right:20px;
  bottom:20px;
  z-index:12;
  display:flex;
  align-items:center;
  gap:8px;
  min-height:50px;
  padding:8px 24px 8px 10px;
  border:1px solid rgba(255,255,255,.22);
  border-radius:999px;
  color:#fff;
  background:#16c65f;
  box-shadow:0 12px 28px rgba(22,198,95,.36);
  font-weight:900;
  font-size:18px;
  line-height:1;
  white-space:nowrap;
}
.whatsapp-float img{
  display:block;
  width:32px;
  height:32px;
  flex:0 0 32px;
  object-fit:contain;
  background:#fff;
  border-radius:50%;
}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .55s ease,transform .55s ease}
.reveal.is-visible{opacity:1;transform:none}
@keyframes phoneLift{50%{transform:rotate(-4deg) translateY(-12px)}}
@keyframes laptopLift{50%{transform:translateY(-10px) rotate(2deg)}}
@keyframes floatCard{50%{transform:translateY(-12px)}}
@keyframes pulseRing{0%{transform:scale(.78);opacity:.8}100%{transform:scale(1.18);opacity:0}}
@keyframes floatPoint{50%{transform:translateY(-30px);opacity:.25}}
@media (prefers-reduced-motion:reduce){
  *,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition:none!important}
}
@media (max-width:900px){
  .site-header{position:relative;align-items:flex-start;flex-wrap:wrap}
  .nav{order:3;width:100%;overflow-x:auto;padding-bottom:4px}
  .hero{
    grid-template-columns:minmax(150px,240px) minmax(0,1fr);
    min-height:calc(100vh - 78px);
    align-items:center;
    gap:22px;
    padding-top:42px;
  }
  .hero-content{grid-column:2;grid-row:1}
  .device-stage{grid-column:1;grid-row:1;min-height:360px}
  .device-stage{transform:scale(.82)}
  .phone{width:min(178px,100%)}
  .tool-one{left:0;top:30%}
  .tool-two{right:0;bottom:24%}
  .intro,.services-grid,.timeline,.notebook-grid,.info-cards,.location-layout{grid-template-columns:1fr}
  .intro p:last-child{margin-top:0}
  .map-panel iframe{height:320px;min-height:320px}
}
@media (max-width:560px){
  .brand img{width:138px;max-height:54px}
  .header-cta{display:none}
  .hero{
    grid-template-columns:minmax(120px,170px) minmax(0,1fr);
    gap:16px;
    padding-top:28px;
  }
  .device-stage{min-height:300px;transform:scale(.78)}
  .phone{width:min(148px,36vw);border-radius:22px;box-shadow:0 20px 48px rgba(0,0,0,.48),inset 0 0 0 6px #050812}
  .laptop{width:min(128px,40%);right:2%;bottom:14%}
  .laptop-screen{height:88px;padding:20px 16px;border-radius:12px 12px 6px 6px;box-shadow:0 16px 36px rgba(0,0,0,.4),inset 0 0 0 5px #050812}
  .laptop-screen i{height:7px;margin-bottom:8px}
  .laptop-base{height:18px}
  .speaker{width:48px;height:6px;margin:15px auto}
  .screen-lines{padding:36px 22px;gap:10px}
  .screen-lines i{height:9px}
  h1{font-size:clamp(30px,9vw,42px)}
  h1 span{white-space:normal}
  .hero-copy{font-size:13px}
  .hero-actions{margin:18px 0;gap:8px}
  .btn{min-height:36px;padding:0 12px;font-size:12px}
  .trust-row{gap:6px;font-size:10px}
  .trust-row span{padding:6px 8px}
  .tool-card{padding:8px 10px;font-size:11px}
  .tool-one{left:-4px;top:34%}
  .tool-two{right:-6px;bottom:28%}
  .tool-three{left:32%;bottom:10%}
  .whatsapp-float{right:12px;bottom:14px;max-width:calc(100vw - 24px);font-size:15px;padding-right:18px}
}
@media (max-width:430px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-content{grid-column:1;grid-row:1}
  .device-stage{grid-column:1;grid-row:2;min-height:300px;transform:scale(.86)}
  .phone{width:min(180px,56vw)}
  .laptop{width:min(160px,50%);right:5%;bottom:6%}
}
