/* ════════════════════════════════════════════════════════════════
   DTech Creative Agency — main.css v5
   Ultra-modern design system
════════════════════════════════════════════════════════════════ */

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

/* ── Variables ──────────────────────────────────────────────── */
:root {
  --accent:       #6C47FF;
  --accent-2:     #FF6B35;
  --accent-3:     #00D4AA;
  --primary:      #0a0a0f;
  --text:         #1a1a2e;
  --text-muted:   #64748b;
  --text-light:   #94a3b8;
  --bg:           #ffffff;
  --bg-2:         #f8f9fe;
  --bg-3:         #f1f3fd;
  --border:       rgba(108,71,255,.12);
  --border-light: rgba(0,0,0,.06);
  --card-shadow:  0 4px 32px rgba(108,71,255,.08);
  --card-hover:   0 16px 64px rgba(108,71,255,.18);
  --radius:       16px;
  --radius-sm:    8px;
  --radius-lg:    24px;
  --font-display: 'Syne',sans-serif;
  --font-body:    'DM Sans',sans-serif;
  --ease:         cubic-bezier(.4,0,.2,1);
  --spring:       cubic-bezier(.34,1.56,.64,1);
  --glass:        rgba(255,255,255,.7);
}

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);color:var(--text);background:var(--bg);line-height:1.7;overflow-x:hidden}
img,video,iframe{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
::selection{background:var(--accent);color:white}

/* ── Loader ────────────────────────────────────────────────── */
#page-loader{position:fixed;inset:0;background:var(--primary);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .5s,visibility .5s}
#page-loader.hidden{opacity:0;visibility:hidden}
.loader-logo{font-family:var(--font-display);font-size:2rem;font-weight:800;color:white}
.loader-logo span{color:var(--accent)}
.loader-logo::after{content:'';display:block;height:3px;background:var(--accent);margin-top:8px;animation:loaderBar 1.5s ease-in-out infinite;border-radius:99px}
@keyframes loaderBar{0%{width:0;opacity:0}50%{width:100%;opacity:1}100%{width:0;opacity:0}}

/* ── Navbar ────────────────────────────────────────────────── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 2rem;transition:all .3s var(--ease);border-bottom:1px solid transparent}
.navbar.scrolled{background:rgba(255,255,255,.94);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom-color:var(--border-light);box-shadow:0 4px 20px rgba(0,0,0,.06)}
.nav-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:80px}
.nav-logo{font-family:var(--font-display);font-size:1.5rem;font-weight:800;color:white;letter-spacing:-.02em;display:flex;align-items:center;gap:8px;transition:color .3s}
.navbar.scrolled .nav-logo,.navbar.scrolled .nav-logo-text{color:var(--primary)}
.nav-logo-text{font-family:var(--font-display);font-size:1.5rem;font-weight:800;letter-spacing:-.02em}
.nav-logo-text span,.nav-logo span{color:var(--accent)}
.logo-dot{width:8px;height:8px;background:var(--accent);border-radius:50%;display:inline-block;animation:pulseDot 2s infinite}
@keyframes pulseDot{0%,100%{transform:scale(1)}50%{transform:scale(1.3);opacity:.7}}
.nav-logo-img{transition:filter .3s}
.nav-logo-transparent{filter:brightness(0) invert(1)}
.navbar.scrolled .nav-logo-transparent{filter:none}
.nav-links{display:flex;align-items:center;gap:.5rem;list-style:none}
.nav-links a{font-size:.875rem;font-weight:500;color:rgba(255,255,255,.8);padding:8px 14px;border-radius:8px;transition:all .2s}
.navbar.scrolled .nav-links a{color:var(--text-muted)}
.nav-links a:hover,.nav-links a.active{color:var(--accent);background:rgba(108,71,255,.08)}
.btn-nav{background:var(--accent);color:white;padding:10px 22px;border-radius:10px;font-size:.875rem;font-weight:600;transition:all .2s;border:none;cursor:pointer;box-shadow:0 4px 14px rgba(108,71,255,.3)}
.btn-nav:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(108,71,255,.4)}
.menu-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.menu-toggle span{display:block;width:24px;height:2px;background:white;border-radius:2px;transition:all .3s}
.navbar.scrolled .menu-toggle span{background:var(--primary)}

/* ── Mobile Menu ───────────────────────────────────────────── */
.mobile-menu{display:none;position:fixed;inset:0;background:rgba(10,10,15,.97);backdrop-filter:blur(20px);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}
.mobile-menu.open{display:flex}
.mobile-menu .nav-link{font-family:var(--font-display);font-size:2rem;font-weight:800;color:white;transition:color .2s}
.mobile-menu .nav-link:hover{color:var(--accent)}
.mobile-menu-close{position:absolute;top:1.5rem;right:1.5rem;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.1);border:none;color:white;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center}

