@import url('https://fonts.googleapis.com/css2?family=Cormorant:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=Montserrat:wght@300;400;500;600;700;800;900&display=swap');

/* ═══════════════════════════
   DESIGN TOKENS
═══════════════════════════ */
:root {
  --blue:       #0095FF;
  --blue-dark:  #006FCC;
  --blue-glow:  rgba(0,149,255,.35);
  --blue-light: #E8F4FF;
  --black:      #111827;
  --gray-700:   #374151;
  --gray-500:   #6B7280;
  --gray-300:   #D1D5DB;
  --gray-100:   #F3F4F6;
  --white:      #FFFFFF;
  --surface:    #F8FAFF;
  --border:     rgba(0,0,0,.08);

  --f-head: 'Cormorant', Georgia, serif;
  --f-body: 'Montserrat', system-ui, sans-serif;

  --ease-out:    cubic-bezier(.16,1,.3,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);

  --r-card: 24px;
  --r-btn:  50px;
  --shadow-card: 0 4px 24px rgba(0,0,0,.06), 0 1px 4px rgba(0,0,0,.04);
  --shadow-blue: 0 8px 32px rgba(0,149,255,.3);
  --nav-h: 88px;
}

/* ═══ RESET ═══ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden;}
body{
  font-family:var(--f-body);
  background:var(--white);
  color:var(--gray-700);
  line-height:1.65;
  overflow-x:hidden;
  width:100%;
  -webkit-font-smoothing:antialiased;
  cursor: auto;
}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}
img{display:block;max-width:100%;}
button{border:none;background:none;font-family:inherit;cursor: auto;}
input,select,textarea{font-family:inherit;}

::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-track{background:#F1F5F9;}
::-webkit-scrollbar-thumb{background:var(--blue);border-radius:4px;}

/* ═══ LAYOUT ═══ */
.container{max-width:1300px;margin:0 auto;padding:0 clamp(20px,5vw,64px);}
.section{padding:clamp(80px,10vw,140px) 0;position:relative;}

/* ════════════════════════════════
   THREE.JS FULL-PAGE CANVAS
   Covers entire page background
════════════════════════════════ */
#bg-canvas{
  position:fixed;
  top:0;left:0;
  width:100vw;height:100vh;
  z-index:0;
  pointer-events:none;
}

/* Everything on top of canvas */
#preloader,
#navbar,
.hero-section,
.ticker-wrap,
.services-section,
.stats-band,
.process-section,
.about-section,
.reviews-section,
.cities-section,
.contact-section,
.faq-section,
footer,
.wa-float,
.mob-menu{
  position:relative;
  z-index:1;
}

/* ════════════════════════════════
   ULTRA PREMIUM 3D TECH CURSOR
════════════════════════════════ */
#tech-cursor {
  position: fixed; z-index: 10000; pointer-events: none;
  left: 0; top: 0;
}
.tc-3d-volume {
  position: absolute;
  width: 52px; height: 52px;
  transform-style: preserve-3d;
  transform: translate(-50%, -50%);
  transition: width 0.3s var(--ease-out), height 0.3s var(--ease-out);
}
.tc-ring {
  position: absolute; inset: 0;
  border-radius: 50%;
  pointer-events: none;
}
.tc-gear {
  border: 1.5px dashed rgba(0, 149, 255, 0.4);
  animation: tcSpin 10s linear infinite;
}
.tc-glow {
  box-shadow: 0 0 20px rgba(0, 149, 255, 0.2), inset 0 0 10px rgba(0, 149, 255, 0.1);
  border: 1px solid rgba(0, 149, 255, 0.2);
  transform: translateZ(-2px);
  transition: all 0.3s;
}
.tc-core {
  position: absolute; inset: 10px;
  background: radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.9), rgba(240, 248, 255, 0.6));
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.8);
  box-shadow: 0 8px 16px rgba(0, 149, 255, 0.25), inset 0 -4px 12px rgba(0, 149, 255, 0.1);
  display: flex; align-items: center; justify-content: center;
  transform: translateZ(8px);
  color: var(--blue);
}
.tc-icon {
  width: 16px; height: 16px;
  position: absolute;
  opacity: 0; transform: scale(0.5);
  transition: all 0.4s var(--ease-spring);
}
.tc-icon.active {
  opacity: 1; transform: scale(1);
}
.tc-label {
  position: absolute;
  left: 35px; top: 0;
  transform: translateY(-50%);
  background: var(--black); color: #fff;
  font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  padding: 6px 16px; border-radius: 50px;
  opacity: 0; pointer-events: none;
  white-space: nowrap;
  box-shadow: 0 4px 16px rgba(0,0,0,0.15);
  transition: opacity 0.3s, transform 0.3s var(--ease-out);
}
@keyframes tcSpin { 100% { transform: rotate(360deg); } }

/* Hover States */
body.cursor-hover .tc-3d-volume {
  width: 64px; height: 64px;
}
body.cursor-hover .tc-glow {
  box-shadow: 0 0 30px rgba(0, 149, 255, 0.3), inset 0 0 15px rgba(0, 149, 255, 0.2);
  border-color: rgba(0, 149, 255, 0.4);
}
body.cursor-hover .tc-core {
  background: radial-gradient(circle at 30% 30%, rgba(0, 149, 255, 0.9), rgba(0, 80, 170, 0.9));
  color: white; border-color: rgba(255,255,255,0.4);
}
body.cursor-cta .tc-label {
  opacity: 1; transform: translateY(-50%) translateX(10px);
}
body.cursor-click .tc-3d-volume {
  transform: translate(-50%, -50%) scale(0.85);
}

/* Sparks Effects */
.tc-spark {
  position: fixed; z-index: 9999; pointer-events: none;
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--white);
  box-shadow: 0 0 8px var(--white), 0 0 16px var(--blue);
}

@media(pointer:coarse){
  #tech-cursor, #tc-sparks {display:none!important;}
  body {cursor:auto;}
  a,button,.svc-card,.rv-card {cursor:pointer;}
}

/* ═══ PRELOADER ═══ */
#preloader{
  position:fixed;inset:0;z-index:99999;
  background:#fff;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .8s var(--ease-out),visibility .8s;
}
#preloader.done{opacity:0;visibility:hidden;pointer-events:none;}
.pre-content{display:flex;flex-direction:column;align-items:center;gap:30px;}
.pre-logo{width:clamp(180px,28vw,260px);animation:prePulse 2.2s ease-in-out infinite;}
@keyframes prePulse{
  0%,100%{filter:drop-shadow(0 0 0 rgba(0,149,255,0));transform:scale(1);}
  50%{filter:drop-shadow(0 0 30px rgba(0,149,255,.6));transform:scale(1.03);}
}
.pre-bar-wrap{width:280px;height:3px;background:var(--gray-100);border-radius:3px;overflow:hidden;position:relative;}
.pre-bar-wrap::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);
  animation:shimBar 1.2s ease infinite;
}
@keyframes shimBar{from{transform:translateX(-100%)}to{transform:translateX(100%)}}
.pre-bar{width:0;height:100%;background:linear-gradient(90deg,var(--blue-dark),var(--blue),#5AC8FF);border-radius:3px;transition:width .08s linear;}
.pre-label{font-size:10px;letter-spacing:3.5px;text-transform:uppercase;color:var(--gray-500);font-weight:600;}

/* ═══ NAVBAR ═══ */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:box-shadow .4s,background .4s;
}
#navbar.scrolled{
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  box-shadow:0 1px 0 rgba(0,0,0,.07),0 4px 24px rgba(0,0,0,.05);
}
.nav-inner{
  max-width:1300px;margin:0 auto;
  padding:0 clamp(20px,5vw,64px);
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.logo-link{flex-shrink:0;display:flex;align-items:center;}
.logo-img{
  height:96px;width:auto;object-fit:contain;
  transition:transform .35s var(--ease-spring),filter .35s;
  filter:drop-shadow(0 2px 8px rgba(0,149,255,.15));
}
.logo-link:hover .logo-img{
  transform:scale(1.05);
  filter:drop-shadow(0 4px 20px rgba(0,149,255,.5));
}

.nav-links{display:flex;align-items:center;gap:4px;}
.nl{
  font-size:13.5px;font-weight:600;letter-spacing:.3px;
  color:var(--gray-700);padding:9px 18px;border-radius:50px;
  transition:all .25s;position:relative;
}
.nl::after{
  content:'';position:absolute;bottom:5px;left:50%;
  width:0;height:2px;background:var(--blue);
  transform:translateX(-50%);transition:width .3s var(--ease-out);
  border-radius:1px;
}
.nl:hover::after,.nl.active::after{width:55%;}
.nl:hover{color:var(--blue);}
.nl.active{color:var(--blue);}

.nav-right{display:flex;align-items:center;gap:14px;}
.nav-phone-btn{
  display:flex;align-items:center;gap:8px;
  font-size:13px;font-weight:600;color:var(--gray-700);
  padding:9px 18px;border-radius:50px;
  border:1.5px solid var(--gray-300);white-space:nowrap;
  transition:all .3s;
}
.nav-phone-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light);}