/* ── Buttons ───────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.95rem;font-weight:600;cursor:pointer;border:none;transition:all .25s;text-decoration:none;position:relative;overflow:hidden;white-space:nowrap}
.btn-primary{background:var(--accent);color:white;box-shadow:0 4px 20px rgba(108,71,255,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(108,71,255,.45)}
.btn-secondary{background:transparent;color:var(--accent);border:2px solid var(--accent)}
.btn-secondary:hover{background:var(--accent);color:white;transform:translateY(-2px)}
.btn-dark{background:var(--primary);color:white;box-shadow:0 4px 20px rgba(10,10,15,.2)}
.btn-dark:hover{transform:translateY(-2px)}
.btn-light{background:white;color:var(--accent);box-shadow:0 4px 16px rgba(0,0,0,.1)}
.btn-light:hover{transform:translateY(-2px)}
.btn-sm{padding:9px 18px;font-size:.82rem}
.btn-lg{padding:17px 40px;font-size:1rem;border-radius:12px}
.w-100{width:100%;justify-content:center}

/* ── HERO SECTION ──────────────────────────────────────────── */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:var(--primary);padding:120px 2rem 80px}
.hero-bg{position:absolute;inset:0;overflow:hidden}
.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);animation:floatOrb 8s ease-in-out infinite}
.hero-orb-1{width:600px;height:600px;background:radial-gradient(circle,rgba(108,71,255,.35),transparent 70%);top:-100px;right:-100px}
.hero-orb-2{width:400px;height:400px;background:radial-gradient(circle,rgba(255,107,53,.25),transparent 70%);bottom:-50px;left:10%;animation-delay:3s}
.hero-orb-3{width:300px;height:300px;background:radial-gradient(circle,rgba(0,212,170,.2),transparent 70%);top:40%;left:30%;animation-delay:5s}
@keyframes floatOrb{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.05)}}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:60px 60px}
.hero-content{max-width:1280px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(108,71,255,.15);border:1px solid rgba(108,71,255,.3);color:#b4a0ff;padding:8px 16px;border-radius:99px;font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:1.75rem;animation:fadeInUp .8s both}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--accent-3);animation:pulseDot 2s infinite}
.hero-title{font-family:var(--font-display);font-size:clamp(2.4rem,4.5vw,4.2rem);font-weight:800;line-height:1.08;letter-spacing:-.03em;color:white;margin-bottom:1.5rem;opacity:0;animation:fadeInUp .8s .2s forwards}
.hero-title .highlight{background:linear-gradient(135deg,var(--accent),#a78bfa 50%,var(--accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-subtitle{font-size:1.05rem;color:rgba(255,255,255,.6);max-width:520px;line-height:1.8;margin-bottom:2.5rem;opacity:0;animation:fadeInUp .8s .4s forwards}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:fadeInUp .8s .6s forwards}
.hero-stats{display:flex;gap:2rem;margin-top:3rem;opacity:0;animation:fadeInUp .8s .8s forwards;flex-wrap:wrap}
.hero-stat-number{font-family:var(--font-display);font-size:2rem;font-weight:800;color:white;line-height:1}
.hero-stat-label{font-size:.78rem;color:rgba(255,255,255,.5);margin-top:2px}
.hero-visual{position:relative;opacity:0;animation:fadeInRight .8s .5s forwards}
.hero-card-main{background:rgba(255,255,255,.05);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:2rem;position:relative}
.hero-card-screen{background:linear-gradient(135deg,#1e1e3f,#0f0f23);border-radius:12px;padding:1.5rem;font-family:'Courier New',monospace;font-size:.8rem;color:#64ffda;line-height:2;min-height:200px;overflow:hidden}
.hero-card-screen::before{content:'● ● ●';display:block;color:rgba(255,255,255,.3);margin-bottom:1rem;letter-spacing:4px}
.code-line{animation:codeIn .5s ease forwards;opacity:0}
.code-line:nth-child(2){animation-delay:.5s}
.code-line:nth-child(3){animation-delay:1s}
.code-line:nth-child(4){animation-delay:1.5s}
.code-line:nth-child(5){animation-delay:2s}
.code-line:nth-child(6){animation-delay:2.5s}
@keyframes codeIn{to{opacity:1}}
.code-keyword{color:#c792ea}
.code-string{color:#f78c6c}
.code-value{color:#c3e88d}
.code-comment{color:rgba(100,150,100,.7)}
.floating-cards{position:absolute;display:flex;flex-direction:column;gap:12px;right:-40px;top:50%;transform:translateY(-50%)}
.float-card{background:rgba(255,255,255,.08);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:12px 16px;display:flex;align-items:center;gap:12px;white-space:nowrap;animation:floatCard 3s ease-in-out infinite}
.float-card:nth-child(2){animation-delay:1s}
.float-card:nth-child(3){animation-delay:2s}
@keyframes floatCard{0%,100%{transform:translateX(0)}50%{transform:translateX(-6px)}}
.float-card-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem}
.float-card-icon.green{background:rgba(0,212,170,.2);color:var(--accent-3)}
.float-card-icon.purple{background:rgba(108,71,255,.2);color:var(--accent)}
.float-card-icon.orange{background:rgba(255,107,53,.2);color:var(--accent-2)}
.float-card-text{font-size:.75rem;color:rgba(255,255,255,.8);font-weight:600}
.float-card-sub{font-size:.65rem;color:rgba(255,255,255,.4)}

/* ── Section ───────────────────────────────────────────────── */
.section{padding:100px 2rem}
.section-sm{padding:60px 2rem}
.section-dark{background:var(--primary)}
.section-gray{background:var(--bg-2)}
.container{max-width:1280px;margin:0 auto}
.section-tag{display:inline-block;background:rgba(108,71,255,.1);color:var(--accent);padding:6px 16px;border-radius:99px;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1rem;border:1px solid rgba(108,71,255,.2)}
.section-title{font-family:var(--font-display);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;letter-spacing:-.025em;line-height:1.15;color:var(--text);margin-bottom:1rem}
.section-title-white{color:white}
.section-subtitle{font-size:1rem;color:var(--text-muted);max-width:600px;line-height:1.8}
.section-header{margin-bottom:3.5rem}
.section-header-center{text-align:center}
.section-header-center .section-subtitle{margin:0 auto}

/* ── Services Grid ─────────────────────────────────────────── */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}
.service-card{background:white;border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:2rem;position:relative;overflow:hidden;transition:all .35s var(--ease);cursor:pointer}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transform:scaleX(0);transition:transform .35s var(--ease);transform-origin:left}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--card-hover);border-color:var(--border)}
.service-card:hover::before{transform:scaleX(1)}
.service-icon{width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,rgba(108,71,255,.12),rgba(108,71,255,.06));display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--accent);margin-bottom:1.25rem;transition:all .35s var(--ease)}
.service-card:hover .service-icon{background:linear-gradient(135deg,var(--accent),#8b5cf6);color:white;transform:scale(1.1) rotate(-5deg)}
.service-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;margin-bottom:.6rem;letter-spacing:-.01em}
.service-desc{font-size:.875rem;color:var(--text-muted);line-height:1.7;margin-bottom:1.25rem}
.service-price{font-size:.85rem;color:var(--accent);font-weight:700;margin-bottom:1.25rem}
.service-btn{width:100%;background:var(--bg-3);color:var(--accent);border:none;border-radius:10px;padding:12px;font-family:var(--font-body);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}
.service-btn:hover{background:var(--accent);color:white}
.service-btn-arrow{transition:transform .3s}
.service-btn:hover .service-btn-arrow{transform:translateX(4px)}

/* ── Features Grid ─────────────────────────────────────────── */
.features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem}
.feature-card{padding:2rem;border-radius:var(--radius-lg);background:white;border:1px solid var(--border-light);transition:all .3s var(--ease)}
.feature-card:hover{box-shadow:var(--card-shadow);transform:translateY(-4px)}
.feature-number{font-family:var(--font-display);font-size:3rem;font-weight:900;color:rgba(108,71,255,.08);line-height:1;margin-bottom:1rem}
.feature-title{font-family:var(--font-display);font-size:1.05rem;font-weight:700;margin-bottom:.5rem}
.feature-text{font-size:.875rem;color:var(--text-muted);line-height:1.7}

/* ── Portfolio Grid ─────────────────────────────────────────── */
.portfolio-filter{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:2.5rem}
.filter-btn{padding:8px 20px;border-radius:99px;font-size:.85rem;font-weight:600;cursor:pointer;border:1.5px solid var(--border-light);background:transparent;color:var(--text-muted);transition:all .2s;font-family:var(--font-body)}
.filter-btn.active,.filter-btn:hover{background:var(--accent);color:white;border-color:var(--accent)}
.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}
.portfolio-card{border-radius:var(--radius-lg);overflow:hidden;position:relative;cursor:pointer;transition:all .35s var(--ease);aspect-ratio:16/10;background:var(--bg-3)}
.portfolio-card:hover{transform:scale(1.02);box-shadow:var(--card-hover)}
.portfolio-img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.portfolio-card:hover .portfolio-img{transform:scale(1.05)}
.portfolio-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,15,.9),transparent 60%);padding:1.5rem;display:flex;flex-direction:column;justify-content:flex-end;opacity:0;transition:opacity .3s}
.portfolio-card:hover .portfolio-overlay{opacity:1}
.portfolio-cat{font-size:.72rem;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.portfolio-name{font-family:var(--font-display);font-size:1.15rem;color:white;font-weight:700}
.portfolio-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-3),var(--bg-2));color:var(--text-muted);font-size:2.5rem}

/* ── Testimonials ──────────────────────────────────────────── */
.testimonials-slider{position:relative;overflow:hidden}
.testimonials-track{display:flex;gap:1.5rem;transition:transform .5s var(--ease)}
.testimonial-card{min-width:calc(33.333% - 1rem);background:white;border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:2rem;flex-shrink:0;transition:box-shadow .3s}
.testimonial-card:hover{box-shadow:var(--card-shadow)}
.testimonial-stars{color:#f59e0b;font-size:.9rem;margin-bottom:1rem}
.testimonial-text{font-size:.9rem;line-height:1.8;color:var(--text-muted);margin-bottom:1.5rem;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:12px}
.testimonial-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;color:white;font-weight:700;font-size:1rem;font-family:var(--font-display)}
.testimonial-name{font-weight:700;font-size:.875rem}
.testimonial-role{font-size:.78rem;color:var(--text-muted)}
.slider-controls{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:2.5rem}
.slider-btn{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--border-light);background:white;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--text-muted);transition:all .2s}
.slider-btn:hover{border-color:var(--accent);color:var(--accent)}
.slider-dots{display:flex;gap:6px}
.slider-dot{width:8px;height:8px;border-radius:99px;background:var(--border-light);cursor:pointer;transition:all .2s}
.slider-dot.active{width:24px;background:var(--accent)}