/* ═══ BUTTONS ═══ */
.btn-main{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--blue);color:#fff;
  font-family:var(--f-body);font-size:15px;font-weight:700;
  padding:14px 30px;border-radius:var(--r-btn);
  border:none;cursor: auto;white-space:nowrap;
  transition:all .35s var(--ease-out);
  box-shadow:var(--shadow-blue);
  position:relative;overflow:hidden;
}
.btn-main::before{content:'';position:absolute;inset:-2px;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 50%);border-radius:inherit;pointer-events:none;}
.btn-main:hover{background:var(--blue-dark);transform:translateY(-3px) scale(1.02);box-shadow:0 16px 48px rgba(0,149,255,.45);}
.btn-main:active{transform:translateY(-1px) scale(.99);}
.btn-xl{padding:18px 40px;font-size:17px;}

.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;
  background:transparent;color:var(--black);
  font-family:var(--f-body);font-size:15px;font-weight:600;
  padding:14px 30px;border-radius:var(--r-btn);
  border:2px solid var(--gray-300);cursor: auto;
  transition:all .35s;
}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue);background:rgba(0,149,255,.04);transform:translateY(-2px);}
.btn-ghost.btn-xl{padding:18px 40px;font-size:17px;}

/* Burger */
.burger-btn{display:none;flex-direction:column;gap:5px;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;border:1.5px solid var(--gray-300);background:#fff;cursor: auto;}
.burger-btn span{display:block;width:20px;height:1.5px;background:var(--black);border-radius:2px;transition:all .35s;}
.burger-btn.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.burger-btn.open span:nth-child(2){opacity:0;}
.burger-btn.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

/* Mobile menu */
.mob-menu{position:fixed;inset:0;z-index:990;background:#fff;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .45s,visibility .45s;}
.mob-menu.open{opacity:1;visibility:visible;pointer-events:all;}
.mob-menu-inner{display:flex;flex-direction:column;align-items:center;gap:12px;}
.mob-logo{width:190px;margin-bottom:30px;}
.mob-nav{display:flex;flex-direction:column;align-items:center;gap:4px;width:100%;}
.mob-nl{font-family:var(--f-head);font-size:clamp(30px,8vw,50px);font-weight:700;color:var(--black);padding:8px 0;cursor: auto;transition:color .25s;}
.mob-nl:hover{color:var(--blue);}
.mob-cta{margin-top:28px;}

/* Section headings */
.sec-tag{display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:700;letter-spacing:3.5px;text-transform:uppercase;color:var(--blue);margin-bottom:18px;}
.sec-tag::before{content:'';display:block;width:28px;height:2px;background:var(--blue);border-radius:2px;}
.sec-title{font-family:var(--f-head);font-size:clamp(38px,5vw,70px);font-weight:700;line-height:1.05;color:var(--black);margin-bottom:18px;letter-spacing:-.02em;}
.sec-title em{font-style:italic;color:var(--blue);font-weight:500;}
.sec-sub{font-size:clamp(15px,1.6vw,18px);line-height:1.75;color:var(--gray-500);max-width:600px;}

.section-header{margin-bottom:clamp(48px,6vw,80px);}
.section-header.centered{text-align:center;}
.section-header.centered .sec-tag{justify-content:center;}
.section-header.centered .sec-sub{margin:0 auto;}
.section-footer{text-align:center;margin-top:54px;display:flex;flex-direction:column;align-items:center;gap:18px;}
.section-footer p{color:var(--gray-500);font-size:15px;}

/* ═══ HERO ═══ */
.hero-section{
  position:relative;
  min-height:100svh;
  padding-top:calc(var(--nav-h) + 80px);
  padding-bottom:60px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(170deg,rgba(250,250,249,.8) 0%,rgba(240,248,255,.85) 50%,rgba(228,243,255,.9) 100%);
  overflow:hidden;
}
.hero-section::before{
  content:'';position:absolute;inset:0;z-index:0;
  background-image:radial-gradient(rgba(0,149,255,.1) 1px,transparent 1px);
  background-size:24px 24px;pointer-events:none;
  mask-image: linear-gradient(to bottom, black 40%, transparent 100%);
  -webkit-mask-image: linear-gradient(to bottom, black 40%, transparent 100%);
}

.hero-content-wrapper{
  position:relative;z-index:2;
  width:100%;max-width:1400px;margin:0 auto;
  padding:40px clamp(20px,5vw,64px) 80px;
  display:flex;flex-direction:column;align-items:center;text-align:center;
  overflow:hidden;
}

.hero-badge{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:700;letter-spacing:1.5px;color:var(--blue);background:var(--blue-light);border:1.5px solid rgba(0,149,255,.2);padding:9px 24px;border-radius:50px;margin-bottom:34px;box-shadow:0 12px 24px rgba(0,149,255,.15);}
.badge-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);flex-shrink:0;animation:bdot 2s ease infinite;}
@keyframes bdot{0%,100%{box-shadow:0 0 0 0 rgba(0,149,255,.5);}50%{box-shadow:0 0 0 8px rgba(0,149,255,0);}}

.hero-h1{font-family:var(--f-head);font-size:clamp(42px, 8vw, 110px);font-weight:700;line-height:1.05;color:var(--black);letter-spacing:-.03em;margin-bottom:28px;perspective:1000px;}
.word3d{display:inline-block;transform-style:preserve-3d;will-change:transform,opacity;}
.hero-h1 em{display:inline-block;font-style:italic;color:var(--gray-700);font-weight:400;position:relative;z-index:1;}
.h1-blue{color:var(--blue);}

.svg-envelope{position:relative;display:inline-block;}
.hand-drawn-circle{
  position:absolute;
  top:-30%; left:-10%;
  width:120%; height:160%;
  pointer-events:none;
  z-index:0;
  color:var(--blue);
  opacity:0.8;
}
.circle-path{
  stroke-dasharray:4000;
  stroke-dashoffset:4000;
}

.hero-para{font-size:clamp(16px,1.8vw,20px);line-height:1.8;color:var(--gray-500);max-width:700px;margin:0 auto 44px;}
.hero-actions{display:flex;justify-content:center;gap:20px;flex-wrap:wrap;margin-bottom:70px;}
.hero-actions .btn-main, .hero-actions .btn-ghost{padding:20px 48px;font-size:18px;}

/* Centered visual showcase */
.hero-visual-showcase{
  position:relative;width:100%;max-width:780px;margin:0 auto;
  perspective:1500px;
}
.hero-image-glass{
  position:relative;z-index:2;
  border-radius: 28px;
  padding:20px;
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border:2px solid rgba(0,0,0,0.05);
  box-shadow: 0 0 100px rgba(0,0,0,.08), 0 37px 50px rgba(0,0,0,.1), 0 149px 60px rgba(0,0,0,.05), 0 233px 65px rgba(0,0,0,.02);
  transform-style:preserve-3d;
  will-change:transform;
}
.hero-main-img{width:100%;border-radius:18px;display:block;}

.glow-ring{position:absolute;border-radius:50%;pointer-events:none;z-index:1;}
.r1{width:500px;height:500px;top:-20%;left:-15%;background:radial-gradient(circle,rgba(0,149,255,.15) 0%,transparent 70%);}
.r2{width:400px;height:400px;bottom:-10%;right:-10%;background:radial-gradient(circle,rgba(90,200,255,.15) 0%,transparent 70%);}

.float-card{position:absolute;z-index:10;background:rgba(255,255,255,.94);backdrop-filter:blur(24px) saturate(200%);-webkit-backdrop-filter:blur(24px) saturate(200%);border:1px solid rgba(255,255,255,.8);border-radius:24px;padding:18px 24px;box-shadow:0 20px 50px rgba(0,0,0,.15),0 0 0 1px rgba(0,149,255,.1) inset;display:flex;gap:16px;align-items:center;min-width:230px;color:var(--black);text-align:left;}
.float-card strong{display:block;font-size:15px;font-weight:700;}
.float-card p{font-size:13px;color:var(--gray-500);margin-top:2px;}
.fc-icon{width:46px;height:46px;border-radius:14px;flex-shrink:0;display:flex;align-items:center;justify-content:center;}