/* ── CTA Section ───────────────────────────────────────────── */
.cta-section{background:linear-gradient(135deg,var(--accent),#4c1d95);border-radius:32px;padding:80px;text-align:center;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.cta-title{font-family:var(--font-display);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;color:white;letter-spacing:-.025em;margin-bottom:1rem;position:relative}
.cta-text{font-size:1rem;color:rgba(255,255,255,.75);margin-bottom:2.5rem;position:relative}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative}

/* ── Contact ───────────────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:4rem;align-items:start}
.contact-info-item{display:flex;gap:16px;align-items:flex-start;margin-bottom:2rem}
.contact-info-icon{width:48px;height:48px;border-radius:12px;background:rgba(108,71,255,.1);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:1.1rem;flex-shrink:0}
.contact-info-label{font-size:.78rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.contact-info-value{font-weight:600;font-size:.925rem}
.contact-map{border-radius:var(--radius-lg);overflow:hidden;margin-top:2rem;height:220px}
.contact-map iframe{width:100%;height:100%;border:none}
.contact-form{background:var(--bg-2);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:2.5rem}

/* ── Forms ─────────────────────────────────────────────────── */
.form-group{margin-bottom:1.25rem}
.form-label{display:block;font-size:.82rem;font-weight:600;color:var(--text-muted);margin-bottom:6px;letter-spacing:.02em}
.form-control{width:100%;padding:12px 16px;border:1.5px solid var(--border-light);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.875rem;color:var(--text);background:white;transition:all .2s;outline:none}
.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 4px rgba(108,71,255,.08)}
.form-control::placeholder{color:var(--text-light)}
textarea.form-control{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-success{background:rgba(0,212,170,.1);border:1px solid rgba(0,212,170,.3);color:#059669;border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:1rem;font-size:.875rem}
.form-alert{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:#ef4444;border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:1rem;font-size:.875rem}

/* ── Modal ─────────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;z-index:2000;background:rgba(10,10,15,.75);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;visibility:hidden;transition:all .3s}
.modal-overlay.active{opacity:1;visibility:visible}
.modal{background:white;border-radius:var(--radius-lg);max-width:540px;width:100%;padding:2.5rem;position:relative;transform:translateY(30px) scale(.96);transition:all .3s var(--spring);max-height:90vh;overflow-y:auto}
.modal-overlay.active .modal{transform:translateY(0) scale(1)}
.modal-close{position:absolute;top:1.25rem;right:1.25rem;width:36px;height:36px;border-radius:50%;border:none;background:var(--bg-2);cursor:pointer;font-size:1.1rem;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:all .2s}
.modal-close:hover{background:var(--accent);color:white}
.modal-title{font-family:var(--font-display);font-size:1.4rem;font-weight:800;margin-bottom:.5rem}
.modal-subtitle{font-size:.875rem;color:var(--text-muted);margin-bottom:1.75rem}
.modal-service-name{background:rgba(108,71,255,.08);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-weight:700;color:var(--accent);font-size:.875rem;margin-bottom:1.5rem}

/* ── Page Hero ─────────────────────────────────────────────── */
.page-hero{background:var(--primary);padding:160px 2rem 100px;text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center top,rgba(108,71,255,.25),transparent 70%)}
.page-hero-title{font-family:var(--font-display);font-size:clamp(2.2rem,5vw,3.8rem);font-weight:900;color:white;letter-spacing:-.03em;position:relative}
.page-hero-sub{font-size:1rem;color:rgba(255,255,255,.6);margin-top:1rem;position:relative}
.breadcrumb{display:flex;align-items:center;gap:8px;justify-content:center;margin-top:1.25rem;font-size:.82rem;color:rgba(255,255,255,.4);position:relative}
.breadcrumb a{color:rgba(255,255,255,.6);transition:color .2s}
.breadcrumb a:hover{color:white}

/* ── Footer ────────────────────────────────────────────────── */
footer{background:var(--primary);color:rgba(255,255,255,.7);padding:80px 2rem 40px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;max-width:1280px;margin:0 auto;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-logo{font-family:var(--font-display);font-size:1.5rem;font-weight:800;color:white;letter-spacing:-.02em;margin-bottom:1rem}
.footer-logo span{color:var(--accent)}
.footer-desc{font-size:.85rem;line-height:1.8;max-width:280px}
.footer-socials{display:flex;gap:10px;margin-top:1.5rem}
.social-link{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);font-size:.95rem;transition:all .2s}
.social-link:hover{background:var(--accent);color:white;transform:translateY(-2px)}
.footer-col h4{font-family:var(--font-display);font-size:.85rem;font-weight:700;color:white;letter-spacing:.04em;text-transform:uppercase;margin-bottom:1.25rem}
.footer-links{list-style:none}
.footer-links li{margin-bottom:.6rem}
.footer-links a{font-size:.85rem;color:rgba(255,255,255,.55);transition:all .2s}
.footer-links a:hover{color:white;padding-left:4px}
.footer-bottom{max-width:1280px;margin:0 auto;padding-top:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.78rem}

/* ── Auth ──────────────────────────────────────────────────── */
.auth-page{min-height:100vh;background:linear-gradient(135deg,#f8f9fe,#ede9fe);display:flex;align-items:center;justify-content:center;padding:2rem}
.auth-card{background:white;border-radius:24px;padding:3rem;max-width:480px;width:100%;box-shadow:0 20px 60px rgba(108,71,255,.12)}
.auth-logo{text-align:center;margin-bottom:2rem}
.auth-logo-text{font-family:var(--font-display);font-size:1.75rem;font-weight:800;color:var(--primary)}
.auth-logo-text span{color:var(--accent)}
.auth-title{font-family:var(--font-display);font-size:1.4rem;font-weight:800;margin-bottom:.3rem}
.auth-sub{font-size:.875rem;color:var(--text-muted);margin-bottom:2rem}
.auth-switch{text-align:center;margin-top:1.5rem;font-size:.875rem;color:var(--text-muted)}
.auth-switch a{color:var(--accent);font-weight:600}
.password-toggle{position:relative}
.password-toggle .toggle-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:1rem}

/* ── Mission/Vision ────────────────────────────────────────── */
.mission-vision-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.mv-card{background:white;border-radius:var(--radius-lg);padding:2.5rem;border:1px solid var(--border-light);position:relative;overflow:hidden}
.mv-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px}
.mv-card.mission::before{background:linear-gradient(90deg,var(--accent),#a78bfa)}
.mv-card.vision::before{background:linear-gradient(90deg,var(--accent-2),#fbbf24)}
.mv-icon{font-size:2.5rem;margin-bottom:1.5rem}
.mv-title{font-family:var(--font-display);font-size:1.3rem;font-weight:800;margin-bottom:1rem}
.mv-text{font-size:.9rem;color:var(--text-muted);line-height:1.8}

/* ── Admin Layout ──────────────────────────────────────────── */
.admin-layout{display:flex;min-height:100vh;font-family:var(--font-body)}
.admin-sidebar{width:260px;background:var(--primary);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto;transition:transform .3s}
.sidebar-header{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.08)}
.sidebar-logo{font-family:var(--font-display);font-size:1.25rem;font-weight:800;color:white}
.sidebar-logo span{color:var(--accent)}
.sidebar-badge{display:inline-block;background:rgba(108,71,255,.2);color:var(--accent);font-size:.62rem;padding:2px 8px;border-radius:99px;margin-top:4px;font-weight:700;letter-spacing:.05em}
.sidebar-nav{padding:1rem 0;flex:1}
.sidebar-section{padding:.5rem 1rem;font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-top:1rem}
.sidebar-link{display:flex;align-items:center;gap:12px;padding:10px 1.25rem;color:rgba(255,255,255,.55);font-size:.85rem;transition:all .2s;cursor:pointer;position:relative;text-decoration:none}
.sidebar-link:hover,.sidebar-link.active{color:white;background:rgba(108,71,255,.15)}
.sidebar-link.active::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);border-radius:0 2px 2px 0}
.sidebar-link-icon{width:18px;text-align:center;font-size:.95rem}
.sidebar-link-badge{margin-left:auto;background:var(--accent-2);color:white;font-size:.62rem;font-weight:800;padding:2px 7px;border-radius:99px}
.sidebar-footer{padding:1.25rem;border-top:1px solid rgba(255,255,255,.08)}
.sidebar-user{display:flex;align-items:center;gap:10px}
.sidebar-avatar{width:36px;height:36px;border-radius:10px;background:var(--accent);color:white;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem;font-family:var(--font-display)}
.sidebar-user-name{font-size:.85rem;font-weight:700;color:white}
.sidebar-user-role{font-size:.7rem;color:rgba(255,255,255,.4)}
.admin-main{margin-left:260px;flex:1;display:flex;flex-direction:column;min-height:100vh;background:var(--bg-2)}
.admin-topbar{background:white;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:50;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.admin-page-title{font-family:var(--font-display);font-size:1.2rem;font-weight:800}
.admin-topbar-right{display:flex;align-items:center;gap:1rem}
.notif-btn{position:relative;width:40px;height:40px;border-radius:10px;border:1.5px solid var(--border-light);background:white;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:1rem;transition:all .2s}
.notif-btn:hover{border-color:var(--accent);color:var(--accent)}
.notif-badge{position:absolute;top:-4px;right:-4px;width:18px;height:18px;border-radius:50%;background:var(--accent-2);color:white;font-size:.62rem;font-weight:800;display:flex;align-items:center;justify-content:center}
.admin-content{padding:2rem;flex:1}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem;margin-bottom:2rem}
.stat-card{background:white;border-radius:var(--radius);padding:1.5rem;border:1px solid var(--border-light);position:relative;overflow:hidden;transition:all .3s}
.stat-card:hover{box-shadow:var(--card-shadow);transform:translateY(-2px)}
.stat-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:1rem}
.stat-card-icon.purple{background:rgba(108,71,255,.1);color:var(--accent)}
.stat-card-icon.orange{background:rgba(255,107,53,.1);color:var(--accent-2)}
.stat-card-icon.green{background:rgba(0,212,170,.1);color:var(--accent-3)}
.stat-card-icon.blue{background:rgba(59,130,246,.1);color:#3b82f6}
.stat-number{font-family:var(--font-display);font-size:2rem;font-weight:900;line-height:1;margin-bottom:4px}
.stat-label{font-size:.82rem;color:var(--text-muted);font-weight:500}
.stat-trend{position:absolute;top:1.25rem;right:1.25rem;font-size:.72rem;font-weight:700;padding:4px 8px;border-radius:6px}
.stat-trend.up{background:rgba(0,212,170,.1);color:var(--accent-3)}
.stat-trend.down{background:rgba(239,68,68,.1);color:#ef4444}
.admin-card{background:white;border-radius:var(--radius);border:1px solid var(--border-light);overflow:hidden;margin-bottom:1.5rem}
.admin-card-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}
.admin-card-title{font-family:var(--font-display);font-size:.95rem;font-weight:800}
.admin-card-body{padding:1.5rem}
.data-table{width:100%;border-collapse:collapse}
.data-table th{text-align:left;padding:10px 16px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--bg-2);border-bottom:1px solid var(--border-light)}
.data-table td{padding:13px 16px;font-size:.85rem;border-bottom:1px solid var(--border-light);vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:var(--bg-2)}
.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:99px;font-size:.7rem;font-weight:700;letter-spacing:.02em}
.badge-pending{background:rgba(245,158,11,.1);color:#d97706}
.badge-completed{background:rgba(0,212,170,.1);color:#059669}
.badge-in_progress{background:rgba(59,130,246,.1);color:#2563eb}
.badge-cancelled{background:rgba(239,68,68,.1);color:#dc2626}
.badge-admin{background:rgba(108,71,255,.1);color:var(--accent)}
.badge-user{background:rgba(100,116,139,.1);color:#475569}
.badge-active{background:rgba(0,212,170,.1);color:#059669}
.badge-inactive{background:rgba(239,68,68,.1);color:#dc2626}
.action-btns{display:flex;gap:6px}
.action-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--border-light);background:white;cursor:pointer;font-size:.82rem;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-muted);text-decoration:none}
.action-btn.edit:hover{border-color:var(--accent);color:var(--accent);background:rgba(108,71,255,.06)}
.action-btn.delete:hover{border-color:#ef4444;color:#ef4444;background:rgba(239,68,68,.06)}
.action-btn.view:hover{border-color:#3b82f6;color:#3b82f6;background:rgba(59,130,246,.06)}
.search-bar{display:flex;align-items:stretch;gap:0;max-width:320px}
.search-bar input{flex:1;padding:9px 14px;border:1.5px solid var(--border-light);border-right:none;border-radius:var(--radius-sm) 0 0 var(--radius-sm);font-family:var(--font-body);font-size:.85rem;outline:none;transition:border-color .2s}
.search-bar input:focus{border-color:var(--accent)}
.search-bar button{padding:9px 14px;border:1.5px solid var(--border-light);border-left:none;background:var(--bg-2);cursor:pointer;border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-muted);font-size:.875rem}
.search-bar button:hover{background:var(--accent);color:white;border-color:var(--accent)}
.admin-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.admin-select{width:100%;padding:10px 14px;border:1.5px solid var(--border-light);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.85rem;color:var(--text);background:white;outline:none;transition:border-color .2s;cursor:pointer}
.admin-select:focus{border-color:var(--accent)}
.quick-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1.5rem}
.quick-action{display:flex;align-items:center;gap:8px;background:white;border:1.5px solid var(--border-light);border-radius:var(--radius-sm);padding:8px 16px;font-size:.82rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .2s;text-decoration:none}
.quick-action:hover{border-color:var(--accent);color:var(--accent);background:rgba(108,71,255,.03)}
.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}
.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.4}
.empty-state-text{font-size:1rem;font-weight:600;margin-bottom:.5rem}
.empty-state-sub{font-size:.85rem}
.pagination-nav{display:flex;justify-content:center;margin-top:2rem}
.pagination{display:flex;gap:6px;list-style:none;align-items:center}
.pagination li a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1.5px solid var(--border-light);font-size:.85rem;color:var(--text-muted);transition:all .2s;text-decoration:none}
.pagination li.active a{background:var(--accent);color:white;border-color:var(--accent)}
.pagination li a:hover{border-color:var(--accent);color:var(--accent)}

/* ── Profile ───────────────────────────────────────────────── */
.profile-grid{display:grid;grid-template-columns:240px 1fr;gap:2rem;align-items:start}

/* ── Animations ────────────────────────────────────────────── */
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
@keyframes fadeInRight{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.animate-on-scroll{opacity:0;transform:translateY(30px);transition:opacity .7s,transform .7s}
.animate-on-scroll.visible{opacity:1;transform:none}
.animate-on-scroll.delay-1{transition-delay:.1s}
.animate-on-scroll.delay-2{transition-delay:.2s}
.animate-on-scroll.delay-3{transition-delay:.3s}
.animate-on-scroll.delay-4{transition-delay:.4s}
.animate-on-scroll.delay-5{transition-delay:.5s}

/* ── Toast ─────────────────────────────────────────────────── */
#toast-container{position:fixed;bottom:2rem;right:2rem;z-index:9999;display:flex;flex-direction:column;gap:10px}
.toast{background:white;border-radius:12px;padding:1rem 1.25rem;box-shadow:0 8px 32px rgba(0,0,0,.12);border-left:4px solid var(--accent);display:flex;align-items:center;gap:12px;font-size:.85rem;max-width:320px;animation:toastIn .4s both;font-family:var(--font-body)}
.toast.success{border-left-color:var(--accent-3)}
.toast.error{border-left-color:#ef4444}
.toast.warning{border-left-color:#f59e0b}
.toast-icon{font-size:1.1rem}
.toast-message{flex:1;color:var(--text)}
.toast-close{cursor:pointer;color:var(--text-muted);background:none;border:none;font-size:1.1rem}
@keyframes toastIn{from{transform:translateX(100%);opacity:0}to{transform:none;opacity:1}}

/* ── Google Reviews ────────────────────────────────────────── */
.google-reviews-section{padding:60px 2rem;background:var(--bg-2)}

/* ── Misc utils ────────────────────────────────────────────── */
.text-center{text-align:center}
.text-accent{color:var(--accent)}
.text-muted{color:var(--text-muted)}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-4{margin-bottom:2rem}
.d-flex{display:flex}.align-center{align-items:center}
.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}
.overflow-x-auto{overflow-x:auto;-webkit-overflow-scrolling:touch}

/* ═══════════════════════════════════════════════════════════
   TEAM SECTION — Animated Cards (Screenshot Style)
═══════════════════════════════════════════════════════════ */
.team-ss-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.team-ss-card{text-align:center;cursor:default}
.team-ss-photo-wrap{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:3/3.5;background:var(--bg-3);margin-bottom:1.1rem;box-shadow:0 4px 20px rgba(0,0,0,.06);transition:box-shadow .35s var(--ease),transform .35s var(--spring)}
.team-ss-card:hover .team-ss-photo-wrap{box-shadow:0 16px 48px rgba(108,71,255,.18);transform:translateY(-6px)}
.team-ss-photo{width:100%;height:100%;object-fit:cover;transition:transform .5s,filter .4s;display:block}
.team-ss-card:hover .team-ss-photo{transform:scale(1.05);filter:brightness(.8)}
.team-ss-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#f1f0ff,#e8e3ff);display:flex;align-items:center;justify-content:center;transition:filter .4s}
.team-ss-card:hover .team-ss-placeholder{filter:brightness(.92)}
.team-ss-initials{font-family:var(--font-display);font-size:4rem;font-weight:900;color:rgba(108,71,255,.22);transition:color .3s}
.team-ss-card:hover .team-ss-initials{color:rgba(108,71,255,.45)}
.team-ss-socials{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:center;gap:.5rem;padding:.875rem .75rem;background:linear-gradient(to top,rgba(10,10,15,.72),transparent);transform:translateY(100%);opacity:0;transition:transform .35s var(--spring),opacity .25s}
.team-ss-card:hover .team-ss-socials{transform:translateY(0);opacity:1}
.team-ss-social{width:36px;height:36px;border-radius:50%;background:white;display:flex;align-items:center;justify-content:center;color:var(--text);font-size:.85rem;text-decoration:none;transition:all .2s;box-shadow:0 2px 8px rgba(0,0,0,.12)}
.team-ss-social:hover{background:var(--accent);color:white;transform:scale(1.12)}
.team-ss-info{padding:0 .25rem}
.team-ss-role{font-size:.75rem;color:var(--text-muted);margin-bottom:4px}
.team-ss-name{font-family:var(--font-display);font-size:1.05rem;font-weight:800;color:var(--text);letter-spacing:-.01em;transition:color .2s;margin-bottom:.35rem}
.team-ss-card:hover .team-ss-name{color:var(--accent)}
.team-ss-bio{font-size:.78rem;color:var(--text-muted);line-height:1.6}

/* ═══════════════════════════════════════════════════════════
   PORTFOLIO DETAIL PAGE
═══════════════════════════════════════════════════════════ */
.portfolio-detail-hero{background:var(--primary);padding:140px 2rem 80px;position:relative;overflow:hidden}
.portfolio-detail-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(108,71,255,.2),transparent 60%)}
.portfolio-meta-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;margin:2rem 0}
.portfolio-meta-item{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:1rem;text-align:center}
.portfolio-meta-label{font-size:.7rem;color:rgba(255,255,255,.5);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.portfolio-meta-value{font-size:.9rem;color:white;font-weight:700}
.portfolio-content{max-width:900px}
.portfolio-tech-tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}
.tech-tag{background:rgba(108,71,255,.1);color:var(--accent);padding:5px 13px;border-radius:99px;font-size:.78rem;font-weight:700;border:1px solid rgba(108,71,255,.2)}

/* ═══════════════════════════════════════════════════════════
   FULL RESPONSIVE SYSTEM
═══════════════════════════════════════════════════════════ */

/* Navbar */
@media(max-width:900px){.nav-links,.nav-cta .btn-nav{display:none!important}.menu-toggle{display:flex!important}.nav-inner{height:68px;padding:0 1.25rem}}
@media(min-width:901px){.menu-toggle{display:none!important}.mobile-menu{display:none!important}}

/* Hero — full mobile fix */
@media(max-width:1100px){.hero-content{grid-template-columns:1fr;gap:2.5rem;max-width:720px}.hero-visual{order:-1}.floating-cards{right:0}}
@media(max-width:768px){
  .hero{padding:100px 1.25rem 60px;min-height:auto}
  .hero-content{gap:1.5rem}
  .hero-title{font-size:clamp(1.9rem,7.5vw,2.8rem)}
  .hero-subtitle{font-size:.9rem;margin-bottom:1.75rem}
  .hero-actions{flex-direction:column;gap:.75rem;width:100%}
  .hero-actions .btn{width:100%;justify-content:center;padding:14px 20px}
  .hero-stats{gap:1.25rem;margin-top:2rem;flex-wrap:wrap}
  .hero-stat-number{font-size:1.5rem}
  .hero-badge{font-size:.7rem;padding:6px 12px}
}
@media(max-width:560px){
  .hero{padding:88px 1rem 52px}
  .hero-title{font-size:clamp(1.7rem,8vw,2.2rem)}
  .hero-visual{display:none}
  .hero-stats{gap:1rem}
  .hero-stat{min-width:calc(50% - .5rem)}
}
@media(max-width:380px){.hero-title{font-size:1.6rem}.hero-stats{flex-wrap:wrap}}

/* Sections */
@media(max-width:768px){.section{padding:56px 1.25rem}.section-sm{padding:40px 1.25rem}.section-title{font-size:clamp(1.5rem,5vw,2rem)}.section-header{margin-bottom:2rem}}

/* Services */
@media(max-width:1024px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.services-grid{grid-template-columns:1fr}.service-card{padding:1.5rem}}

/* Features */
@media(max-width:900px){.features-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.features-grid{grid-template-columns:1fr}}

/* Portfolio */
@media(max-width:900px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.portfolio-grid{grid-template-columns:1fr}.portfolio-filter{overflow-x:auto;flex-wrap:nowrap;padding-bottom:.5rem}.filter-btn{flex-shrink:0}}

/* Testimonials */
@media(max-width:900px){.testimonial-card{min-width:calc(50% - .75rem)}}
@media(max-width:540px){.testimonial-card{min-width:100%}}

/* CTA */
@media(max-width:768px){.cta-section{padding:48px 1.5rem;border-radius:20px}.cta-actions{flex-direction:column;align-items:center}.cta-actions .btn{width:100%;justify-content:center;max-width:320px}}

/* Contact */
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:2.5rem}.contact-map{height:200px}}
@media(max-width:540px){.contact-form{padding:1.5rem}.form-row{grid-template-columns:1fr}}

/* About grids */
@media(max-width:900px){.about-main-grid{grid-template-columns:1fr!important;gap:2.5rem!important}.mission-vision-grid{grid-template-columns:1fr}}

/* Team */
@media(max-width:1100px){.team-ss-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.team-ss-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}}
@media(max-width:420px){.team-ss-grid{grid-template-columns:1fr}}

/* Footer */
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column;text-align:center}footer{padding:56px 1.25rem 32px}}

/* Auth */
@media(max-width:540px){.auth-card{padding:2rem 1.5rem;border-radius:16px}.auth-page{padding:1rem;align-items:flex-start;padding-top:2rem}}

/* Page hero */
@media(max-width:640px){.page-hero{padding:120px 1.25rem 70px}.page-hero-title{font-size:clamp(1.8rem,7vw,2.5rem)}.page-hero-sub{font-size:.875rem}}

/* Modal */
@media(max-width:560px){.modal{padding:1.75rem 1.25rem;margin:0}.modal-overlay{padding:.5rem;align-items:flex-end}.modal{border-radius:20px 20px 0 0;max-height:85vh}}

/* Admin */
@media(max-width:900px){
  .admin-sidebar{transform:translateX(-100%)}
  .admin-sidebar.open{transform:translateX(0)}
  .admin-main{margin-left:0!important}
  #sidebar-toggle{display:flex!important}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:520px){.stats-grid{grid-template-columns:1fr}.admin-content{padding:1rem}.admin-topbar{padding:.875rem 1rem}.admin-card-body{padding:1rem}.admin-form-grid{grid-template-columns:1fr}}

/* Profile */
@media(max-width:720px){.profile-grid{grid-template-columns:1fr!important}}

/* Service detail */
@media(max-width:900px){.service-detail-grid{grid-template-columns:1fr!important}}

/* Touch targets */
@media(pointer:coarse){.btn,.btn-nav,.service-btn,.filter-btn,.action-btn,.sidebar-link{min-height:44px}}

/* Large screens */
@media(min-width:1400px){.container,.hero-content{max-width:1380px}.section-title{font-size:3.2rem}}

/* ═══════════════════════════════════════════════════════════
   ARCHED TEAM CARDS (screenshot style)
═══════════════════════════════════════════════════════════ */
.arch-team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
}
/* Card */
.arch-card {
  cursor: default;
  transition: transform .35s var(--spring);
}
.arch-card:hover { transform: translateY(-6px); }