.fc-1{top:12%;left:-6%;animation:floatY 6s ease-in-out infinite;}
.fc-2{bottom:-6%;right:-4%;animation:floatY 7s ease-in-out infinite 1s;}
.fc-3{top:18%;right:-8%;animation:floatY 5.5s ease-in-out infinite .5s;flex-direction:column;gap:6px;align-items:flex-start;min-width:210px;}
.stars-row{color:#F59E0B;font-size:18px;letter-spacing:1.5px;}
.fc-3 p{font-size:14px;font-style:italic;color:var(--gray-700);}
.fc-3 small{font-size:12px;color:var(--gray-500);}

@keyframes floatY{0%,100%{transform:translateY(0) rotate(0deg);}50%{transform:translateY(-16px) rotate(1deg);}}

.scroll-cue{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;z-index:1;color:var(--gray-500);font-size:10px;letter-spacing:2.5px;text-transform:uppercase;}
.scroll-mouse{width:26px;height:42px;border-radius:13px;border:2px solid var(--gray-300);display:flex;justify-content:center;padding-top:8px;}
.scroll-wheel{width:3px;height:8px;border-radius:3px;background:var(--blue);animation:swh 1.8s ease-in-out infinite;}
@keyframes swh{0%{opacity:1;transform:translateY(0);}100%{opacity:0;transform:translateY(14px);}}

/* ═══ TICKER ═══ */
.ticker-wrap{overflow:hidden;background:var(--blue);padding:16px 0;}
.ticker-track{display:flex;width:max-content;animation:tickScroll 35s linear infinite;}
.ticker-track:hover{animation-play-state:paused;}
.ticker-set{display:flex;align-items:center;}
.ticker-set span{display:inline-flex;align-items:center;font-size:12.5px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.9);padding:0 22px;}
.ticker-set .td{font-size:8px;color:rgba(255,255,255,.45);}
@keyframes tickScroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ═══ SERVICES ═══ */
.services-section{background:rgba(248,250,255,.92);}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;perspective:1500px;transform-style:preserve-3d;}

/* Premium Glass & 3D Base */
.svc-card{
  background:rgba(255,255,255,0.7);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border-radius:var(--r-card);
  border:1px solid rgba(255,255,255,0.9);
  transition:box-shadow .4s, border-color .4s;
  cursor: auto;
  transform-style:preserve-3d;
  will-change:transform;
}

/* Base Shadow when hovering the 3D element */
.svc-card:hover{
  border-color:rgba(0,149,255,.4);
  box-shadow:0 40px 100px rgba(0,149,255,.15), inset 0 2px 20px rgba(255,255,255,.5);
}

/* Card Top clipping */
.svc-card-top{position:relative;height:210px;overflow:hidden;display:flex;align-items:center;justify-content:center;border-radius:calc(var(--r-card) - 1px) calc(var(--r-card) - 1px) 0 0;transform-style:preserve-3d;}

/* Pushed back Image */
.svc-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:1;transition:transform .6s var(--ease-out);transform:translateZ(-10px) scale(1.02);}
.svc-card:hover .svc-img{transform:translateZ(-5px) scale(1.08);}

/* Premium Corners - Elegant Floating Icon */
.svc-icon-floating{position:absolute;top:16px;right:16px;z-index:5;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.85);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(0,0,0,.15);border:1px solid rgba(255,255,255,.7);transform:translateZ(40px);transition:transform .4s var(--ease-spring), box-shadow .4s;}
.svc-card:hover .svc-icon-floating{transform:translateZ(75px) scale(1.15) rotate(10deg);box-shadow:0 16px 36px rgba(0,149,255,.3);}