/* Photo wrap — arch shape */
.arch-photo-wrap {
  position: relative;
  overflow: hidden;
  /* arch = rectangle bottom + rounded top */
  border-radius: 120px 120px 20px 20px;
  aspect-ratio: .85;
  background: linear-gradient(135deg, #f0eeff, #e8e3ff);
  box-shadow: 0 4px 24px rgba(0,0,0,.08);
  transition: box-shadow .35s;
  margin-bottom: 1.25rem;
}
.arch-card:hover .arch-photo-wrap {
  box-shadow: 0 16px 48px rgba(108,71,255,.2);
}
.arch-photo {
  width: 100%; height: 100%;
  object-fit: cover; object-position: top;
  display: block;
  transition: transform .5s, filter .4s;
}
.arch-card:hover .arch-photo {
  transform: scale(1.04);
  filter: brightness(.82);
}
/* Placeholder */
.arch-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #ede9fe, #ddd6fe);
  transition: filter .4s;
}
.arch-card:hover .arch-placeholder { filter: brightness(.92); }
.arch-initial {
  font-family: var(--font-display);
  font-size: 5rem; font-weight: 900;
  color: rgba(108,71,255,.25);
  transition: color .3s;
  user-select: none;
}
.arch-card:hover .arch-initial { color: rgba(108,71,255,.45); }

/* Social icons — slide up from bottom */
.arch-socials {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  display: flex; justify-content: center; gap: .625rem;
  padding: 1rem .75rem;
  background: linear-gradient(to top, rgba(10,10,15,.72) 0%, transparent 100%);
  transform: translateY(100%);
  opacity: 0;
  transition: transform .35s var(--spring), opacity .25s;
}
.arch-card:hover .arch-socials {
  transform: translateY(0);
  opacity: 1;
}
.arch-social {
  width: 36px; height: 36px; border-radius: 50%;
  background: white; color: var(--text);
  display: flex; align-items: center; justify-content: center;
  font-size: .85rem; text-decoration: none;
  transition: all .2s;
  box-shadow: 0 2px 10px rgba(0,0,0,.15);
}
.arch-social:hover {
  background: var(--accent); color: white;
  transform: scale(1.12) translateY(-2px);
}

/* Info below photo */
.arch-info { text-align: center; padding: 0 .5rem; }
.arch-name {
  font-family: var(--font-display);
  font-size: 1.1rem; font-weight: 800;
  color: var(--text); letter-spacing: -.01em;
  margin-bottom: 4px;
  transition: color .2s;
}
.arch-card:hover .arch-name { color: var(--accent); }
.arch-role {
  font-size: .8rem; color: var(--text-muted);
}

/* Responsive arch grid */
@media(max-width:1100px) { .arch-team-grid { grid-template-columns: repeat(3,1fr); } }
@media(max-width:768px)  { .arch-team-grid { grid-template-columns: repeat(2,1fr); gap: 1.25rem; } }
@media(max-width:460px)  { .arch-team-grid { grid-template-columns: 1fr 1fr; gap: 1rem; }
  .arch-photo-wrap { border-radius: 80px 80px 16px 16px; }
  .arch-initial { font-size: 3.5rem; }
}

/* ═══════════════════════════════════════════════════════════
   TESTIMONIAL SLIDER v2 — FULLY FIXED
═══════════════════════════════════════════════════════════ */
.tslider-wrap {
  overflow: hidden;
  position: relative;
}
.tslider-track {
  display: flex;
  gap: 1.5rem;
  transition: transform .5s var(--ease);
  will-change: transform;
}
.tslider-card {
  background: white;
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  padding: 2rem;
  flex-shrink: 0;
  /* width set by JS */
}
.tslider-text-wrap { margin-bottom: 1.5rem; }
.tslider-text {
  font-size: .9rem; line-height: 1.8;
  color: var(--text-muted); font-style: italic;
  margin: 0 0 .35rem;
}
.tslider-seemore {
  background: none; border: none; cursor: pointer;
  color: var(--accent); font-size: .8rem; font-weight: 700;
  padding: 0; font-family: var(--font-body);
  transition: opacity .2s;
}
.tslider-seemore:hover { opacity: .7; }
.tslider-controls {
  display: flex; align-items: center; justify-content: center;
  gap: 12px; margin-top: 2rem;
}

/* ═══════════════════════════════════════════════════════════
   ADMIN DASHBOARD — modern
═══════════════════════════════════════════════════════════ */
.dash-stat-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 1.25rem;
  margin-bottom: 1.75rem;
}
.dash-stat {
  background: white;
  border-radius: var(--radius);
  border: 1px solid var(--border-light);
  padding: 1.4rem 1.5rem;
  display: flex; align-items: center; gap: 14px;
  transition: all .3s; position: relative; overflow: hidden;
}
.dash-stat::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 3px;
  background: var(--stat-color, var(--accent));
  transform: scaleX(0); transform-origin: left;
  transition: transform .35s;
}
.dash-stat:hover { box-shadow: var(--card-shadow); transform: translateY(-2px); }
.dash-stat:hover::after { transform: scaleX(1); }
.dash-stat-icon {
  width: 48px; height: 48px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.25rem; flex-shrink: 0;
  background: color-mix(in srgb, var(--stat-color, var(--accent)) 12%, transparent);
  color: var(--stat-color, var(--accent));
}
.dash-stat-body {}
.dash-stat-num {
  font-family: var(--font-display);
  font-size: 1.9rem; font-weight: 900; line-height: 1;
  color: var(--text);
}
.dash-stat-label { font-size: .78rem; color: var(--text-muted); font-weight:600; margin-top: 2px; }
.dash-stat-trend {
  position: absolute; top: .875rem; right: .875rem;
  font-size: .68rem; font-weight: 700; padding: 3px 8px;
  border-radius: 6px;
}
.dash-trend-up   { background: rgba(0,212,170,.1);  color: var(--accent-3); }
.dash-trend-down { background: rgba(239,68,68,.1);  color: #ef4444; }
.dash-trend-new  { background: rgba(108,71,255,.1); color: var(--accent); }

.dash-row { display: grid; grid-template-columns: 1.6fr 1fr; gap: 1.25rem; }
.dash-card {
  background: white; border-radius: var(--radius);
  border: 1px solid var(--border-light); overflow: hidden;
}
.dash-card-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.25rem; border-bottom: 1px solid var(--border-light);
}
.dash-card-title { font-family: var(--font-display); font-size: .9rem; font-weight: 800; }
.dash-activity-item {
  display: flex; align-items: center; gap: 12px;
  padding: .875rem 1.25rem; border-bottom: 1px solid var(--border-light);
  transition: background .15s;
}
.dash-activity-item:hover { background: var(--bg-2); }
.dash-activity-item:last-child { border-bottom: none; }
.dash-activity-icon {
  width: 36px; height: 36px; border-radius: 10px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; font-size: .9rem;
}
.dash-chart-bar-wrap { padding: 1.25rem; }
.dash-bar-item { margin-bottom: 1rem; }
.dash-bar-label { display: flex; justify-content: space-between; font-size: .78rem; font-weight: 600; margin-bottom: 5px; color: var(--text-muted); }
.dash-bar { height: 8px; background: var(--bg-3); border-radius: 99px; overflow: hidden; }
.dash-bar-fill { height: 100%; border-radius: 99px; background: var(--accent); transition: width 1s var(--ease); }