/* Floating Body Layer */
.svc-card-body{padding:24px 28px 28px;transform-style:preserve-3d;transform:translateZ(40px);}
.svc-tag-row{margin-bottom:12px;min-height:24px;transform:translateZ(10px);}
.svc-badge{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 12px;border-radius:50px;background:var(--blue-light);color:var(--blue);border:1px solid rgba(0,149,255,.15);}
.svc-badge.most-booked{background:#ECFDF5;color:#065F46;border-color:rgba(34,197,94,.2);}
.svc-badge.emergency{background:#FEF2F2;color:#B91C1C;border-color:rgba(220,38,38,.2);}
.svc-badge.premium{background:#F5F3FF;color:#5B21B6;border-color:rgba(124,58,237,.2);}

.svc-card h3{font-family:var(--f-head);font-size:23px;font-weight:700;color:var(--black);margin-bottom:10px;transform:translateZ(20px);}
.svc-card p{font-size:14px;line-height:1.7;color:var(--gray-500);margin-bottom:20px;transform:translateZ(5px);}

.svc-footer-row{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid var(--gray-100);transform:translateZ(15px);}
.svc-price{font-family:var(--f-head);font-size:19px;font-weight:700;color:var(--black);}
.svc-cta-link{font-size:13px;font-weight:700;color:var(--blue);transition:letter-spacing .3s;}
.svc-cta-link:hover{letter-spacing:.5px;}

/* ═══ STATS BAND ═══ */
.stats-band{background:var(--blue);}
.stats-band-grid{display:grid;grid-template-columns:repeat(4,1fr);}
.sb-item{padding:clamp(40px,5vw,60px) 24px;text-align:center;border-right:1px solid rgba(255,255,255,.12);transition:background .3s;position:relative;overflow:hidden;}
.sb-item::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(255,255,255,.06) 0%,transparent 70%);}
.sb-item:last-child{border-right:none;}
.sb-item:hover{background:rgba(255,255,255,.08);}
.sb-num{display:block;font-family:var(--f-head);font-size:clamp(38px,5vw,66px);font-weight:700;color:#fff;line-height:1;}
.sb-item>span{font-size:11.5px;color:rgba(255,255,255,.65);margin-top:8px;display:block;text-transform:uppercase;letter-spacing:1.5px;}

/* ═══ HOW IT WORKS ═══ */
.process-section{background:rgba(255,255,255,.92);}
.process-steps{position:relative;display:flex;flex-direction:column;gap:0;}
.process-line{position:absolute;left:40px;top:70px;bottom:70px;width:2px;background:linear-gradient(180deg,var(--blue) 0%,rgba(0,149,255,.1) 100%);z-index:0;}
.ps-item{display:flex;align-items:center;gap:36px;padding:28px 0;position:relative;z-index:1;}
.ps-item.ps-right{flex-direction:row-reverse;}
.ps-num{width:82px;height:82px;border-radius:50%;flex-shrink:0;background:#fff;border:2.5px solid var(--blue);display:flex;align-items:center;justify-content:center;font-family:var(--f-head);font-size:24px;font-weight:700;color:var(--blue);box-shadow:0 0 0 8px rgba(0,149,255,.08),var(--shadow-blue);}
.ps-card{background:rgba(248,250,255,.95);border:1.5px solid var(--border);border-radius:var(--r-card);padding:34px 38px;flex:1;transition:all .4s var(--ease-out);}
.ps-card:hover{border-color:rgba(0,149,255,.2);box-shadow:0 16px 48px rgba(0,0,0,.08);transform:translateX(5px);}
.ps-item.ps-right .ps-card:hover{transform:translateX(-5px);}
.ps-icon-wrap{width:58px;height:58px;border-radius:18px;background:rgba(0,149,255,.08);border:1.5px solid rgba(0,149,255,.2);display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:all .4s var(--ease-spring);}
.ps-card:hover .ps-icon-wrap{background:rgba(0,149,255,.15);transform:scale(1.1) rotate(8deg);}
.ps-card h3{font-family:var(--f-head);font-size:28px;font-weight:700;color:var(--black);margin-bottom:10px;}
.ps-card p{font-size:15px;line-height:1.75;color:var(--gray-500);}

/* ═══ ABOUT ═══ */
.about-section{background:linear-gradient(140deg,rgba(250,250,249,.92) 0%,rgba(240,248,255,.9) 100%);}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center;}
.about-img-frame{position:relative;border-radius:28px;}
.about-glow{position:absolute;inset:-30px;background:radial-gradient(circle at 40% 40%,rgba(0,149,255,.13) 0%,transparent 65%);pointer-events:none;z-index:0;}
.about-img{width:100%;border-radius:26px;box-shadow:0 30px 80px rgba(0,0,0,.14);position:relative;z-index:2;}
.about-badge-card{position:absolute;top:5%;right:-6%;z-index:10;background:var(--blue);color:#fff;border-radius:20px;padding:20px 24px;display:flex;gap:14px;align-items:center;min-width:210px;box-shadow:0 16px 40px rgba(0,149,255,.4);animation:floatY 6s ease-in-out infinite;}
.abc-circle{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.about-badge-card strong{display:block;font-size:14px;font-weight:700;}
.about-badge-card span{font-size:12px;opacity:.75;}
.about-exp-card{position:absolute;bottom:-5%;left:-6%;z-index:10;background:#fff;border:1.5px solid var(--border);border-radius:20px;padding:18px 26px;box-shadow:0 24px 60px rgba(0,0,0,.1);animation:floatY 7s ease-in-out infinite .8s;}
.about-exp-card strong{display:block;font-family:var(--f-head);font-size:28px;font-weight:700;color:var(--black);}
.about-exp-card span{font-size:12px;color:var(--gray-500);text-transform:uppercase;letter-spacing:1px;}

.about-para{font-size:16px;line-height:1.85;color:var(--gray-500);margin-bottom:36px;}
.why-list{display:flex;flex-direction:column;gap:20px;margin-bottom:36px;}
.why-item{display:flex;gap:16px;align-items:flex-start;}
.why-icon{width:40px;height:40px;border-radius:12px;flex-shrink:0;background:var(--blue-light);border:1.5px solid rgba(0,149,255,.2);display:flex;align-items:center;justify-content:center;margin-top:2px;transition:all .35s var(--ease-spring);}
.why-item:hover .why-icon{background:var(--blue);}
.why-item:hover .why-icon svg{stroke:#fff;}
.why-item strong{display:block;font-size:16px;font-weight:700;color:var(--black);margin-bottom:4px;}
.why-item p{font-size:14px;line-height:1.65;color:var(--gray-500);}
.why-mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.why-mini{background:#fff;border:1.5px solid var(--border);border-radius:18px;padding:20px 16px;text-align:center;transition:all .35s var(--ease-out);}
.why-mini:hover{border-color:var(--blue);transform:translateY(-4px);box-shadow:var(--shadow-card);}
.why-mini strong{display:block;font-family:var(--f-head);font-size:26px;font-weight:700;color:var(--blue);}
.why-mini span{font-size:11px;color:var(--gray-500);text-transform:uppercase;letter-spacing:1px;}

/* ═══════════════════════════════════
   CINEMATIC APP SHOWCASE
═══════════════════════════════════ */
.cinematic-wrapper {
  position: relative;
  width: 100vw;
  height: 100vh;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(248,250,255,.92);
  perspective: 1500px;
}

.bg-grid-theme {
  position: absolute; inset: 0; z-index: 0; pointer-events: none; opacity: 0.5;
  background-size: 60px 60px;
  background-image: 
      linear-gradient(to right, rgba(0,149,255,0.06) 1px, transparent 1px),
      linear-gradient(to bottom, rgba(0,149,255,0.06) 1px, transparent 1px);
  mask-image: radial-gradient(ellipse at center, black 0%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 0%, transparent 70%);
}

.gsap-reveal { visibility: hidden; }

/* The Foreground Card */
.main-card {
  position: absolute;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  width: 85vw;
  height: 85vh;
  border-radius: 40px;
  background: linear-gradient(145deg, #0A101D 0%, #162C6D 100%);
  box-shadow: 
      0 40px 100px -20px rgba(0, 0, 0, 0.9),
      0 20px 40px -20px rgba(0, 0, 0, 0.8),
      inset 0 1px 2px rgba(255, 255, 255, 0.2),
      inset 0 -2px 4px rgba(0, 0, 0, 0.8);
  border: 1px solid rgba(255, 255, 255, 0.04);
}

.card-sheen {
  position: absolute; inset: 0; border-radius: inherit; pointer-events: none; z-index: 50;
  background: radial-gradient(800px circle at var(--mouse-x, 50%) var(--mouse-y, 50%), rgba(255,255,255,0.08) 0%, transparent 40%);
  mix-blend-mode: screen; transition: opacity 0.3s ease;
}

/* Background Texts */
.hero-text-wrapper, .cta-wrapper {
  position: absolute; z-index: 10;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; width: 100%; padding: 0 20px;
}
.cta-wrapper h2 { font-size: 5rem; font-family: var(--f-head); font-weight: 800; line-height: 1.1; margin-bottom: 24px; color: var(--black); }
.cta-wrapper p { font-size: 1.25rem; color: var(--gray-700); max-width: 600px; margin-bottom: 40px; }

.text-track, .text-days {
  color: var(--black);
  font-family: var(--f-head);
  font-weight: 800;
  letter-spacing: -2px;
  line-height: 1.1;
}
.text-track { font-size: 5rem; text-shadow: 0 10px 30px rgba(0,149,255,0.2); }
.text-days { font-size: 6.5rem; background: linear-gradient(180deg, var(--blue) 0%, var(--black) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }

/* Flex Layout for Card Interior */
.card-interior {
  position: relative; width: 100%; height: 100%;
  max-width: 1200px;
  display: grid; grid-template-columns: 1fr 1fr 1fr; align-items: center; gap: 40px;
  z-index: 10;
}
.card-left-text { width: 100%; text-align: left; padding-left: 20px; }
.card-left-text h3 {
  color: #fff; font-family: var(--f-head); font-size: 42px; font-weight: 700; line-height: 1.1; margin-bottom: 12px;
}
.card-left-text p {
  color: rgba(255,255,255,0.7); font-size: 16px; line-height: 1.6;
}

.card-right-text { width: 100%; text-align: right; padding-right: 20px; }
.card-right-text h2 {
  font-family: var(--f-head); font-size: 5.5rem; font-weight: 900; line-height: 1.1; text-transform: uppercase;
  background: linear-gradient(180deg, #FFFFFF 0%, #A1A1AA 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  filter: drop-shadow(0px 12px 24px rgba(0,0,0,0.8));
}

.mockup-scroll-wrapper {
  position: relative; width: 100%; height: 600px;
  display: flex; align-items: center; justify-content: center; z-index: 10;
  perspective: 1000px;
}

.iphone-bezel {
  background-color: #111;
  width: 280px; height: 580px; border-radius: 46px; position: relative;
  box-shadow: inset 0 0 0 2px #52525B, inset 0 0 0 7px #000, 0 40px 80px -15px rgba(0,0,0,0.9), 0 15px 25px -5px rgba(0,0,0,0.7);
  transform-style: preserve-3d;
}
.hardware-btn {
  background: linear-gradient(90deg, #404040 0%, #171717 100%);
  position: absolute;
  box-shadow: -2px 0 5px rgba(0,0,0,0.8), inset -1px 0 1px rgba(255,255,255,0.15), inset 1px 0 2px rgba(0,0,0,0.8);
  border-left: 1px solid rgba(255,255,255,0.05);
}
.btn-1 { top: 120px; left: -3px; width: 3px; height: 25px; border-radius: 3px 0 0 3px; }
.btn-2 { top: 160px; left: -3px; width: 3px; height: 45px; border-radius: 3px 0 0 3px; }
.btn-3 { top: 220px; left: -3px; width: 3px; height: 45px; border-radius: 3px 0 0 3px; }
.btn-4 { top: 170px; right: -3px; width: 3px; height: 70px; border-radius: 0 3px 3px 0; }

.screen-glare {
  background: linear-gradient(110deg, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0) 45%); position: absolute; inset: 0; pointer-events: none; z-index: 40;
}
.dynamic-island {
  position: absolute; top: 12px; left: 50%; transform: translateX(-50%); width: 100px; height: 28px; background: #000; border-radius: 50px; z-index: 50; box-shadow: inset 0 -1px 2px rgba(255,255,255,0.1);
}

.floating-badge {
  position: absolute; z-index: 30; display: flex; align-items: center; gap: 12px; padding: 12px 18px; border-radius: 16px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.01) 100%);
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.1), 0 25px 50px -12px rgba(0, 0, 0, 0.8), inset 0 1px 1px rgba(255,255,255,0.2), inset 0 -1px 1px rgba(0,0,0,0.5);
}
.floating-badge p { color: #fff; font-size: 14px; font-weight: 700; margin:0;}
.floating-badge span { color: rgba(255,255,255,0.5); font-size: 11px; font-weight: 500; }
.fb-icon { width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 20px; box-shadow: inset 0 2px 5px rgba(255,255,255,0.1); }
.fb-icon.blue { background: linear-gradient(180deg, rgba(0,149,255,0.2) 0%, rgba(0,149,255,0.05) 100%); border: 1px solid rgba(0,149,255,0.3); }
.fb-icon.green { background: linear-gradient(180deg, rgba(22,163,74,0.2) 0%, rgba(22,163,74,0.05) 100%); border: 1px solid rgba(22,163,74,0.3); }

.btn-modern-dark {
  background: linear-gradient(180deg, #27272A 0%, #18181B 100%);
  color: #FFFFFF; border-radius: 20px; padding: 14px 30px; display: flex; align-items: center; gap: 14px; text-decoration: none;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.1), 0 2px 4px rgba(0,0,0,0.6), 0 12px 24px -4px rgba(0,0,0,0.9), inset 0 1px 1px rgba(255,255,255,0.15), inset 0 -3px 6px rgba(0,0,0,0.8);
  transition: all 0.4s var(--ease-out);
}
.btn-modern-dark:hover { transform: translateY(-3px); box-shadow: 0 0 0 1px rgba(255,255,255,0.15), 0 6px 12px -2px rgba(0,0,0,0.7), 0 20px 32px -6px rgba(0,0,0,1), inset 0 1px 1px rgba(255,255,255,0.2), inset 0 -3px 6px rgba(0,0,0,0.8); }
.cta-row-flex { display: flex; gap: 20px; align-items: center; justify-content: center; }

/* Phone interior dummy UI */
.phone-ui-canvas { position: absolute; inset: 7px; background: #050914; border-radius: 40px; overflow: hidden; color: #fff; padding: 50px 20px 20px; box-shadow: inset 0 0 15px #000; }
.phone-widget { background: linear-gradient(180deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0.01) 100%); border: 1px solid rgba(255,255,255,0.03); border-radius: 16px; padding: 12px; margin-bottom: 12px; box-shadow: inset 0 1px 1px rgba(255,255,255,0.05), inset 0 -1px 1px rgba(0,0,0,0.5); }
.widget-flex { display: flex; align-items: center; gap: 12px; }
.w-icon { width: 40px; height: 40px; border-radius: 12px; background: rgba(0,149,255,0.1); display: flex; align-items: center; justify-content: center; color: var(--blue); }
.w-bar1 { height: 6px; width: 80px; background: #ddd; border-radius: 10px; margin-bottom: 8px; }
.w-bar2 { height: 4px; width: 40px; background: #666; border-radius: 10px; }
.app-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 30px; }
.app-header span { font-size: 24px; font-weight: 800; font-family: var(--f-head); }
.app-avatar { width: 36px; height: 36px; border-radius: 50%; background: rgba(255,255,255,0.1); display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; border: 1px solid rgba(255,255,255,0.1); }
.home-indicator { position: absolute; bottom: 8px; left: 50%; transform: translateX(-50%); width: 120px; height: 4px; background: rgba(255,255,255,0.4); border-radius: 10px; }

@media (max-width: 991px) {
  .card-interior { display: flex; flex-direction: column; justify-content: space-evenly; gap: 0px; }
  .card-right-text { order: 1; text-align: center; padding: 0; }
  .card-right-text h2 { font-size: 3rem; }
  .mockup-scroll-wrapper { order: 2; height: 380px; transform: scale(0.85); }
  .card-left-text { order: 3; text-align: center; padding: 0; margin-top: -20px; }
  .card-left-text h3 { font-size: 24px; }
  .card-left-text p { display: none; }
  .text-track { font-size: 2.8rem; }
  .text-days { font-size: 3.5rem; }
  .cta-wrapper h2 { font-size: 2.8rem; }
  .cta-row-flex { flex-direction: column; width: 100%; padding: 0 40px; }
  .cta-row-flex a { width: 100%; justify-content: center; }
}

/* ═══ 3D REVIEWS MARQUEE ═══ */
.reviews-section{background:rgba(248,250,255,.92);overflow:hidden;}
.overall-bar{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:20px;flex-wrap:wrap;}
.ob-stars{color:#F59E0B;font-size:24px;letter-spacing:2px;}
.ob-num{font-family:var(--f-head);font-size:52px;font-weight:700;color:var(--black);line-height:1;}
.ob-meta{font-size:14px;color:var(--gray-500);}

/* The Master Container */
.reviews-3d-wrapper {
  position: relative;
  display: flex;
  height: 600px;
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-radius: 20px;
  perspective: 1200px;
}

/* Gradient Masks */
.reviews-3d-wrapper::before,
.reviews-3d-wrapper::after {
  content: '';
  position: absolute;
  left: -10%;
  right: -10%;
  height: 25%;
  z-index: 10;
  pointer-events: none;
}
.reviews-3d-wrapper::before {
  top: 0;
  background: linear-gradient(to bottom, rgba(248,250,255,1) 0%, rgba(248,250,255,0) 100%);
}
.reviews-3d-wrapper::after {
  bottom: 0;
  background: linear-gradient(to top, rgba(248,250,255,1) 0%, rgba(248,250,255,0) 100%);
}

/* 3D Matrix Container */
.reviews-matrix {
  display: flex;
  gap: 20px;
  transform-style: preserve-3d;
  /* Exactly matching the React Demo Matrix */
  transform: translateX(-50px) translateY(0px) translateZ(-100px) rotateX(20deg) rotateY(-10deg) rotateZ(20deg) scale(1.1);
}

.reviews-matrix:hover .marquee-col {
  animation-play-state: paused;
}

/* Marquee Columns */
.marquee-col {
  display: flex;
  flex-direction: column;
  gap: 20px;
  width: 280px;
  will-change: transform;
}
.marquee-col.down { animation: marquee-down 40s linear infinite; }
.marquee-col.up { animation: marquee-up 40s linear infinite; }

@keyframes marquee-down {
  0% { transform: translateY(calc(-50% - 10px)); }
  100% { transform: translateY(0); }
}
@keyframes marquee-up {
  0% { transform: translateY(0); }
  100% { transform: translateY(calc(-50% - 10px)); }
}

/* Rebuilt Glass Cards */
.rv-card{
  background:rgba(255,255,255,.7);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border-radius:var(--r-card);
  border:1px solid rgba(255,255,255,.9);
  padding:24px;
  display:flex;flex-direction:column;gap:12px;
  transition:all .3s var(--ease-out);
  box-shadow: 0 10px 30px rgba(0,0,0,0.05);
  cursor: auto;
}
.rv-card:hover{
  border-color:rgba(0,149,255,.4);
  box-shadow: 0 20px 50px rgba(0,149,255,.15);
  transform: translateY(-4px) scale(1.02) !important;
}
.rv-author{display:flex;align-items:center;gap:12px;}
.rv-avatar{width:42px;height:42px;border-radius:50%;object-fit:cover;border:2px solid #fff;box-shadow:0 4px 10px rgba(0,0,0,0.1);}
.rv-author strong{display:block;font-size:13.5px;font-weight:700;color:var(--black);}
.rv-author span{font-size:11.5px;color:var(--gray-500);}
.rv-text{font-size:13.5px;line-height:1.7;color:var(--gray-700);}

/* ═══ CITIES ═══ */
.cities-section{background:rgba(255,255,255,.92);}
.cities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:14px;perspective:1000px;}
.city-item{background:rgba(255,255,255,.7);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border:1.5px solid rgba(255,255,255,.9);border-radius:14px;padding:18px 20px;display:flex;align-items:center;gap:12px;font-size:15px;font-weight:600;color:var(--gray-700);box-shadow:0 10px 20px rgba(0,0,0,.04);transform-style:preserve-3d;transition:all .4s var(--ease-spring);}
.city-item:hover{border-color:rgba(0,149,255,.4);color:var(--blue);background:rgba(255,255,255,0.95);transform:translateY(-8px) scale(1.05) translateZ(30px) rotateX(10deg);box-shadow:0 20px 40px rgba(0,149,255,.15);}
.city-item svg { transform: translateZ(15px); }
.city-more{background:var(--blue);color:#fff;border-color:var(--blue);justify-content:center;font-style:italic;}

/* ═══ CONTACT / FORM ═══ */
.contact-section{background:rgba(248,250,255,.92);}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(40px,6vw,80px);align-items:start;}
.contact-desc{font-size:16px;line-height:1.8;color:var(--gray-500);margin-bottom:36px;}
.contact-items{display:flex;flex-direction:column;gap:18px;margin-bottom:36px;}
.ci{display:flex;gap:16px;align-items:flex-start;}
.ci-icon{width:46px;height:46px;border-radius:14px;flex-shrink:0;background:var(--blue-light);border:1.5px solid rgba(0,149,255,.2);display:flex;align-items:center;justify-content:center;}
.ci strong{display:block;font-size:14px;font-weight:700;color:var(--black);margin-bottom:2px;}
.ci span{font-size:14px;color:var(--gray-500);}
.trust-badges{display:flex;flex-direction:column;gap:12px;}
.tb{display:flex;align-items:center;gap:12px;font-size:14px;font-weight:600;color:var(--gray-700);}

.contact-form-wrap{perspective:1500px;}
.booking-form{background:rgba(255,255,255,.75);backdrop-filter:blur(30px) saturate(200%);-webkit-backdrop-filter:blur(30px) saturate(200%);border-radius:28px;border:1.5px solid rgba(255,255,255,1);padding:clamp(28px,4vw,50px);transform-style:preserve-3d;transform:rotateY(-6deg) rotateX(3deg);box-shadow:0 30px 80px rgba(0,0,0,.08);transition:all .6s var(--ease-spring);}
.booking-form:hover{transform:rotateY(0deg) rotateX(0deg) scale(1.02);box-shadow:0 50px 100px rgba(0,149,255,.15);border-color:rgba(0,149,255,.2);}
.booking-form .form-row, .booking-form .form-group, .booking-form .btn-form-submit { transform: translateZ(40px); }

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{margin-bottom:18px;transform-style:preserve-3d;}
.form-group label{display:block;font-size:12.5px;font-weight:700;color:var(--gray-700);margin-bottom:7px;letter-spacing:.3px;transform:translateZ(10px);}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:13px 16px;background:rgba(255,255,255,0.8);color:var(--black);border:1.5px solid rgba(0,0,0,0.06);border-radius:14px;font-size:15px;outline:none;transition:all .3s;appearance:none;transform:translateZ(20px);box-shadow:inset 0 2px 4px rgba(0,0,0,0.02);}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,149,255,.1), inset 0 2px 4px rgba(0,0,0,0.02);background:#fff;transform:translateZ(30px) scale(1.02);}
.form-group textarea{resize:vertical;min-height:100px;}
.btn-form-submit{width:100%;justify-content:center;font-size:17px;padding:18px;border-radius:16px;margin-bottom:12px;box-shadow: 0 15px 30px rgba(0,149,255,0.3);}
.btn-form-submit:hover{transform:translateZ(50px) translateY(-4px);box-shadow: 0 20px 40px rgba(0,149,255,0.4);}
.form-note{text-align:center;font-size:12px;color:var(--gray-500);transform:translateZ(10px);}

/* ═══ FAQ ═══ */
.faq-section{background:rgba(255,255,255,.92);}
.faq-layout{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(40px,6vw,80px);align-items:start;}
.faq-left{position:sticky;top:110px;}
.faq-left p{font-size:15px;color:var(--gray-500);margin-top:16px;line-height:1.7;}
.faq-list{display:flex;flex-direction:column;gap:16px;perspective:1000px;}
.faq-item{position:relative;z-index:1;background:rgba(255,255,255,.7);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border:1px solid rgba(255,255,255,0.9);border-radius:20px;box-shadow:0 10px 20px rgba(0,0,0,0.03);transform-style:preserve-3d;transform-origin:top center;transition:all .5s var(--ease-spring);}
.faq-item:hover{z-index:5;border-color:rgba(0,149,255,.2);transform:translateZ(20px) scale(1.02);box-shadow:0 20px 40px rgba(0,149,255,.08);}
.faq-item.open{z-index:10;border-color:rgba(0,149,255,.4);background:rgba(255,255,255,1);transform:translateZ(40px) scale(1.04);box-shadow:0 30px 60px rgba(0,149,255,.15);}
.faq-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:26px 28px;gap:16px;cursor: auto;background:transparent;transform-style:preserve-3d;}
.faq-btn span{font-size:16px;font-weight:700;color:var(--black);text-align:left;line-height:1.4;transform:translateZ(15px);}
.faq-arr{width:34px;height:34px;border-radius:50%;flex-shrink:0;background:#fff;border:1.5px solid var(--gray-200);display:flex;align-items:center;justify-content:center;color:var(--gray-500);transform:translateZ(20px);transition:all .4s var(--ease-spring);box-shadow:0 4px 10px rgba(0,0,0,0.05);}
.faq-item.open .faq-arr{background:var(--blue);border-color:var(--blue);color:#fff;transform:translateZ(30px) rotate(180deg);box-shadow:0 10px 20px rgba(0,149,255,.3);}
.faq-body{max-height:0;overflow:hidden;transform-style:preserve-3d;transition:max-height .5s var(--ease-out);}
.faq-body p{padding:0 28px 26px;font-size:15px;line-height:1.8;color:var(--gray-600);transform:translateZ(10px);}

/* ═══ PREMIUM FOOTER (LIGHT 3D THEME) ═══ */
.site-footer {
  background: #FAFAF9; /* Premium light white/gray */
  position: relative;
  overflow: hidden;
  margin-top: 120px;
  border-top: 1px solid rgba(0,0,0,0.04);
}
.footer-cta {
  position: relative;
  z-index: 10;
  margin-top: -60px; /* Pulls it up slightly out of the footer */
  margin-bottom: 50px;
  perspective: 1000px; /* Enable 3D space */
}
.cta-inner {
  background: linear-gradient(135deg, #ffffff, #f4f4f5);
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 32px;
  padding: clamp(40px, 6vw, 70px) 20px;
  text-align: center;
  box-shadow: 0 40px 100px rgba(0,0,0,0.06);
  transform: rotateX(3deg) translateY(0);
  transition: transform 0.6s var(--ease-spring), box-shadow 0.6s var(--ease-spring);
  transform-style: preserve-3d;
}
.cta-inner:hover {
  transform: rotateX(0deg) translateY(-10px) scale(1.02);
  box-shadow: 0 60px 120px rgba(0,149,255,0.15);
}
.cta-inner h2 {
  font-family: var(--f-head);
  font-size: clamp(28px, 4vw, 42px);
  color: var(--black);
  margin-bottom: 14px;
  letter-spacing: -0.5px;
  transform: translateZ(30px);
}
.cta-inner p {
  color: var(--gray-600);
  font-size: 16px;
  margin-bottom: 34px;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
  transform: translateZ(20px);
}
.cta-footer-btn {
  background: var(--blue);
  color: #fff;
  border-color: var(--blue);
  padding: 16px 36px;
  font-size: 16px;
  box-shadow: 0 10px 30px rgba(0, 149, 255, 0.3);
  transform: translateZ(40px);
}
.cta-footer-btn:hover {
  transform: translateZ(40px) translateY(-3px) scale(1.05);
  box-shadow: 0 15px 40px rgba(0, 149, 255, 0.4);
}

.footer-top {
  padding: 20px 0 60px;
  position: relative;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 50px;
}
.footer-brand-col .footer-logo {
  width: 180px;
  margin-bottom: 24px;
  filter: none; /* Original colored logo */
}
.footer-brand-col p {
  font-size: 14.5px;
  line-height: 1.8;
  color: var(--gray-600);
  max-width: 290px;
  margin-bottom: 28px;
}
.footer-socials {
  display: flex;
  gap: 14px;
}
.fsoc {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #ffffff;
  border: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 10px 20px rgba(0,0,0,0.04);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gray-700);
  transition: all 0.4s var(--ease-spring);
  cursor: auto;
}
.fsoc:hover {
  background: var(--blue);
  border-color: var(--blue);
  color: #fff;
  transform: translateY(-8px) scale(1.15) rotate(5deg);
  box-shadow: 0 20px 40px rgba(0, 149, 255, 0.35);
}
.footer-col h5 {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--black);
  margin-bottom: 24px;
}
.footer-col a {
  display: block;
  font-size: 14.5px;
  color: var(--gray-500);
  margin-bottom: 15px;
  transition: all 0.3s var(--ease-out);
  cursor: auto;
  position: relative;
  width: fit-content;
}
.footer-col a::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0;
  height: 1.5px;
  background: var(--blue);
  transition: width 0.3s var(--ease-out);
}
.footer-col a:hover {
  color: var(--blue);
  transform: translateX(8px);
}
.footer-col a:hover::after {
  width: 100%;
}
.footer-col p {
  font-size: 13.5px;
  color: var(--gray-500);
  line-height: 1.65;
}
.footer-bottom {
  background: transparent;
  border-top: 1px solid rgba(0,0,0,0.06);
  padding: 28px 0;
}
.footer-bottom .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
}
.footer-bottom p {
  font-size: 13.5px;
  color: var(--gray-500);
}
.foot-links {
  display: flex;
  gap: 28px;
}
.foot-links a {
  font-size: 13.5px;
  color: var(--gray-500);
  transition: color 0.25s;
  cursor: auto;
}
.foot-links a:hover {
  color: var(--blue);
}

/* ═══ WHATSAPP 3D ═══ */
.wa-float{position:fixed;bottom:30px;right:30px;z-index:990;cursor: auto;}
.wa-3d-wrap{position:relative;width:70px;height:70px;transform-style:preserve-3d;animation:waFloat3D 4s ease-in-out infinite;}
@keyframes waFloat3D{0%,100%{transform:translateY(0) rotateY(0deg);}25%{transform:translateY(-10px) rotateY(15deg);}75%{transform:translateY(-10px) rotateY(-15deg);}}
.wa-sphere{width:70px;height:70px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#40E07A,#25D366,#128C7E);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px rgba(37,211,102,.5),inset 0 -4px 12px rgba(0,0,0,.15),inset 0 4px 10px rgba(255,255,255,.3);position:relative;z-index:2;transition:transform .3s var(--ease-spring),box-shadow .3s;}
.wa-float:hover .wa-sphere{transform:scale(1.15);box-shadow:0 16px 50px rgba(37,211,102,.65),inset 0 -4px 12px rgba(0,0,0,.15),inset 0 4px 10px rgba(255,255,255,.3);}
.wa-shadow{position:absolute;bottom:-14px;left:50%;transform:translateX(-50%);width:50px;height:12px;border-radius:50%;background:rgba(37,211,102,.3);filter:blur(8px);animation:waShadow 4s ease-in-out infinite;}
@keyframes waShadow{0%,100%{transform:translateX(-50%) scale(1);opacity:.7;}50%{transform:translateX(-50%) scale(.7);opacity:.35;}}
.wa-ring{position:absolute;inset:-8px;border-radius:50%;border:2px solid rgba(37,211,102,.35);animation:waRing 2.5s ease-out infinite;}
.wa-ring:nth-child(2){animation-delay:.8s;}
.wa-ring:nth-child(3){animation-delay:1.6s;}
@keyframes waRing{0%{transform:scale(1);opacity:.8;}100%{transform:scale(1.7);opacity:0;}}
.wa-tooltip{position:absolute;right:calc(100% + 14px);top:50%;transform:translateY(-50%);white-space:nowrap;background:var(--black);color:#fff;font-size:12px;font-weight:700;padding:9px 18px;border-radius:50px;opacity:0;transition:all .3s;pointer-events:none;box-shadow:0 8px 24px rgba(0,0,0,.2);}
.wa-tooltip::after{content:'';position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:0;height:0;border-top:5px solid transparent;border-bottom:5px solid transparent;border-left:6px solid var(--black);}
.wa-float:hover .wa-tooltip{opacity:1;}

/* ═══ RESPONSIVE ═══ */
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr;}.hero-right{display:none;}
  .services-grid{grid-template-columns:1fr 1fr;}.about-grid{grid-template-columns:1fr;}
  .process-line{display:none;}.ps-item,.ps-item.ps-right{flex-direction:column;align-items:flex-start;}
  .reviews-layout{grid-template-columns:1fr;}.contact-grid{grid-template-columns:1fr;}
  .faq-layout{grid-template-columns:1fr;}.faq-left{position:static;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px;}
  .stats-band-grid{grid-template-columns:1fr 1fr;}.sb-item:nth-child(2){border-right:none;}
}
@media(max-width:768px){
  :root{--nav-h:74px;}
  .nav-links,.nav-phone-btn,.nav-cta{display:none;}.burger-btn{display:flex;}
  .services-grid{grid-template-columns:1fr;}.float-card{display:none;}
  .why-mini-grid{grid-template-columns:1fr;}.form-row{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;gap:40px;text-align:center;}.logo-img{height:72px;}
  .footer-brand-col p { margin: 0 auto 28px; }
  .footer-socials { justify-content: center; }
  .footer-col h5::after { content: ''; display: block; width: 40px; height: 2px; background: var(--blue); margin: 10px auto 0; }
  .footer-col a { margin: 0 auto 15px; }
}
@media(max-width:480px){
  .hero-actions{flex-direction:column;}.cities-grid{grid-template-columns:1fr 1fr;}
  .stats-band-grid{grid-template-columns:1fr 1fr;}.hero-stats{flex-wrap:wrap;gap:20px;}
  .hs:not(:last-child){border-right:none;padding-right:0;margin-right:0;}
  .hand-drawn-circle { width: 110%; left: -5%; }
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important;}}

/* ═══════════════════════════════════════════════════════════
   PORTAL SHARED STYLES
   Shared across: user-portal, provider-portal, customer-profile,
   booking-detail, chat, experts, provider-profile, admin
═══════════════════════════════════════════════════════════ */

/* Extra token aliases used by portals */
:root {
  --gray:     #6B7280;
  --gray-600: #4B5563;
  --blue-mid: #3AAEFF;
}

/* Portal base */
.portal-body {
  font-family: var(--f-body);
  background: #f8fafc;
  color: var(--gray-700);
  min-height: 100vh;
  cursor: default !important;
}
.portal-body button { cursor: pointer !important; }
.portal-body a      { cursor: pointer !important; }

/* Headings in portals use Outfit via inline font-family; fall back to Montserrat */
.portal-h { font-family: 'Outfit', var(--f-body); }

/* ── Portal Cards ── */
.pcard {
  background: #fff;
  border-radius: 20px;
  border: 1.5px solid #edf2f7;
  box-shadow: 0 4px 20px rgba(0,0,0,0.04);
  padding: 28px;
}
.pcard-sm { padding: 18px 20px; border-radius: 16px; }

/* ── Section Labels ── */
.portal-section-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gray);
  margin-bottom: 16px;
}

/* ── Status Badges ── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 12px;
  border-radius: 50px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.badge-blue     { background: #e8f4ff; color: #0065b3; }
.badge-green    { background: #dcfce7; color: #15803d; }
.badge-yellow   { background: #fef3c7; color: #b45309; }
.badge-red      { background: #fee2e2; color: #dc2626; }
.badge-purple   { background: #ede9fe; color: #6d28d9; }
.badge-gray     { background: #f1f5f9; color: #64748b; }

/* ── Avatar ── */
.avatar {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--blue), var(--blue-dark));
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 18px;
  flex-shrink: 0;
}
.avatar-lg { width: 72px; height: 72px; border-radius: 18px; font-size: 28px; }
.avatar-xl { width: 96px; height: 96px; border-radius: 24px; font-size: 36px; }

/* ── Stars ── */
.stars { color: #f59e0b; letter-spacing: 1.5px; }

/* ── Portal Toast ── */
.toast-notif {
  position: fixed; bottom: 30px; left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: #111827; color: #fff;
  padding: 13px 28px; border-radius: 50px;
  font-size: 14px; font-weight: 600;
  z-index: 9999;
  opacity: 0; pointer-events: none;
  transition: all 0.35s cubic-bezier(.16,1,.3,1);
  white-space: nowrap;
}
.toast-notif.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* ── Portal Modal Overlay ── */
.p-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 2000;
  display: none; align-items: center; justify-content: center;
}
.p-overlay.open { display: flex; }
.p-modal {
  background: #fff;
  border-radius: 24px;
  padding: 36px;
  width: 90%;
  max-width: 520px;
  max-height: 90vh;
  overflow-y: auto;
  animation: modalIn 0.35s cubic-bezier(.16,1,.3,1);
}
@keyframes modalIn {
  from { opacity: 0; transform: scale(0.94) translateY(20px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}
.p-modal-lg { max-width: 720px; }
.p-modal-title {
  font-size: 20px; font-weight: 800;
  margin-bottom: 20px;
}

/* ── Form Fields (portal forms) ── */
.p-field { margin-bottom: 16px; }
.p-field label {
  display: block;
  font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.8px;
  color: var(--gray); margin-bottom: 6px;
}
.p-field input,
.p-field select,
.p-field textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1.5px solid #e2e8f0;
  border-radius: 12px;
  font-size: 14px;
  font-family: var(--f-body);
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
  background: #fff;
}
.p-field input:focus,
.p-field select:focus,
.p-field textarea:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(0,149,255,0.12);
}
.p-field textarea { min-height: 100px; resize: vertical; }

/* ── Portal Buttons ── */
.p-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 13px 24px;
  border-radius: 50px;
  font-size: 14px; font-weight: 700;
  font-family: var(--f-body);
  border: none; cursor: pointer;
  transition: all 0.3s;
  white-space: nowrap;
}
.p-btn-primary   { background: var(--blue); color: #fff; box-shadow: 0 4px 18px rgba(0,149,255,.3); }
.p-btn-primary:hover { background: var(--blue-dark); transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,149,255,.4); }
.p-btn-ghost     { background: transparent; color: var(--black); border: 1.5px solid #e2e8f0; }
.p-btn-ghost:hover { border-color: var(--blue); color: var(--blue); background: var(--blue-light); }
.p-btn-danger    { background: #fee2e2; color: #dc2626; }
.p-btn-danger:hover { background: #fecaca; }
.p-btn-success   { background: #dcfce7; color: #15803d; }
.p-btn-success:hover { background: #bbf7d0; }
.p-btn-sm        { padding: 8px 16px; font-size: 12px; }
.p-btn-lg        { padding: 16px 32px; font-size: 16px; }
.p-btn-full      { width: 100%; }
.p-btn:disabled  { opacity: 0.5; pointer-events: none; }

/* ── Spinner ── */
.p-spinner {
  display: inline-block;
  width: 20px; height: 20px;
  border: 2.5px solid rgba(255,255,255,0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
}
.p-spinner-blue {
  border: 2.5px solid rgba(0,149,255,0.2);
  border-top-color: var(--blue);
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Empty State ── */
.p-empty {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 60px 20px; text-align: center;
  color: var(--gray);
}
.p-empty-icon { font-size: 48px; margin-bottom: 16px; opacity: 0.5; }
.p-empty h3   { font-size: 18px; font-weight: 700; color: var(--gray-600); margin-bottom: 8px; }
.p-empty p    { font-size: 14px; max-width: 300px; }

/* ── Skeleton Loader ── */
.skeleton {
  background: linear-gradient(90deg, #f1f5f9 25%, #e2e8f0 50%, #f1f5f9 75%);
  background-size: 200% 100%;
  animation: skeletonWave 1.5s ease infinite;
  border-radius: 8px;
}
@keyframes skeletonWave {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ── Tab Nav (portals) ── */
.portal-tabs {
  display: flex; gap: 4px;
  background: #f1f5f9;
  padding: 5px;
  border-radius: 14px;
  width: fit-content;
  flex-wrap: wrap;
}
.portal-tab {
  padding: 10px 20px;
  border-radius: 10px;
  font-size: 13px; font-weight: 600;
  color: var(--gray); cursor: pointer;
  transition: all 0.25s;
  white-space: nowrap;
}
.portal-tab.active, .portal-tab:hover {
  background: #fff;
  color: var(--blue);
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}

/* ── Info Row (label + value pairs) ── */
.info-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid #f1f5f9;
}
.info-row:last-child { border-bottom: none; }
.info-row .lbl { font-size: 13px; color: var(--gray); }
.info-row .val { font-size: 14px; font-weight: 600; text-align: right; }

/* ── Rating Bar ── */
.rating-bar-wrap { display: flex; align-items: center; gap: 10px; margin-bottom: 6px; }
.rating-bar-track { flex: 1; height: 6px; background: #f1f5f9; border-radius: 50px; overflow: hidden; }
.rating-bar-fill  { height: 100%; border-radius: 50px; background: #f59e0b; transition: width 0.6s; }

/* ── Booking Timeline ── */
.booking-timeline { display: flex; align-items: center; gap: 0; margin: 20px 0; }
.btl-step {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  flex: 1; position: relative;
}
.btl-dot {
  width: 20px; height: 20px; border-radius: 50%;
  border: 2.5px solid #e2e8f0; background: #fff;
  position: relative; z-index: 1;
  transition: all 0.3s;
}
.btl-dot.done   { background: var(--blue); border-color: var(--blue); }
.btl-dot.active { background: #fff; border-color: var(--blue); box-shadow: 0 0 0 4px rgba(0,149,255,0.2); }
.btl-label { font-size: 10px; font-weight: 600; color: var(--gray); text-align: center; }
.btl-line {
  height: 2px; background: #e2e8f0; flex: 1;
  margin-top: -15px; /* vertically align with dots */
  transition: background 0.3s;
}
.btl-line.done { background: var(--blue); }

/* ── Image Upload Preview ── */
.img-upload-wrap { position: relative; display: inline-block; }
.img-upload-preview {
  width: 90px; height: 90px; border-radius: 18px;
  object-fit: cover; border: 2px solid #e2e8f0;
  display: block;
}
.img-upload-btn {
  position: absolute; bottom: -6px; right: -6px;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--blue); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; cursor: pointer;
  border: 2px solid #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}

/* ── Chat Bubble ── */
.chat-bubble {
  max-width: 72%;
  padding: 12px 16px;
  border-radius: 18px;
  font-size: 14px; line-height: 1.5;
  word-break: break-word;
}
.chat-bubble.sent {
  background: var(--blue); color: #fff;
  border-bottom-right-radius: 4px;
  margin-left: auto;
}
.chat-bubble.recv {
  background: #f1f5f9; color: var(--gray-700);
  border-bottom-left-radius: 4px;
}

/* ── Provider Card ── */
.provider-card {
  background: #fff;
  border-radius: 20px;
  border: 1.5px solid #edf2f7;
  overflow: hidden;
  transition: transform 0.3s, box-shadow 0.3s;
}
.provider-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0,0,0,0.1);
}
.provider-card-img {
  width: 100%; height: 180px;
  object-fit: cover;
}
.provider-card-body { padding: 20px; }
.provider-card-name { font-size: 16px; font-weight: 700; margin-bottom: 4px; }
.provider-card-cat  { font-size: 12px; color: var(--gray); margin-bottom: 12px; }
.provider-card-meta { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 14px; }
.provider-card-tag  {
  font-size: 11px; font-weight: 600;
  padding: 4px 10px; border-radius: 50px;
  background: #f1f5f9; color: var(--gray-600);
}
.provider-card-actions { display: flex; gap: 8px; }

/* ── Search / Filter Bar ── */
.filter-bar {
  display: flex; gap: 12px; align-items: center;
  flex-wrap: wrap; padding: 16px 20px;
  background: #fff; border-radius: 16px;
  border: 1.5px solid #edf2f7;
  margin-bottom: 24px;
}
.filter-bar input,
.filter-bar select {
  padding: 10px 14px;
  border: 1.5px solid #e2e8f0;
  border-radius: 10px;
  font-size: 14px;
  font-family: var(--f-body);
  outline: none;
  background: #f8fafc;
  transition: border-color 0.2s;
}
.filter-bar input:focus,
.filter-bar select:focus { border-color: var(--blue); background: #fff; }
.filter-bar input { flex: 1; min-width: 200px; }

/* ── Notification Item ── */
.notif-item {
  display: flex; gap: 14px; align-items: flex-start;
  padding: 14px 16px; border-radius: 12px;
  transition: background 0.2s;
}
.notif-item:hover { background: #f8fafc; }
.notif-item.unread { background: #f0f7ff; }
.notif-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--blue); flex-shrink: 0; margin-top: 6px;
}
.notif-text { font-size: 14px; line-height: 1.5; }
.notif-time { font-size: 11px; color: var(--gray); margin-top: 4px; }

/* ── Stat Cards (portal) ── */
.portal-stat {
  background: #fff;
  border-radius: 18px;
  border: 1.5px solid #edf2f7;
  padding: 22px;
  display: flex; flex-direction: column; gap: 4px;
}
.portal-stat-val  { font-size: 28px; font-weight: 800; }
.portal-stat-lbl  { font-size: 12px; color: var(--gray); font-weight: 600; }
.portal-stat-icon { font-size: 26px; margin-bottom: 8px; }

/* ── Responsive Portal Utilities ── */
@media (max-width: 1024px) {
  .hide-tablet { display: none !important; }
}
@media (max-width: 768px) {
  /* Portal full-width modal on mobile */
  .p-modal {
    width: 100%;
    max-width: 100%;
    max-height: 100vh;
    border-radius: 24px 24px 0 0;
    margin-top: auto;
  }
  .p-overlay { align-items: flex-end; }

  /* Portals: stack header actions */
  .portal-header-row {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 12px !important;
  }
  .portal-header-row button, .portal-header-row .p-btn {
    width: 100%;
  }

  /* Portal tabs: scroll horizontally */
  .portal-tabs { flex-wrap: nowrap; overflow-x: auto; width: 100%; -webkit-overflow-scrolling: touch; }
  .portal-tab  { flex-shrink: 0; }

  /* Booking timeline text: smaller */
  .btl-label { font-size: 9px; }
  .btl-dot   { width: 16px; height: 16px; }

  /* Chat bubble: full width */
  .chat-bubble { max-width: 85%; }

  /* Filter bar: stack */
  .filter-bar { flex-direction: column; align-items: stretch; }
  .filter-bar input { min-width: unset; }

  .hide-mobile { display: none !important; }
}
@media (max-width: 480px) {
  .pcard { padding: 16px; }
  .p-modal { padding: 20px; }
  .portal-stat-val { font-size: 22px; }
  .provider-card-actions { flex-direction: column; }
  .provider-card-actions .p-btn { width: 100%; justify-content: center; }
}
.mob-bottom-nav { display: none !important; }
#notifPanel {
  position: fixed !important;
  z-index: 99999 !important;
}