@media(max-width:1024px) { .dash-stat-grid { grid-template-columns: repeat(2,1fr); } .dash-row { grid-template-columns: 1fr; } }
@media(max-width:560px)  { .dash-stat-grid { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════════
   ADMIN LIVE CHAT PANEL v3 — Modern
═══════════════════════════════════════════════════════════ */
.lcp-wrap {
  display: grid;
  grid-template-columns: 300px 1fr;
  height: calc(100vh - 168px);
  min-height: 540px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 4px 32px rgba(0,0,0,.08);
  border: 1px solid var(--border-light);
}
/* sidebar */
.lcp-sidebar {
  background: white; border-right: 1px solid var(--border-light);
  display: flex; flex-direction: column; overflow: hidden;
}
.lcp-sidebar-head {
  padding: .875rem 1rem; border-bottom: 1px solid var(--border-light);
  display: flex; align-items: center; justify-content: space-between;
  flex-shrink: 0;
}
.lcp-sidebar-title { font-family: var(--font-display); font-size: .875rem; font-weight: 800; }
.lcp-search { padding: .5rem .875rem; border-bottom: 1px solid var(--border-light); flex-shrink: 0; }
.lcp-search input {
  width: 100%; padding: 8px 12px;
  border: 1.5px solid var(--border-light); border-radius: 10px;
  font-size: .8rem; outline: none; font-family: var(--font-body);
  transition: border-color .2s;
}
.lcp-search input:focus { border-color: var(--accent); }
.lcp-sessions { overflow-y: auto; flex: 1; }
.lcp-session-item {
  padding: .75rem .875rem; border-bottom: 1px solid #f8f9fe;
  cursor: pointer; transition: background .15s;
  display: flex; align-items: center; gap: 9px; position: relative;
}
.lcp-session-item:hover { background: #f8f9fe; }
.lcp-session-item.active { background: rgba(108,71,255,.05); }
.lcp-session-item.active::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px; background: var(--accent); border-radius: 0 2px 2px 0;
}
.lcp-avatar {
  width: 38px; height: 38px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, var(--accent), #8b5cf6);
  color: white; display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-weight: 900; font-size: .9rem;
}
.lcp-session-info { flex: 1; min-width: 0; }
.lcp-session-name { font-weight: 700; font-size: .82rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lcp-session-preview { font-size: .72rem; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 1px; }
.lcp-session-meta { display: flex; flex-direction: column; align-items: flex-end; gap: 3px; flex-shrink: 0; }
.lcp-session-time { font-size: .64rem; color: var(--text-light); }
.lcp-unread-badge {
  background: var(--accent); color: white;
  width: 17px; height: 17px; border-radius: 50%;
  font-size: .58rem; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
}
.lcp-mode-tag {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 1px 6px; border-radius: 99px; font-size: .58rem; font-weight: 700;
}
.lcp-mode-tag.bot    { background: rgba(108,71,255,.1); color: var(--accent); }
.lcp-mode-tag.human  { background: rgba(0,212,170,.1);  color: var(--accent-3); }
.lcp-mode-tag.offline{ background: rgba(239,68,68,.1);  color: #ef4444; }

/* main */
.lcp-main { background: #f4f6fb; display: flex; flex-direction: column; overflow: hidden; }
.lcp-topbar {
  background: white; padding: .875rem 1.25rem;
  border-bottom: 1px solid var(--border-light);
  display: flex; align-items: center; justify-content: space-between;
  flex-shrink: 0;
}
.lcp-user-info { display: flex; align-items: center; gap: 10px; min-width: 0; }
.lcp-user-avatar {
  width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, var(--accent), #8b5cf6);
  color: white; font-family: var(--font-display); font-weight: 900;
  display: flex; align-items: center; justify-content: center;
}
.lcp-user-name { font-weight: 800; font-size: .875rem; }
.lcp-user-meta { font-size: .7rem; color: var(--text-muted); }
.lcp-topbar-actions { display: flex; gap: .5rem; flex-shrink: 0; align-items: center; }

/* messages area */
.lcp-messages {
  flex: 1; overflow-y: auto; padding: 1.25rem;
  display: flex; flex-direction: column; gap: .625rem; min-height: 0;
}
.lcp-messages::-webkit-scrollbar { width: 4px; }
.lcp-messages::-webkit-scrollbar-thumb { background: #d1d5db; border-radius: 2px; }

.lcp-msg { display: flex; align-items: flex-end; gap: 8px; animation: msgIn .25s ease both; }
@keyframes msgIn { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:none} }
.lcp-msg.user  { flex-direction: row; }
.lcp-msg.admin, .lcp-msg.bot { flex-direction: row-reverse; }
.lcp-msg-avatar {
  width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: .68rem; font-weight: 700; color: white;
}
.lcp-msg.user  .lcp-msg-avatar { background: linear-gradient(135deg,#64748b,#475569); }
.lcp-msg.admin .lcp-msg-avatar { background: linear-gradient(135deg,var(--accent),#4c1d95); }
.lcp-msg.bot   .lcp-msg-avatar { background: linear-gradient(135deg,var(--accent-3),#047857); }
.lcp-msg-bubble {
  max-width: 70%; padding: .6rem .9rem; font-size: .875rem;
  line-height: 1.55; word-break: break-word; border-radius: 14px;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.lcp-msg.user  .lcp-msg-bubble { background: white; color: var(--text); border: 1px solid #e8ecf3; border-bottom-left-radius: 4px; }
.lcp-msg.admin .lcp-msg-bubble { background: linear-gradient(135deg, var(--accent), #4c1d95); color: white; border-bottom-right-radius: 4px; }
.lcp-msg.bot   .lcp-msg-bubble { background: #e8f8f4; color: #065f46; border-bottom-right-radius: 4px; border: 1px solid #a7f3d0; font-style: italic; font-size: .82rem; }
.lcp-msg-time { font-size: .63rem; color: #9ca3af; margin-top: 3px; padding: 0 3px; }
.lcp-date-divider {
  display: flex; align-items: center; gap: .75rem;
  margin: .375rem 0; color: var(--text-light); font-size: .7rem; text-align: center;
}
.lcp-date-divider::before,.lcp-date-divider::after { content:''; flex:1; height:1px; background: #e5e7eb; }

/* input */
.lcp-input-area {
  background: white; border-top: 1px solid var(--border-light);
  padding: .875rem 1.25rem; display: flex; gap: .75rem;
  align-items: flex-end; flex-shrink: 0;
}
.lcp-input {
  flex: 1; border: 1.5px solid var(--border-light); border-radius: 14px;
  padding: 10px 14px; font-size: .875rem; resize: none; outline: none;
  font-family: var(--font-body); line-height: 1.5; transition: border-color .2s;
  max-height: 100px; overflow-y: auto;
}
.lcp-input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(108,71,255,.06); }
.lcp-send-btn {
  width: 42px; height: 42px; border-radius: 12px; flex-shrink: 0;
  background: var(--accent); border: none; color: white; font-size: 1rem;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all .2s;
}
.lcp-send-btn:hover:not(:disabled) { background: #4c1d95; transform: scale(1.06); }
.lcp-send-btn:disabled { opacity: .5; cursor: not-allowed; }
.lcp-no-session {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 1rem; color: var(--text-muted);
}
.lcp-no-session-icon {
  width: 72px; height: 72px; border-radius: 50%;
  background: var(--bg-2); display: flex; align-items: center; justify-content: center;
  font-size: 1.75rem; color: var(--text-light);
}
/* Toggle */
.lcp-toggle-wrap { display: flex; align-items: center; gap: 8px; }
.lcp-toggle { position: relative; width: 44px; height: 22px; cursor: pointer; }
.lcp-toggle input { opacity: 0; width: 0; height: 0; }
.lcp-toggle-slider { position: absolute; inset: 0; border-radius: 99px; background: #cbd5e1; transition: background .3s; }
.lcp-toggle-slider::before { content:''; position:absolute; height:16px; width:16px; left:3px; bottom:3px; border-radius:50%; background:white; transition:transform .3s; box-shadow:0 1px 4px rgba(0,0,0,.15); }
.lcp-toggle input:checked + .lcp-toggle-slider { background: #22c55e; }
.lcp-toggle input:checked + .lcp-toggle-slider::before { transform: translateX(22px); }

/* Stats row */
.lcp-stats-row {
  display: flex; gap: .875rem; padding: .875rem 1.25rem;
  border-bottom: 1px solid var(--border-light); background: white; flex-shrink: 0;
  flex-wrap: wrap;
}
.lcp-stat { display: flex; align-items: center; gap: 8px; background: var(--bg-2); border-radius: 10px; padding: .5rem .875rem; font-size: .78rem; color: var(--text-muted); }
.lcp-stat strong { font-weight: 800; color: var(--text); font-size: .875rem; }

@media(max-width:900px) { .lcp-wrap { grid-template-columns: 1fr; height: auto; } .lcp-sidebar { height: 260px; } .lcp-main { min-height: 420px; } }

/* ═══════════════════════════════════════════════════════════
   ADMIN AJAX TABLE WRAPPER
═══════════════════════════════════════════════════════════ */
.ajax-table-toolbar {
  display: flex; align-items: center; gap: .75rem;
  padding: .875rem 1.25rem; border-bottom: 1px solid var(--border-light);
  flex-wrap: wrap; background: white;
}
.ajax-search-wrap { display: flex; flex: 1; min-width: 200px; max-width: 320px; }
.ajax-search-wrap input {
  flex: 1; padding: 9px 13px; border: 1.5px solid var(--border-light);
  border-right: none; border-radius: var(--radius-sm) 0 0 var(--radius-sm);
  font-size: .82rem; outline: none; font-family: var(--font-body); transition: border-color .2s;
}
.ajax-search-wrap input:focus { border-color: var(--accent); }
.ajax-search-wrap button {
  padding: 9px 13px; border: 1.5px solid var(--border-light); border-left: none;
  background: var(--bg-2); cursor: pointer; color: var(--text-muted);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0; font-size: .875rem; transition: all .2s;
}
.ajax-search-wrap button:hover { background: var(--accent); color: white; border-color: var(--accent); }
.ajax-filter-select {
  padding: 9px 13px; border: 1.5px solid var(--border-light); border-radius: var(--radius-sm);
  font-size: .82rem; font-family: var(--font-body); outline: none; cursor: pointer;
  background: white; color: var(--text); transition: border-color .2s;
}
.ajax-filter-select:focus { border-color: var(--accent); }
.ajax-table-wrap { overflow-x: auto; }
.ajax-loading { opacity: .4; pointer-events: none; }
.ajax-pagination {
  display: flex; align-items: center; justify-content: space-between;
  padding: .875rem 1.25rem; border-top: 1px solid var(--border-light);
  font-size: .78rem; color: var(--text-muted); flex-wrap: wrap; gap: .75rem;
}
.ajax-page-btns { display: flex; gap: 5px; }
.ajax-page-btn {
  width: 32px; height: 32px; border-radius: 8px;
  border: 1.5px solid var(--border-light); background: white;
  font-size: .78rem; cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all .2s; font-family: var(--font-body);
}
.ajax-page-btn:hover { border-color: var(--accent); color: var(--accent); }
.ajax-page-btn.active { background: var(--accent); color: white; border-color: var(--accent); }
.ajax-page-btn:disabled { opacity: .4; cursor: not-allowed; }
