﻿:root{
  --bg:#071427;
  --bg-2:#0a1f3f;
  --bg-3:#121330;
  --mobile-fab-size:54px;
  --mobile-fab-gap:12px;
  --mobile-fab-right:18px;
  --mobile-call-stack-height:46px;
  --chatbot-toggle-mobile-width:116px;
  --panel: rgba(13,30,58,0.62);
  --text:#f5f7ff;
  --muted:rgba(245,247,255,0.78);
  --gold:#e6c878;
  --dark-green:#133f48;
  --neon:#31c3ff;
  --violet:#8f78ff;
  --glass-border: rgba(126,210,255,0.28);
  --panel-border:rgba(126,210,255,0.24);
  --pointer-x:50vw;
  --pointer-y:50vh;
  --signature-border-rest:rgba(126,210,255,0.2);
  --signature-border-peak:rgba(126,210,255,0.42);
  --signature-inset-glow:rgba(49,195,255,0.08);
  --signature-line-cyan:rgba(49,195,255,0.82);
  --signature-line-violet:rgba(143,120,255,0.86);
  --signature-line-glow:rgba(49,195,255,0.7);
  --signature-pulse-duration:4.2s;
  --signature-sweep-duration:4.6s;
  --signature-sweep-form-duration:5.4s;
}
*{box-sizing:border-box}
html,body{height:100%}
html{
  background-color:var(--bg);
  background-image:
    radial-gradient(1400px 900px at -10% -20%, rgba(49,195,255,0.25), transparent 62%),
    radial-gradient(1200px 820px at 110% 120%, rgba(143,120,255,0.18), transparent 64%),
    repeating-linear-gradient(115deg, rgba(152,226,255,0.05) 0 1px, transparent 1px 24px),
    repeating-linear-gradient(25deg, rgba(152,226,255,0.028) 0 1px, transparent 1px 36px);
  background-repeat:repeat,repeat;
  background-attachment:fixed,fixed;
}
body{
  margin:0;
  background-color:var(--bg);
  background-image:
    radial-gradient(1200px 820px at -8% -18%, rgba(49,195,255,0.24), transparent 64%),
    radial-gradient(980px 720px at 108% 118%, rgba(143,120,255,0.2), transparent 68%),
    linear-gradient(160deg, var(--bg) 0%, var(--bg-2) 48%, var(--bg-3) 100%),
    repeating-linear-gradient(115deg, rgba(152,226,255,0.048) 0 1px, transparent 1px 24px),
    repeating-linear-gradient(25deg, rgba(152,226,255,0.024) 0 1px, transparent 1px 36px);
  background-repeat:no-repeat,no-repeat,repeat,repeat;
  background-position:0% 0%,100% 100%,0 0,0 0;
  background-size:auto,auto,auto,auto;
  color:var(--text);
  font-size:18px;
  line-height:1.62;
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  scroll-behavior:smooth;
  position:relative;
  overflow-x:hidden;
}

body[data-signature-mood="subtle"]{
  --signature-border-rest:rgba(126,210,255,0.14);
  --signature-border-peak:rgba(126,210,255,0.28);
  --signature-inset-glow:rgba(49,195,255,0.045);
  --signature-line-cyan:rgba(49,195,255,0.6);
  --signature-line-violet:rgba(143,120,255,0.62);
  --signature-line-glow:rgba(49,195,255,0.42);
  --signature-pulse-duration:6s;
  --signature-sweep-duration:6.8s;
  --signature-sweep-form-duration:7.4s;
}

body[data-signature-mood="balanced"]{
  --signature-border-rest:rgba(126,210,255,0.2);
  --signature-border-peak:rgba(126,210,255,0.42);
  --signature-inset-glow:rgba(49,195,255,0.08);
  --signature-line-cyan:rgba(49,195,255,0.82);
  --signature-line-violet:rgba(143,120,255,0.86);
  --signature-line-glow:rgba(49,195,255,0.7);
  --signature-pulse-duration:4.2s;
  --signature-sweep-duration:4.6s;
  --signature-sweep-form-duration:5.4s;
}

body[data-signature-mood="dramatic"]{
  --signature-border-rest:rgba(126,210,255,0.26);
  --signature-border-peak:rgba(126,210,255,0.62);
  --signature-inset-glow:rgba(49,195,255,0.16);
  --signature-line-cyan:rgba(49,195,255,0.95);
  --signature-line-violet:rgba(143,120,255,0.98);
  --signature-line-glow:rgba(49,195,255,0.88);
  --signature-pulse-duration:2.9s;
  --signature-sweep-duration:3.2s;
  --signature-sweep-form-duration:3.8s;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:radial-gradient(300px 300px at var(--pointer-x) var(--pointer-y), rgba(230,200,120,0.2), rgba(49,195,255,0.12) 38%, rgba(49,195,255,0.04) 56%, transparent 72%);
  opacity:0.8;
  z-index:0;
  transition:opacity .25s ease;
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, transparent 0 4%, rgba(125,219,255,0.1) 4% 4.2%, transparent 4.2% 100%),
    linear-gradient(0deg, transparent 0 6%, rgba(125,219,255,0.075) 6% 6.18%, transparent 6.18% 100%),
    radial-gradient(14px 14px at 18% 24%, rgba(148,228,255,0.26), transparent 74%),
    radial-gradient(16px 16px at 74% 66%, rgba(143,120,255,0.22), transparent 74%),
    radial-gradient(12px 12px at 48% 36%, rgba(230,200,120,0.24), transparent 76%);
  mix-blend-mode:screen;
  opacity:0.42;
  z-index:0;
  animation:circuitDrift 22s linear infinite;
}

@keyframes circuitDrift{
  0%{transform:translate3d(0,0,0)}
  50%{transform:translate3d(-1.2%, -1%, 0)}
  100%{transform:translate3d(0,0,0)}
}

main,
.site-header,
.site-footer,
.floating-call,
.chatbot-toggle,
.chatbot-panel,
.call-toast{
  position:relative;
  z-index:1;
}

section{scroll-margin-top:96px}

@media (prefers-reduced-motion:reduce){
  body::before,body::after{display:none}
  .hero-content::after,
  .contact-form::after{display:none}
}
@media (pointer:coarse){
  body::before,body::after{display:none}
}
.container{max-width:1100px;margin:0 auto;padding:2rem}

h1,h2,h3,h4{line-height:1.2;letter-spacing:0.01em}
p,li{line-height:1.62}

/* Header */
.site-header{position:sticky;top:0;z-index:60;background:linear-gradient(180deg,rgba(12,21,38,0.7),rgba(12,21,38,0.12));backdrop-filter: blur(8px);border-bottom:1px solid rgba(255,255,255,0.14)}
.header-inner{display:flex;align-items:center;gap:1rem;justify-content:space-between}
.logo{font-family:Orbitron,Inter, sans-serif;font-weight:600;color:var(--gold);letter-spacing:0.6px;text-decoration:none}
.nav{display:flex;gap:0.6rem;align-items:center;flex-wrap:wrap}
.nav a,
.nav-more > summary{
  color:var(--text);
  text-decoration:none;
  padding:0.52rem 0.44rem;
  border-radius:8px;
  font-weight:600;
  font-size:0.96rem;
  opacity:0.95;
  transition:all .28s ease;
}
.nav a:hover,
.nav-more > summary:hover,
.nav-more[open] > summary{
  color:var(--neon);
  text-shadow:0 0 12px rgba(49,195,255,0.34);
  background:rgba(126,210,255,0.08);
}
.nav-more{position:relative}
.nav-more > summary{
  display:inline-flex;
  align-items:center;
  gap:0.4rem;
  cursor:pointer;
  list-style:none;
}
.nav-more > summary::-webkit-details-marker{display:none}
.nav-more > summary i{font-size:0.78rem;transition:transform .24s ease}
.nav-more[open] > summary i{transform:rotate(180deg)}
.nav-more-menu{
  position:absolute;
  top:calc(100% + 0.45rem);
  right:0;
  min-width:220px;
  display:grid;
  gap:0.25rem;
  padding:0.5rem;
  border-radius:12px;
  background:rgba(12,22,38,0.97);
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:0 16px 32px rgba(0,0,0,0.42);
  z-index:90;
}
.nav-more:not([open]) .nav-more-menu{display:none}
.nav-more-menu a{
  display:block;
  white-space:nowrap;
}
.header-actions{display:flex;gap:0.5rem;align-items:center}
.call-desktop{
  position:relative;
  isolation:isolate;
  display:inline-flex;
  align-items:center;
  gap:0.5rem;
  padding:0.52rem 0.98rem;
  border-radius:12px;
  border:1px solid rgba(126,210,255,0.58);
  text-decoration:none;
  font-weight:700;
  color:#f9fcff;
  background:linear-gradient(135deg, rgba(22,52,84,0.92), rgba(18,38,66,0.86));
  box-shadow:0 0 0 1px rgba(126,210,255,0.2), 0 8px 22px rgba(49,195,255,0.24), 0 0 18px rgba(49,195,255,0.18);
  transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease, color .24s ease, background .24s ease;
  overflow:hidden;
}

.call-desktop::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  padding:1px;
  background:linear-gradient(125deg, rgba(126,210,255,0.9), rgba(49,195,255,0.78), rgba(143,120,255,0.72));
  mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  opacity:0.72;
  transition:opacity .24s ease;
  pointer-events:none;
  z-index:0;
}

.call-desktop > *{position:relative;z-index:1}

.call-desktop:hover{
  transform:translateY(-1px) scale(1.02);
  color:#ffffff;
  border-color:rgba(126,210,255,0.82);
  background:linear-gradient(135deg, rgba(25,58,92,0.96), rgba(20,44,77,0.9));
  box-shadow:0 0 0 1px rgba(126,210,255,0.34), 0 12px 28px rgba(49,195,255,0.34), 0 0 24px rgba(49,195,255,0.3);
}

.call-desktop:hover::before{opacity:0.96}

.call-desktop:focus-visible{
  outline:none;
  box-shadow:0 0 0 2px rgba(5,15,30,0.95), 0 0 0 4px rgba(126,210,255,0.62), 0 10px 24px rgba(49,195,255,0.28);
}
.mobile-menu{
  display:none;
  background:transparent;
  border:1px solid rgba(255,255,255,0.2);
  color:var(--text);
  font-size:1.1rem;
  min-width:2.2rem;
  min-height:2.2rem;
  border-radius:8px;
  align-items:center;
  justify-content:center;
  padding:0.15rem;
}
.mobile-menu-glyph{display:block;line-height:1;font-size:1.25rem}

.mobile-nav-overlay{
  position:fixed;
  inset:0;
  background:rgba(3,10,22,0.52);
  backdrop-filter:blur(2px);
  opacity:0;
  pointer-events:none;
  transition:opacity .24s ease;
  z-index:58;
}
body.mobile-menu-open .mobile-nav-overlay{
  opacity:1;
  pointer-events:auto;
}

/* Hero */
.hero{position:relative;padding:4rem 0 3.2rem;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:radial-gradient(780px 520px at 8% 18%, rgba(230,200,120,0.1), transparent 44%), radial-gradient(660px 420px at 92% 82%, rgba(49,195,255,0.16), transparent 48%);opacity:0.9;z-index:0;animation:moveBg 20s linear infinite}
@keyframes moveBg{0%{background-position:0% 0%,100% 100%}50%{background-position:10% 5%,90% 95%}100%{background-position:0% 0%,100% 100%}}
.hero-content{position:relative;display:grid;grid-template-columns:1fr 360px;gap:2rem;align-items:center;z-index:2}
.hero-text h1{font-family:Orbitron,Inter;font-size:clamp(1.6rem,3vw,2.4rem);margin:0 0 1rem}
.lead{color:rgba(255,255,255,0.85);margin-bottom:1rem}
.hero-cta{display:flex;gap:1rem;align-items:center}
.btn{display:inline-flex;align-items:center;gap:0.6rem;padding:0.7rem 1rem;border-radius:10px;text-decoration:none;font-weight:700;transition:all .3s ease;position:relative;overflow:hidden}
.btn::after{content:"";position:absolute;inset:-120% auto auto -20%;width:55%;height:260%;transform:rotate(18deg);background:linear-gradient(90deg, transparent, rgba(255,255,255,0.26), transparent);opacity:0;transition:opacity .26s ease,left .6s ease}
.btn:hover::after{left:120%;opacity:1}
.btn-gold{background:linear-gradient(180deg,var(--gold),#b88b2a);color:#050505;box-shadow:0 10px 30px rgba(212,175,55,0.18);border:1px solid rgba(255,255,255,0.12)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(212,175,55,0.3)}
.btn-outline{background:rgba(126,210,255,0.08);border:1px solid rgba(126,210,255,0.42);color:var(--text)}
.btn-outline:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(49,195,255,0.22);background:rgba(126,210,255,0.13);border-color:rgba(126,210,255,0.6)}
.trust-bullets{display:flex;gap:1.4rem;list-style:none;padding:0;margin:1.2rem 0 0}
.trust-bullets li{display:flex;align-items:center;gap:0.6rem;color:rgba(255,255,255,0.9)}
.trust-bullets .neon{color:var(--neon);text-shadow:0 0 8px rgba(49,195,255,0.25)}
.hero-art .glass-card{background:linear-gradient(180deg, rgba(22,58,96,0.76), rgba(18,48,79,0.72));padding:1.2rem;border-radius:16px;border:1px solid var(--glass-border);backdrop-filter:blur(10px);box-shadow:0 10px 42px rgba(0,0,0,0.55), inset 0 1px 0 rgba(255,255,255,0.12)}

/* IT Nexyra signature accents: hero + form only */
.hero-content,
.contact-form{position:relative;overflow:hidden}

.hero-content::before,
.hero-content::after,
.contact-form::before,
.contact-form::after{
  content:"";
  position:absolute;
  pointer-events:none;
}

.hero-content::before,
.contact-form::before{
  inset:0;
  border:1px solid var(--signature-border-rest);
  border-radius:16px;
  animation:signaturePulse var(--signature-pulse-duration) ease-in-out infinite;
}

.hero-content::after,
.contact-form::after{
  width:140px;
  height:2px;
  top:0;
  left:-160px;
  background:linear-gradient(90deg, transparent 0%, var(--signature-line-cyan) 55%, var(--signature-line-violet) 100%);
  box-shadow:0 0 14px var(--signature-line-glow);
  border-radius:1px;
  animation:signatureSweep var(--signature-sweep-duration) linear infinite;
}

.contact-form::before{border-radius:16px}
.contact-form::after{animation-duration:var(--signature-sweep-form-duration)}

@keyframes signaturePulse{
  0%,100%{border-color:var(--signature-border-rest);box-shadow:inset 0 0 0 rgba(49,195,255,0)}
  50%{border-color:var(--signature-border-peak);box-shadow:inset 0 0 28px var(--signature-inset-glow)}
}

@keyframes signatureSweep{
  0%{top:0;left:-160px;width:140px;height:2px}
  25%{top:0;left:calc(100% + 20px);width:140px;height:2px}
  25.01%{top:-160px;left:calc(100% - 1px);width:2px;height:140px}
  50%{top:calc(100% + 20px);left:calc(100% - 1px);width:2px;height:140px}
  50.01%{top:calc(100% - 1px);left:calc(100% + 20px);width:140px;height:2px}
  75%{top:calc(100% - 1px);left:-160px;width:140px;height:2px}
  75.01%{top:calc(100% + 20px);left:-1px;width:2px;height:140px}
  100%{top:-160px;left:-1px;width:2px;height:140px}
}

.intro-video .video-wrap{
  border:1px solid var(--panel-border);
  border-radius:18px;
  overflow:hidden;
  background:rgba(7,20,39,0.72);
  box-shadow:0 20px 48px rgba(0,0,0,0.45);
}
.section.intro-video{padding-top:0.65rem}
.intro-video .container{padding-top:0.1rem}
.intro-video.section::before{display:none}
.brand-video{display:block;width:100%;height:auto}

/* Sections */
.section{padding:3.2rem 0}
.section{position:relative}
.section::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:1px;
  background:linear-gradient(90deg, transparent 0%, rgba(126,210,255,0.1) 20%, rgba(126,210,255,0.22) 50%, rgba(126,210,255,0.1) 80%, transparent 100%);
  pointer-events:none;
}

/* Improve spacing between hero and services */
.services{padding-top:4.8rem}

/* Preview toolbar styles */

.section-title{font-family:Orbitron,Inter;margin:0 0 0.3rem;color:var(--gold)}
.section-sub{color:rgba(255,255,255,0.8);margin-bottom:1rem}
.section-title{font-size:clamp(1.35rem,2.5vw,2rem);text-shadow:0 0 18px rgba(49,195,255,0.14)}
.section-sub{max-width:70ch}

img,video,iframe{
  max-width:100%;
  height:auto;
}

.services-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:1.2rem;
}

.services .section-sub{
  text-align:left;
  margin-left:0;
  margin-right:0;
  margin-bottom:1.35rem;
}

.service-card{
  background:var(--panel);
  padding:1.35rem 1.2rem;
  border-radius:14px;
  border:1px solid var(--panel-border);
  backdrop-filter:blur(6px);
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  text-align:left;
  gap:0.42rem;
  min-height:190px;
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.service-card:hover,
.plan-card:hover,
.step:hover,
.area-card:hover,
.contact-info .info-card:hover,
.why-card:hover{
  transform:translateY(-4px);
  border-color:rgba(126,210,255,0.5);
  box-shadow:0 18px 34px rgba(10,18,36,0.55), 0 0 26px rgba(49,195,255,0.18);
}

.service-card h3{width:100%;margin:0 0 0.14rem}
.service-card .muted{width:100%;color:var(--muted);margin:0}
.service-card .card-icon{font-size:1.8rem;color:var(--neon);margin:0 0 0.48rem;text-shadow:0 0 16px rgba(49,195,255,0.28)}
.service-card.highlight{
  border-color:rgba(230,200,120,0.36);
  background:linear-gradient(180deg,rgba(26,54,84,0.82),rgba(18,40,66,0.76));
  box-shadow:0 0 0 1px rgba(230,200,120,0.12) inset;
}

.service-more-btn{
  margin-top:auto;
  padding:0.72rem 1.05rem;
  font-size:0.96rem;
}
.service-card,
.plan-card,
.step,
.area-card,
.contact-info .info-card,
.why-card{will-change:transform}

.why-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:1rem;
}

.why-card{
  background:linear-gradient(180deg, rgba(18,45,74,0.74), rgba(13,33,58,0.64));
  border:1px solid var(--panel-border);
  border-radius:14px;
  padding:1.35rem 1.2rem;
  backdrop-filter:blur(8px);
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  text-align:left;
  gap:0.42rem;
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.why-card .card-icon{
  font-size:1.8rem;
  color:var(--neon);
  margin:0 0 0.48rem;
  text-shadow:0 0 16px rgba(49,195,255,0.28);
}

.why-card h3{
  width:100%;
  margin:0 0 0.14rem;
  line-height:1.2;
  min-height:0;
}

.why-card p{
  width:100%;
  margin:0;
  line-height:1.58;
}

.services-page-hero{padding-bottom:1.6rem}
.services-page-intro{
  background:linear-gradient(180deg, rgba(18,45,74,0.76), rgba(12,29,50,0.72));
  border:1px solid rgba(126,210,255,0.22);
  border-radius:16px;
  padding:1.4rem 1.45rem;
  box-shadow:0 18px 42px rgba(0,0,0,0.34), inset 0 1px 0 rgba(255,255,255,0.08);
}
.services-page-intro .section-title{margin-bottom:0.45rem}
.services-page-intro .section-sub{margin:0;max-width:72ch}

.services-detail-list{display:grid;gap:1rem}
.service-detail-card{
  background:linear-gradient(180deg, rgba(18,45,74,0.74), rgba(13,33,58,0.64));
  border:1px solid rgba(126,210,255,0.22);
  border-radius:16px;
  padding:1.35rem 1.25rem;
  box-shadow:0 18px 42px rgba(0,0,0,0.34), inset 0 1px 0 rgba(255,255,255,0.08);
}
.service-detail-head{display:grid;grid-template-columns:auto 1fr;gap:0.9rem;align-items:start;margin-bottom:1rem}
.service-detail-head .card-icon{font-size:1.85rem;color:var(--neon);margin-top:0.1rem;text-shadow:0 0 16px rgba(49,195,255,0.24)}
.service-detail-head h2{margin:0 0 0.26rem;color:var(--gold);font-size:clamp(1.25rem,2.5vw,1.7rem)}
.service-detail-lead{margin:0;color:rgba(245,247,255,0.86);max-width:64ch}
.service-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0.95rem;margin-bottom:1rem}
.service-detail-block{
  background:rgba(8,22,40,0.44);
  border:1px solid rgba(126,210,255,0.16);
  border-radius:14px;
  padding:0.95rem 1rem;
}
.service-detail-block.full{grid-column:1 / -1}
.service-detail-block h3{margin:0 0 0.38rem;color:#eef9ff;font-size:1rem}
.service-detail-block p{margin:0;color:rgba(245,247,255,0.82)}
.service-detail-block ul{margin:0;padding-left:1.15rem;color:rgba(245,247,255,0.82);display:grid;gap:0.35rem}
.service-detail-actions{display:flex;gap:0.75rem;flex-wrap:wrap}

.content-page-hero{padding-bottom:1.45rem}
.content-page-hero-card{
  background:linear-gradient(180deg, rgba(18,45,74,0.76), rgba(12,29,50,0.72));
  border:1px solid rgba(126,210,255,0.22);
  border-radius:18px;
  padding:1.45rem 1.5rem;
  box-shadow:0 18px 42px rgba(0,0,0,0.34), inset 0 1px 0 rgba(255,255,255,0.08);
}
.content-page-hero-card .section-title{margin-bottom:0.45rem}
.content-page-hero-card .section-sub{margin:0;max-width:72ch}
.page-stat-row{display:flex;flex-wrap:wrap;gap:0.65rem;margin-top:1rem}
.page-stat{
  display:inline-flex;
  align-items:center;
  gap:0.45rem;
  padding:0.5rem 0.8rem;
  border-radius:999px;
  background:rgba(8,24,42,0.52);
  border:1px solid rgba(126,210,255,0.18);
  color:rgba(245,247,255,0.88);
}
.page-section-stack{display:grid;gap:1rem}
.page-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}
.content-card{
  background:linear-gradient(180deg, rgba(18,45,74,0.74), rgba(13,33,58,0.64));
  border:1px solid rgba(126,210,255,0.2);
  border-radius:16px;
  padding:1.2rem;
  box-shadow:0 18px 36px rgba(0,0,0,0.28), inset 0 1px 0 rgba(255,255,255,0.06);
  display:flex;
  flex-direction:column;
  gap:0.75rem;
}
.content-card h3,
.content-card h4,
.news-card-title{margin:0}
.content-card p,
.content-card ul{margin:0}
.content-card ul{padding-left:1.1rem;display:grid;gap:0.3rem;color:rgba(245,247,255,0.82)}
.meta-row{display:flex;flex-wrap:wrap;gap:0.45rem}
.meta-pill{
  display:inline-flex;
  align-items:center;
  gap:0.35rem;
  padding:0.38rem 0.7rem;
  border-radius:999px;
  background:rgba(126,210,255,0.08);
  border:1px solid rgba(126,210,255,0.18);
  color:rgba(245,247,255,0.9);
  font-size:0.88rem;
}
.card-foot{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:0.75rem;
  flex-wrap:wrap;
  margin-top:auto;
}
.status-note{color:rgba(255,235,185,0.92);font-weight:700}
.coming-soon-card{
  background:linear-gradient(135deg, rgba(22,52,84,0.9), rgba(14,34,60,0.88));
  border-style:dashed;
}
.testimonial-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}
.testimonial-card blockquote{
  margin:0;
  color:rgba(245,247,255,0.92);
  font-size:1.02rem;
}
.testimonial-card cite{font-style:normal;color:rgba(255,255,255,0.7)}
.testimonial-note{
  padding:0.95rem 1rem;
  border-radius:14px;
  border:1px dashed rgba(126,210,255,0.22);
  background:rgba(8,24,42,0.4);
  color:rgba(245,247,255,0.8);
}
.section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
  margin-bottom:1rem;
}
.section-head .section-sub{margin:0;max-width:66ch}
.thumb-placeholder,
.video-thumb,
.news-card-media-placeholder{
  min-height:190px;
  border-radius:14px;
  border:1px solid rgba(126,210,255,0.18);
  background:radial-gradient(circle at top left, rgba(212,175,55,0.18), transparent 38%), radial-gradient(circle at bottom right, rgba(49,195,255,0.18), transparent 42%), rgba(9,24,42,0.72);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:0.35rem;
  padding:1rem;
  color:#f8fcff;
}
.thumb-placeholder i,
.video-thumb i,
.news-card-media-placeholder i{font-size:1.6rem;color:var(--gold)}
.video-thumb{min-height:210px}
.resource-card-copy{display:grid;gap:0.5rem}
.resource-card-copy p{color:rgba(245,247,255,0.8)}
.news-feed-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(255px,1fr));gap:1rem}
.news-card{
  display:flex;
  flex-direction:column;
  color:var(--text);
  text-decoration:none;
  background:linear-gradient(180deg, rgba(18,45,74,0.74), rgba(13,33,58,0.64));
  border:1px solid rgba(126,210,255,0.2);
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 18px 36px rgba(0,0,0,0.28), inset 0 1px 0 rgba(255,255,255,0.06);
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.news-card:hover{
  transform:translateY(-4px);
  border-color:rgba(126,210,255,0.5);
  box-shadow:0 18px 34px rgba(10,18,36,0.55), 0 0 26px rgba(49,195,255,0.18);
}
.news-card-image{
  width:100%;
  aspect-ratio:16 / 9;
  object-fit:cover;
  display:block;
  background:rgba(9,24,42,0.72);
}
.news-card-media-placeholder{border-radius:0;min-height:0;aspect-ratio:16 / 9}
.news-card-body{display:grid;gap:0.55rem;padding:1rem}
.news-card-source{font-size:0.9rem;color:rgba(255,255,255,0.72)}
.news-card-date{font-size:0.9rem;color:rgba(255,255,255,0.68)}
.integration-note{
  padding:0.95rem 1rem;
  border-radius:14px;
  border:1px solid rgba(212,175,55,0.18);
  background:rgba(212,175,55,0.08);
  color:rgba(255,245,220,0.88);
}
.course-meta{display:grid;gap:0.55rem}
.course-price{
  display:inline-flex;
  align-items:center;
  width:max-content;
  padding:0.42rem 0.78rem;
  border-radius:999px;
  background:rgba(212,175,55,0.14);
  border:1px solid rgba(212,175,55,0.2);
  color:#ffe7a1;
  font-weight:700;
}
.cta-panel{
  background:linear-gradient(135deg, rgba(20,47,76,0.9), rgba(13,30,52,0.92));
  border:1px solid rgba(126,210,255,0.22);
  border-radius:18px;
  padding:1.4rem 1.45rem;
  display:grid;
  gap:1rem;
  box-shadow:0 18px 42px rgba(0,0,0,0.34), inset 0 1px 0 rgba(255,255,255,0.08);
}
.cta-panel-actions{display:flex;flex-wrap:wrap;gap:0.75rem}

.thank-you-page{
  min-height:calc(100vh - 92px);
  display:grid;
  place-items:center;
  padding:2rem 0 3rem;
}
.thank-you-wrap{width:min(100%, 760px)}
.thank-you-card{
  background:linear-gradient(180deg, rgba(18,45,74,0.78), rgba(12,29,50,0.78));
  border:1px solid rgba(126,210,255,0.22);
  border-radius:20px;
  padding:1.6rem 1.5rem;
  box-shadow:0 20px 48px rgba(0,0,0,0.38), inset 0 1px 0 rgba(255,255,255,0.08);
  display:grid;
  gap:1rem;
}
.thank-you-card{text-align:center}
.thank-you-copy{display:grid;gap:0.65rem;justify-items:center}
.thank-you-copy .section-sub{margin:0;max-width:34rem}
.thank-you-actions{display:flex;justify-content:center;flex-wrap:wrap;gap:0.75rem}
.thank-you-support{
  background:rgba(8,24,42,0.42);
  border:1px solid rgba(126,210,255,0.16);
  border-radius:16px;
  padding:1rem;
  display:grid;
  gap:0.35rem;
}
.thank-you-support p{margin:0}
.thank-you-support a,
.thank-you-support a:visited{
  color:#ffffff;
  text-decoration:none;
}
.thank-you-support a:hover,
.thank-you-support a:focus-visible{
  color:#ffffff;
}

.coming-soon-page{
  min-height:calc(100vh - 92px);
  display:grid;
  place-items:center;
  padding:2rem 0 3rem;
}
.coming-soon-wrap{width:min(100%, 760px)}
.coming-soon-card{
  background:linear-gradient(180deg, rgba(18,45,74,0.78), rgba(12,29,50,0.78));
  border:1px solid rgba(126,210,255,0.22);
  border-radius:20px;
  padding:1.6rem 1.5rem;
  box-shadow:0 20px 48px rgba(0,0,0,0.38), inset 0 1px 0 rgba(255,255,255,0.08);
  display:grid;
  gap:1rem;
  text-align:center;
}
.coming-soon-copy{display:grid;gap:0.65rem;justify-items:center}
.coming-soon-copy .section-sub{margin:0;max-width:36rem}
.coming-soon-note{
  margin:0;
  padding:0.9rem 1rem;
  border-radius:14px;
  border:1px dashed rgba(126,210,255,0.22);
  background:rgba(8,24,42,0.38);
  color:rgba(245,247,255,0.8);
}
.coming-soon-actions{display:flex;justify-content:center;flex-wrap:wrap;gap:0.75rem}

.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.2rem}
.card{background:var(--panel);padding:1.2rem;border-radius:12px;border:1px solid rgba(255,255,255,0.04);backdrop-filter:blur(6px);transition:transform .18s ease,box-shadow .18s ease}
.card:hover{transform:translateY(-6px);box-shadow:0 8px 30px rgba(49,195,255,0.12),0 8px 40px rgba(212,175,55,0.08);border-color:var(--gold)}
.card .card-icon{font-size:1.8rem;color:var(--neon);margin-bottom:0.6rem;text-shadow:0 0 12px rgba(49,195,255,0.2)}

.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.2rem;align-items:stretch}
.plan-card{
  background:linear-gradient(180deg,rgba(18,44,72,0.74),rgba(12,30,54,0.68));
  padding:1.5rem;
  border-radius:16px;
  border:1px solid rgba(230,200,120,0.22);
  display:flex;
  flex-direction:column;
  gap:0.9rem;
  height:100%;
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.plan-card:hover{
  transform:translateY(-4px);
  border-color:rgba(230,200,120,0.46);
  box-shadow:0 18px 34px rgba(0,0,0,0.45),0 0 24px rgba(230,200,120,0.1);
}
.plan-head{display:flex;flex-direction:column;align-items:flex-start;gap:0.4rem}
.plan-head h3{margin:0;color:var(--gold);font-family:Orbitron,Inter,sans-serif;font-size:1.05rem;letter-spacing:0.04em}
.plan-card ul{list-style:none;padding:0;margin:0;display:grid;gap:0.52rem;flex:1}
.plan-card li{
  display:flex;
  align-items:flex-start;
  gap:0.55rem;
  color:rgba(245,247,255,0.88);
  font-size:0.94rem;
  line-height:1.5;
}
.plan-card li::before{
  content:"✓";
  color:var(--neon);
  font-weight:700;
  flex-shrink:0;
  font-size:0.82rem;
  margin-top:0.16rem;
}
.maintenance-cta{display:flex;justify-content:center;margin:1.2rem 0 0.8rem}
.price{color:var(--gold);font-weight:800;font-size:1.02rem}
.services-maintenance-plans{
  padding-top:5.4rem;
  scroll-margin-top:120px;
}
.services-maintenance-plans .section-title{
  max-width:none;
  margin-left:auto;
  margin-right:auto;
  font-size:clamp(1.45rem,2.4vw,2.05rem);
  text-align:center;
}
.package-sections .package-group .section-title{
  max-width:none;
  white-space:nowrap;
  text-align:center;
}
.maintenance-intro{
  max-width:640px;
  margin:0 auto 2.2rem;
  text-align:center;
}
.maintenance-intro h3{
  margin:0 0 0.55rem;
  color:var(--gold);
  font-family:Orbitron,Inter,sans-serif;
  font-size:clamp(1.05rem,1.85vw,1.38rem);
  letter-spacing:0.02em;
}
.maintenance-intro p{
  margin:0;
  color:rgba(245,247,255,0.82);
  max-width:56ch;
  margin-left:auto;
  margin-right:auto;
}
.maintenance-note{margin-top:1.2rem}
.package-sections .package-group{
  scroll-margin-top:120px;
}
.package-sections .package-group + .package-group{
  margin-top:4.8rem;
}
.package-subheading{
  max-width:58ch;
  margin-left:auto;
  margin-right:auto;
  margin-bottom:2.2rem;
  text-align:center;
}
.package-best-for{
  margin:0;
  color:rgba(245,247,255,0.78);
  font-size:0.94rem;
  line-height:1.55;
}

.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.2rem}
.step{
  background:var(--panel);
  padding:1.5rem 1.2rem;
  border-radius:14px;
  text-align:center;
  border:1px solid var(--panel-border);
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.step-icon{font-size:2rem;color:var(--neon);margin-bottom:0.75rem;text-shadow:0 0 16px rgba(49,195,255,0.28)}

.area-card{background:var(--panel);padding:1rem;border-radius:14px;border:1px solid var(--panel-border)}
.area-card-full{max-width:980px;margin:0 auto;padding:1.35rem 1.4rem 1.25rem}

.service-area-note{
  margin:0 0 0.78rem;
  color:rgba(229,242,255,0.84);
}

.county-accordion{display:grid;gap:0.55rem}

.county-item{
  border:1px solid rgba(126,210,255,0.22);
  border-radius:11px;
  background:rgba(10,29,52,0.56);
  overflow:hidden;
  transition:border-color .24s ease, box-shadow .24s ease, background .24s ease;
}

.county-item:hover{
  border-color:rgba(126,210,255,0.42);
  box-shadow:0 0 18px rgba(49,195,255,0.12);
  background:rgba(12,34,60,0.62);
}

.county-item summary{
  list-style:none;
  cursor:pointer;
  padding:0.64rem 0.8rem;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:0.8rem;
  color:rgba(240,248,255,0.95);
}

.county-item summary::-webkit-details-marker{display:none}

.county-item summary::after{
  content:"+";
  font-size:1.1rem;
  line-height:1;
  color:var(--neon);
  transition:transform .25s ease, color .25s ease;
}

.county-item[open] summary::after{
  transform:rotate(45deg);
  color:#9ee7ff;
}

.town-list-wrap{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows .3s ease;
}

.county-item[open] .town-list-wrap{grid-template-rows:1fr}

.town-list{
  min-height:0;
  margin:0;
  padding:0 0.92rem 0.75rem 1.6rem;
  display:grid;
  gap:0.24rem;
  color:rgba(236,246,255,0.9);
}

.faq .accordion{display:grid;gap:0.7rem}
.faq-q{
  width:100%;
  text-align:left;
  padding:1rem 1.1rem;
  border-radius:12px;
  background:rgba(8,22,42,0.52);
  border:1px solid rgba(126,210,255,0.18);
  color:var(--text);
  font-weight:700;
  font-size:1rem;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:0.75rem;
  cursor:pointer;
  transition:background .22s,border-color .22s;
}
.faq-q:hover{background:rgba(10,28,54,0.68);border-color:rgba(126,210,255,0.34)}
.faq-item.open .faq-q{
  background:rgba(10,28,54,0.7);
  border-color:rgba(126,210,255,0.36);
  border-bottom-left-radius:0;
  border-bottom-right-radius:0;
}
.faq-a{
  display:none;
  padding:1rem 1.1rem;
  background:rgba(8,22,42,0.38);
  border:1px solid rgba(126,210,255,0.18);
  border-top:none;
  border-bottom-left-radius:12px;
  border-bottom-right-radius:12px;
  margin-top:0;
  color:rgba(245,247,255,0.88);
  line-height:1.7;
}
.faq-item.open .faq-a{display:block}

.website-builder-cta{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:1.2rem;
  align-items:center;
  margin:0 0 1.25rem;
  padding:1.25rem 1.35rem;
  border-radius:16px;
  border:1px solid rgba(230,200,120,0.28);
  background:
    radial-gradient(420px 220px at 100% 0%, rgba(230,200,120,0.12), transparent 60%),
    linear-gradient(180deg, rgba(18,42,70,0.86), rgba(12,28,49,0.84));
  box-shadow:0 18px 42px rgba(0,0,0,0.34), inset 0 1px 0 rgba(255,255,255,0.08);
}

.website-builder-cta-copy h2{
  margin:0 0 0.4rem;
  color:var(--gold);
  font-family:Orbitron,Inter,sans-serif;
  font-size:clamp(1.35rem,2.5vw,2rem);
  text-shadow:0 0 16px rgba(49,195,255,0.12);
}

.website-builder-cta-copy p{
  margin:0;
  max-width:60ch;
  color:rgba(245,247,255,0.84);
}

.website-builder-cta-kicker{
  margin:0 0 0.45rem !important;
  color:#b9edff !important;
  font-size:0.88rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.08em;
}

.website-builder-cta-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
}

.contact-grid{display:grid;grid-template-columns:1fr 320px;gap:1rem}
.contact-form{
  background:linear-gradient(180deg, rgba(14,35,62,0.78), rgba(10,26,47,0.76));
  padding:1.35rem;
  border-radius:16px;
  border:1px solid var(--panel-border);
  box-shadow:0 18px 42px rgba(0,0,0,0.42), inset 0 1px 0 rgba(255,255,255,0.08);
}
.contact-form .form-actions .btn.btn-gold{
  min-width:0;
  width:auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0.86rem 1.55rem;
  font-size:1rem;
  line-height:1.15;
  font-weight:800;
  letter-spacing:0.01em;
}
.contact-form label{display:block;margin-bottom:0.9rem;font-size:1rem;font-weight:500}
.contact-form input[type=text],.contact-form input[type=tel],.contact-form input[type=email],.contact-form select,.contact-form textarea{
  width:100%;
  padding:0.78rem 0.82rem;
  border-radius:10px;
  border:1px solid rgba(126,210,255,0.22);
  background:rgba(8,23,43,0.78);
  color:var(--text);
  font-family:inherit;
  font-size:1rem;
  transition:border-color .24s ease, box-shadow .24s ease, background .24s ease;
}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:rgba(229,242,255,0.56)}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{
  outline:none;
  border-color:rgba(126,210,255,0.62);
  box-shadow:0 0 0 3px rgba(49,195,255,0.22), 0 0 16px rgba(49,195,255,0.24);
  background:rgba(9,27,49,0.92);
}

.required{color:#ff7fb5}
.field-help{display:block;font-size:0.875rem;color:rgba(229,242,255,0.72);margin-top:0.3rem}
.field-hidden{display:none !important}

.selected-service-banner{
  margin-bottom:0.9rem;
  padding:0.7rem 0.8rem;
  border-radius:10px;
  border:1px solid rgba(126,210,255,0.35);
  background:rgba(49,195,255,0.11);
}

.contact-method,
.issue-types{
  margin:0 0 1rem;
  padding:0.85rem 0.9rem;
  border-radius:12px;
  border:1px solid rgba(126,210,255,0.22);
  background:rgba(8,22,40,0.52);
}

.contact-method legend,
.issue-types legend{
  grid-column:1 / -1;
  display:block;
  margin:0 0 0.5rem 0;
  font-size:1rem;
  font-weight:500;
  color:var(--text);
}

.contact-method label,
.issue-type-options label{margin:0}

.contact-method{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:0.55rem;
}

.issue-types{
  display:grid;
  grid-template-columns:1fr;
  gap:0.6rem;
}

.contact-method label,
.issue-type-options label{
  display:flex;
  align-items:center;
  gap:0.45rem;
  padding:0.5rem 0.58rem;
  border-radius:9px;
  border:1px solid rgba(126,210,255,0.2);
  background:rgba(14,34,58,0.56);
  transition:all .2s ease;
}

.contact-method label:hover,
.issue-type-options label:hover{border-color:rgba(126,210,255,0.48);background:rgba(16,42,72,0.72)}

.service-needs{display:grid;gap:0.85rem;margin-top:0.2rem}

.service-need{
  border:1px solid rgba(126,210,255,0.24);
  border-radius:14px;
  padding:0.9rem;
  background:rgba(8,22,40,0.45);
}

.service-need-header{display:flex;justify-content:space-between;align-items:center;gap:0.7rem;margin-bottom:0.55rem}
.service-need-title{margin:0;color:#dff5ff}
.remove-service-need{
  border:1px solid rgba(255,133,168,0.38);
  background:rgba(255,133,168,0.12);
  color:#ffd8e4;
  border-radius:8px;
  padding:0.45rem 0.62rem;
  cursor:pointer;
  transition:all .2s ease;
}
.remove-service-need:hover{background:rgba(255,133,168,0.22)}

.issue-type-options{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0.52rem}

.add-service-btn{margin:0.2rem 0 1rem}

.request-summary-wrap{
  border:1px solid rgba(126,210,255,0.28);
  border-radius:12px;
  padding:0.75rem 0.85rem;
  background:rgba(11,31,55,0.62);
  margin-bottom:0.9rem;
}
.request-summary-wrap h4{margin:0 0 0.45rem}
.request-summary-list{margin:0;padding-left:1rem;color:rgba(235,245,255,0.92)}

.checkbox{display:flex;align-items:center;gap:0.6rem;margin-bottom:0.3rem}
.form-actions{display:flex;gap:1.2rem;align-items:center;margin-top:1.2rem;justify-content:flex-start}
.form-message{color:var(--neon);font-weight:700;font-size:1rem;margin-left:1rem}

.contact-info .info-card{background:linear-gradient(180deg, rgba(18,45,74,0.74), rgba(13,33,58,0.64));padding:1rem;border-radius:12px;border:1px solid rgba(126,210,255,0.26);margin-bottom:1rem;transition:all .28s ease}
.contact-info .info-card a,
.contact-info .info-card a:visited{
  color:#f5f7ff;
  text-decoration:none;
  transition:color .24s ease, text-shadow .24s ease;
}

.contact-info .info-card a:hover,
.contact-info .info-card a:focus-visible{
  color:#7edaff;
  text-shadow:0 0 10px rgba(49,195,255,0.28);
  outline:none;
}

/* Website builder */
.website-builder-page .section{padding-top:3.6rem;padding-bottom:3.6rem}
.builder-hero{padding-top:4.2rem}
.builder-hero-grid,
.builder-grid{display:grid;grid-template-columns:minmax(0,1.2fr) 360px;gap:1.35rem;align-items:start}

.builder-hero-copy,
.builder-sidebar-card,
.builder-progress,
.builder-step-card,
.builder-hero-showcase{
  background:linear-gradient(180deg, rgba(14,35,62,0.8), rgba(10,26,47,0.78));
  border:1px solid rgba(126,210,255,0.22);
  box-shadow:0 18px 42px rgba(0,0,0,0.36), inset 0 1px 0 rgba(255,255,255,0.08);
}

.builder-hero-copy,
.builder-hero-showcase,
.builder-sidebar-card,
.builder-progress,
.builder-step-card{border-radius:18px}
.builder-hero-copy{padding:1.55rem}

.eyebrow,
.progress-label,
.sidebar-kicker{
  display:inline-flex;
  align-items:center;
  gap:0.4rem;
  margin:0 0 0.7rem;
  padding:0.32rem 0.65rem;
  border-radius:999px;
  border:1px solid rgba(126,210,255,0.24);
  background:rgba(49,195,255,0.08);
  color:#b9edff;
  font-size:0.88rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.08em;
}

.builder-hero-copy h1{margin:0 0 0.9rem;font-family:Orbitron,Inter,sans-serif;font-size:clamp(1.9rem,4vw,3.3rem);color:var(--gold);text-shadow:0 0 18px rgba(49,195,255,0.14)}
.builder-hero-note{
  margin:1rem 0 0;
  padding:0.95rem 1rem;
  border-radius:14px;
  border:1px solid rgba(230,200,120,0.26);
  background:linear-gradient(180deg, rgba(230,200,120,0.12), rgba(230,200,120,0.04));
  color:#fff6db;
}
.builder-hero-actions{display:flex;gap:0.9rem;flex-wrap:wrap;margin-top:1.2rem}
.builder-hero-points{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0.85rem;margin-top:1.35rem}
.builder-point{padding:0.95rem;border-radius:14px;background:rgba(8,24,42,0.6);border:1px solid rgba(126,210,255,0.18)}
.builder-point strong{display:block;margin-bottom:0.38rem;color:#edf9ff}
.builder-point span{display:block;color:rgba(237,249,255,0.8);font-size:0.96rem}

.builder-hero-showcase{position:relative;min-height:420px;padding:1.25rem;overflow:hidden}
.builder-hero-showcase::before{
  content:"";
  position:absolute;
  inset:18px;
  border-radius:24px;
  background:radial-gradient(circle at top right, rgba(230,200,120,0.15), transparent 34%), radial-gradient(circle at bottom left, rgba(49,195,255,0.18), transparent 42%);
  pointer-events:none;
}

.showcase-window{position:absolute;border:1px solid rgba(126,210,255,0.24);border-radius:22px;background:rgba(5,17,31,0.84);box-shadow:0 28px 54px rgba(0,0,0,0.38)}
.showcase-window-main{inset:26px 34px 34px 26px;padding:0.95rem}
.showcase-window-floating{padding:0.7rem;background:rgba(9,22,39,0.92);backdrop-filter:blur(6px)}
.showcase-window-floating.one{top:38px;right:18px;width:170px;transform:rotate(5deg)}
.showcase-window-floating.two{bottom:20px;right:10px;width:192px;transform:rotate(-6deg)}
.showcase-browser-bar{display:flex;gap:0.34rem;margin-bottom:0.8rem}
.showcase-browser-bar span{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,0.26)}
.showcase-layout{height:100%;border-radius:18px;padding:1rem;background:linear-gradient(155deg, rgba(239,247,255,0.96), rgba(222,236,248,0.95));color:#14253a}
.showcase-chip{display:inline-flex;padding:0.26rem 0.56rem;border-radius:999px;background:#10294b;color:#f1f8ff;font-size:0.8rem;font-weight:700}
.showcase-title{width:68%;height:22px;border-radius:999px;background:#10294b;margin:1rem 0 0.8rem}
.showcase-line{height:12px;border-radius:999px;background:rgba(16,41,75,0.18);margin-bottom:0.5rem}
.showcase-line.short{width:72%}
.showcase-cta-row{display:flex;gap:0.6rem;margin:0.9rem 0 1rem}
.showcase-btn{height:38px;border-radius:999px}
.showcase-btn.gold{width:128px;background:linear-gradient(180deg,#e6c878,#bb902c)}
.showcase-btn.ghost{width:116px;border:1px solid rgba(16,41,75,0.22)}
.showcase-panels{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0.65rem}
.showcase-panels div{height:138px;border-radius:16px;background:linear-gradient(180deg, rgba(16,41,75,0.1), rgba(16,41,75,0.22))}
.showcase-mini-card{border-radius:16px;padding:0.8rem}
.luxury-preview{background:linear-gradient(180deg, #17120f, #312418);color:#f0dec0}
.colorful-preview{background:linear-gradient(180deg, #ffe3d2, #ffeaf9)}
.mini-badge,.mini-heading,.mini-image,.mini-pill-row span,.mini-grid div{display:block;border-radius:999px}
.mini-badge{width:70px;height:10px;background:rgba(240,222,192,0.5);margin-bottom:0.65rem}
.mini-heading{width:88%;height:16px;background:rgba(240,222,192,0.78);margin-bottom:0.9rem}
.mini-image{height:84px;border-radius:14px;background:linear-gradient(180deg, rgba(240,222,192,0.18), rgba(230,200,120,0.3))}
.mini-pill-row{display:flex;gap:0.3rem;margin-bottom:0.7rem}
.mini-pill-row span{width:42px;height:10px;background:rgba(255,111,145,0.48)}
.mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0.45rem}
.mini-grid div{height:56px;border-radius:12px;background:linear-gradient(180deg, rgba(255,181,92,0.4), rgba(94,109,255,0.26))}

.builder-main{display:grid;gap:1rem}
.builder-progress{padding:1rem 1.1rem}
.progress-title{margin:0;color:#edf8ff}
.builder-progress-track{height:12px;border-radius:999px;background:rgba(255,255,255,0.08);overflow:hidden;margin:1rem 0 0.45rem}
.builder-progress-fill{display:block;height:100%;width:0;background:linear-gradient(90deg, var(--gold), #7edaff);border-radius:inherit;transition:width .28s ease}
.builder-progress-text{color:#d4f6ff;font-weight:700;font-size:0.95rem}
.builder-step-links{display:flex;flex-wrap:wrap;gap:0.5rem;margin-top:0.9rem}
.builder-step-links a{
  text-decoration:none;
  color:rgba(245,247,255,0.82);
  padding:0.44rem 0.7rem;
  border-radius:999px;
  border:1px solid rgba(126,210,255,0.18);
  background:rgba(8,22,40,0.48);
  font-size:0.92rem;
  transition:all .2s ease;
}
.builder-step-links a:hover,
.builder-step-links a.is-active{color:#061427;background:var(--gold);border-color:rgba(230,200,120,0.75)}
.builder-step-links a.is-complete{border-color:rgba(126,210,255,0.44);box-shadow:0 0 0 1px rgba(126,210,255,0.16) inset}

.builder-form{display:grid;gap:1.15rem}
.builder-step-card{padding:1.3rem}
.builder-step-head{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.15rem}
.builder-step-head h3{margin:0 0 0.4rem;color:#edf8ff;line-height:1.22}
.builder-step-head p{margin:0;color:rgba(237,248,255,0.74)}
.builder-step-number{min-width:52px;height:52px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(180deg, rgba(230,200,120,0.28), rgba(230,200,120,0.12));border:1px solid rgba(230,200,120,0.32);color:#fff4cb;font-family:Orbitron,Inter,sans-serif;font-weight:700}

.builder-step-card > label,
.builder-field-grid > label{
  display:grid;
  gap:0.38rem;
  align-content:start;
  margin-bottom:0;
}

.builder-label-text{
  display:inline-flex;
  align-items:baseline;
  gap:0.28rem;
  line-height:1.3;
}

.builder-option-text{
  display:block;
  width:100%;
  padding-right:1.35rem;
}

.builder-step-card > label + label,
.builder-field-grid + label,
.builder-note-box,
.builder-submit-note{margin-top:0.25rem}

.builder-field-grid{display:grid;gap:1rem}
.builder-field-grid.two-col{grid-template-columns:repeat(2,minmax(0,1fr))}
.builder-field-grid.three-col{grid-template-columns:repeat(3,minmax(0,1fr))}
.choice-grid,.feature-card-grid,.style-card-grid{display:grid;gap:1rem}
.website-type-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.feature-card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.style-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}

.choice-card,.feature-card,.style-card{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:0.72rem;
  min-height:100%;
  padding:1.05rem;
  border-radius:16px;
  border:1px solid rgba(126,210,255,0.2);
  background:linear-gradient(180deg, rgba(9,25,44,0.86), rgba(8,20,36,0.72));
  cursor:pointer;
  overflow:hidden;
  transition:transform .18s ease, border-color .22s ease, box-shadow .22s ease, background .22s ease;
}
.choice-card::before,
.feature-card::before,
.style-card::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:linear-gradient(180deg, rgba(230,200,120,0.06), rgba(126,210,255,0.02));
  opacity:0;
  transition:opacity .18s ease;
  pointer-events:none;
}
.choice-card::after,
.feature-card::after,
.style-card::after{
  content:"";
  position:absolute;
  top:1rem;
  right:1rem;
  width:19px;
  height:19px;
  border-radius:999px;
  border:1px solid rgba(126,210,255,0.14);
  background:rgba(255,255,255,0.025);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.05);
  opacity:0.82;
  transition:all .18s ease;
  pointer-events:none;
}
.choice-card input,.feature-card input,.style-card input{position:absolute;opacity:0;pointer-events:none}
.choice-card:hover,.feature-card:hover,.style-card:hover{transform:translateY(-3px);border-color:rgba(126,210,255,0.52);box-shadow:0 18px 36px rgba(0,0,0,0.24), 0 0 0 1px rgba(126,210,255,0.16) inset}
.choice-card:hover::after,
.feature-card:hover::after,
.style-card:hover::after{
  border-color:rgba(126,210,255,0.3);
  background:rgba(255,255,255,0.045);
  opacity:1;
}
.choice-card:hover::before,
.feature-card:hover::before,
.style-card:hover::before,
.choice-card:focus-within::before,
.feature-card:focus-within::before,
.style-card:focus-within::before,
.choice-card.is-selected::before,
.feature-card.is-selected::before,
.style-card.is-selected::before{opacity:1}

.choice-card:focus-within,
.feature-card:focus-within,
.style-card:focus-within{
  outline:none;
  border-color:rgba(230,200,120,0.72);
  box-shadow:0 0 0 2px rgba(5,15,30,0.92), 0 0 0 4px rgba(230,200,120,0.24), 0 14px 28px rgba(0,0,0,0.24);
}

.choice-card.is-selected,
.feature-card.is-selected,
.style-card.is-selected{
  transform:translateY(-3px);
  border-color:rgba(230,200,120,0.76);
  background:linear-gradient(180deg, rgba(24,50,76,0.98), rgba(14,32,52,0.94));
  box-shadow:0 18px 38px rgba(0,0,0,0.28), 0 0 0 1px rgba(230,200,120,0.18) inset, 0 0 26px rgba(230,200,120,0.12);
}

.choice-card.is-selected::after,
.feature-card.is-selected::after,
.style-card.is-selected::after{
  content:"\2713";
  display:flex;
  align-items:center;
  justify-content:center;
  color:#061427;
  font-size:0.72rem;
  font-weight:900;
  border-color:rgba(230,200,120,0.82);
  background:linear-gradient(180deg, var(--gold), #c69a35);
  box-shadow:0 8px 18px rgba(230,200,120,0.2);
  opacity:1;
}

.choice-icon{
  width:auto;
  height:auto;
  flex:0 0 auto;
  margin-bottom:0;
  border-radius:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:rgba(203,234,255,0.82);
  background:transparent;
  border:none;
  box-shadow:none;
  font-size:1.25rem;
  transition:transform .18s ease, color .22s ease, text-shadow .22s ease;
  position:relative;
  z-index:1;
}

.choice-card strong,
.feature-card strong,
.style-copy strong{
  display:block;
  width:100%;
  margin:0;
  color:#eef9ff;
  font-size:1.02rem;
  line-height:1.3;
  text-wrap:pretty;
  overflow-wrap:break-word;
}

.card-copy,
.style-copy{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:flex-start;
  gap:0.34rem;
  width:100%;
}

.choice-card:hover .choice-icon,
.feature-card:hover .choice-icon{
  color:#f2f8ff;
  text-shadow:0 0 10px rgba(126,210,255,0.18);
}

.choice-card small,
.feature-card small,
.style-copy small{
  display:block;
  width:100%;
  margin:0;
  color:rgba(238,249,255,0.72);
  line-height:1.55;
  max-width:30ch;
}

.choice-card.is-selected strong,
.feature-card.is-selected strong,
.style-card.is-selected .style-copy strong{color:#fff1be}

.choice-card.is-selected .choice-icon,
.feature-card.is-selected .choice-icon{
  color:#f0d489;
  text-shadow:0 0 14px rgba(230,200,120,0.24);
  transform:translateY(-1px);
}

.style-card.is-selected{
  background:linear-gradient(180deg, rgba(24,50,78,0.98), rgba(12,30,50,0.94));
}

.style-card.is-selected .style-preview{
  border-color:rgba(230,200,120,0.52);
  box-shadow:0 0 0 1px rgba(230,200,120,0.18) inset, 0 14px 30px rgba(0,0,0,0.14);
}

.style-card.is-selected .style-copy small{
  color:rgba(255,246,218,0.82);
}

.website-type-grid .choice-card,
.feature-card-grid .feature-card,
.style-card-grid .style-card{height:100%}

.builder-check-grid,.builder-pill-group{margin:0 0 0.8rem;padding:0.92rem;border-radius:14px;border:1px solid rgba(126,210,255,0.2);background:rgba(8,22,40,0.52)}
.builder-check-grid legend,.builder-pill-group legend{margin-bottom:0.65rem;color:#edf8ff;font-weight:600}
.builder-check-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0.6rem}
.builder-check-grid label,.builder-pill-group label{
  position:relative;
  display:flex;
  align-items:flex-start;
  gap:0;
  margin:0;
  min-height:58px;
  padding:0.78rem 0.82rem;
  border-radius:12px;
  border:1px solid rgba(126,210,255,0.16);
  background:rgba(13,33,58,0.66);
  line-height:1.42;
  transition:border-color .18s ease, background .18s ease, box-shadow .18s ease, transform .18s ease;
}
.builder-check-grid label:hover,.builder-pill-group label:hover{
  transform:translateY(-1px);
  border-color:rgba(126,210,255,0.34);
  background:rgba(15,38,66,0.78);
}
.builder-check-grid label:focus-within,.builder-pill-group label:focus-within{
  border-color:rgba(230,200,120,0.6);
  box-shadow:0 0 0 2px rgba(5,15,30,0.9), 0 0 0 4px rgba(230,200,120,0.18);
}
.builder-check-grid label input,.builder-pill-group label input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.builder-check-grid label:has(input:checked),.builder-pill-group label:has(input:checked){
  border-color:rgba(230,200,120,0.68);
  background:linear-gradient(180deg, rgba(30,54,78,0.92), rgba(17,34,56,0.9));
  box-shadow:0 14px 28px rgba(0,0,0,0.18), 0 0 0 1px rgba(230,200,120,0.14) inset;
}
.builder-check-grid label:has(input:checked)::after,.builder-pill-group label:has(input:checked)::after{
  content:"\2713";
  position:absolute;
  top:0.62rem;
  right:0.62rem;
  width:18px;
  height:18px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(180deg, var(--gold), #c69a35);
  color:#061427;
  font-size:0.68rem;
  font-weight:900;
  box-shadow:0 6px 14px rgba(230,200,120,0.18);
}
.builder-pill-group{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0.6rem}
.builder-pill-group.required-pill-group{margin:0}

.builder-site-stage-group{
  grid-column:1 / -1;
  display:grid;
  grid-template-columns:repeat(2,minmax(220px,1fr));
  gap:0.7rem;
  align-items:start;
  padding:1rem 1.05rem;
}

.builder-site-stage-group legend{
  grid-column:1 / -1;
  margin-bottom:0.1rem;
}

.builder-site-stage-group label{
  min-height:56px;
  justify-content:flex-start;
  padding:0.85rem 0.95rem;
  line-height:1.35;
}

.style-card{padding:0.9rem}
.style-preview{min-height:214px;border-radius:18px;padding:0.8rem;overflow:hidden;border:1px solid rgba(255,255,255,0.08);transition:border-color .22s ease, box-shadow .22s ease, transform .22s ease}
.style-copy{padding-top:0.12rem}
.style-preview-topbar{height:14px;border-radius:999px;background:rgba(255,255,255,0.34);margin-bottom:0.8rem}
.style-preview-topbar.thin{height:8px;opacity:0.65}
.style-preview-hero,.style-preview-split,.style-preview-soft-hero{display:grid;grid-template-columns:1fr 0.92fr;gap:0.7rem;align-items:center}
.style-preview-copy{display:grid;gap:0.42rem}
.style-preview-copy span,.style-preview-lines span,.style-preview-stat-row span,.style-preview-color-panels span,.style-preview-cards span,.style-preview-grid-plain span,.style-preview-pill-row span{display:block;border-radius:999px}
.style-preview-copy span:nth-child(1){width:92%;height:16px}
.style-preview-copy span:nth-child(2){width:74%;height:12px}
.style-preview-copy span:nth-child(3){width:62%;height:12px}
.style-preview-image{height:108px;border-radius:18px}
.style-preview-image.circle{border-radius:50%}
.style-preview-image.portrait{height:124px;border-radius:26px}
.style-preview-cards,.style-preview-stat-row,.style-preview-color-panels,.style-preview-grid-plain,.style-preview-pill-row{display:grid;gap:0.55rem;margin-top:0.8rem}
.style-preview-cards{grid-template-columns:repeat(3,minmax(0,1fr))}
.style-preview-cards.soft{grid-template-columns:repeat(2,minmax(0,1fr))}
.style-preview-stat-row{grid-template-columns:repeat(3,minmax(0,1fr))}
.style-preview-color-panels{grid-template-columns:repeat(3,minmax(0,1fr))}
.style-preview-grid-plain{grid-template-columns:repeat(2,minmax(0,1fr))}
.style-preview-pill-row{grid-template-columns:repeat(3,46px)}
.style-preview-cards span,.style-preview-stat-row span,.style-preview-color-panels span,.style-preview-grid-plain span{height:72px;border-radius:16px}
.style-preview-pill-row span{height:14px}
.style-preview-lines{display:grid;gap:0.46rem}
.style-preview-lines.centered{justify-items:center}
.style-preview-lines span:nth-child(1){width:82%;height:16px}
.style-preview-lines span:nth-child(2){width:68%;height:12px}
.style-preview-lines span:nth-child(3){width:54%;height:12px}
.style-preview-content-block{height:112px;border-radius:18px;margin-top:0.9rem}
.style-preview-graph{height:136px;border-radius:20px}
.style-preview-centerpiece{height:112px;border-radius:999px;margin:1rem auto 0.8rem;max-width:112px}
.style-preview-button{height:36px;border-radius:999px;max-width:120px;margin-top:0.8rem}
.style-preview-button.wide{max-width:150px;margin:0.9rem auto 0}
.style-preview-ribbon{width:42%;height:14px;border-radius:999px;margin-bottom:0.7rem}

.style-card.modern-clean .style-preview{background:linear-gradient(165deg, #f7fbff, #deeefa);color:#17324f}
.style-card.modern-clean .style-preview-copy span,.style-card.modern-clean .style-preview-cards span,.style-card.modern-clean .style-preview-topbar,.style-card.modern-clean .style-preview-button,.style-card.modern-clean .style-preview-grid-plain span,.style-card.modern-clean .style-preview-content-block{background:rgba(20,50,79,0.14)}
.style-card.modern-clean .style-preview-image{background:linear-gradient(180deg, #c7def0, #aac6dc)}
.style-card.bold-business .style-preview{background:linear-gradient(160deg, #071626, #102d4d)}
.style-card.bold-business .style-preview-copy span,.style-card.bold-business .style-preview-stat-row span,.style-card.bold-business .style-preview-topbar{background:rgba(255,255,255,0.22)}
.style-card.bold-business .style-preview-copy.dark span:nth-child(1){background:rgba(255,255,255,0.78)}
.style-card.bold-business .style-preview-copy.dark span:nth-child(2),.style-card.bold-business .style-preview-copy.dark span:nth-child(3){background:rgba(255,255,255,0.34)}
.style-card.bold-business .style-preview-graph{background:linear-gradient(180deg, rgba(230,200,120,0.85), rgba(126,218,255,0.32))}
.style-card.elegant-luxury .style-preview{background:linear-gradient(165deg, #15110c, #2e2416)}
.style-card.elegant-luxury .style-preview-topbar,.style-card.elegant-luxury .style-preview-lines span,.style-card.elegant-luxury .style-preview-button{background:rgba(240,222,192,0.74)}
.style-card.elegant-luxury .style-preview-centerpiece{background:linear-gradient(180deg, rgba(240,222,192,0.16), rgba(230,200,120,0.46));border:1px solid rgba(240,222,192,0.25)}
.style-card.minimal-simple .style-preview{background:linear-gradient(180deg, #fbfdff, #eff4f8)}
.style-card.minimal-simple .style-preview-topbar,.style-card.minimal-simple .style-preview-lines span,.style-card.minimal-simple .style-preview-grid-plain span,.style-card.minimal-simple .style-preview-content-block{background:rgba(20,50,79,0.12)}
.style-card.creative-colorful .style-preview{background:linear-gradient(160deg, #fff1cf, #ffd9ec 55%, #d8ecff)}
.style-card.creative-colorful .style-preview-pill-row span:nth-child(1){background:#ff7c7c}
.style-card.creative-colorful .style-preview-pill-row span:nth-child(2){background:#6c7dff}
.style-card.creative-colorful .style-preview-pill-row span:nth-child(3){background:#ffb84e}
.style-card.creative-colorful .style-preview-copy span{background:rgba(111,86,189,0.24)}
.style-card.creative-colorful .style-preview-image{background:linear-gradient(180deg, rgba(111,86,189,0.22), rgba(255,122,122,0.38))}
.style-card.creative-colorful .style-preview-color-panels span:nth-child(1){background:rgba(255,122,122,0.5)}
.style-card.creative-colorful .style-preview-color-panels span:nth-child(2){background:rgba(111,125,255,0.46)}
.style-card.creative-colorful .style-preview-color-panels span:nth-child(3){background:rgba(255,184,78,0.52)}
.style-card.soft-feminine .style-preview{background:linear-gradient(165deg, #fff7f5, #fde7f0)}
.style-card.soft-feminine .style-preview-ribbon,.style-card.soft-feminine .style-preview-copy span,.style-card.soft-feminine .style-preview-cards span{background:rgba(173,112,134,0.22)}
.style-card.soft-feminine .style-preview-image{background:linear-gradient(180deg, rgba(255,214,224,0.88), rgba(241,192,204,0.72))}

.builder-note-box,.builder-submit-note{padding:0.95rem 1rem;border-radius:14px;border:1px solid rgba(126,210,255,0.2);background:rgba(8,22,40,0.56)}
.builder-note-box strong,.builder-submit-note strong{display:block;margin-bottom:0.36rem;color:#edf8ff}
.builder-note-box p,.builder-submit-note p{margin:0;color:rgba(237,248,255,0.78)}

.builder-sidebar{display:grid;gap:1rem;position:sticky;top:94px}
.builder-sidebar-card{padding:1rem 1.05rem}
.builder-sidebar-card h3{margin:0.2rem 0 0.45rem;color:#eef8ff}
.builder-sidebar-card p{margin:0 0 0.9rem;color:rgba(238,248,255,0.74)}

.builder-summary-panel{display:grid;gap:0.75rem}
.builder-summary-group{
  position:relative;
  padding:0.9rem 0.95rem;
  border-radius:14px;
  border:1px solid rgba(126,210,255,0.16);
  background:linear-gradient(180deg, rgba(10,26,47,0.78), rgba(6,18,32,0.8));
  overflow:hidden;
}
.builder-summary-group::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:4px;
  background:linear-gradient(180deg, rgba(230,200,120,0.88), rgba(126,210,255,0.46));
  opacity:0.82;
}
.builder-summary-group h4{margin:0 0 0.38rem;color:#fff2c5;font-size:0.98rem;line-height:1.25}
.builder-summary-group p{margin:0;color:#eff9ff;line-height:1.58}
.builder-summary-group p.placeholder{color:rgba(239,249,255,0.48)}

.builder-process-list{display:grid;gap:0.9rem}
.builder-process-list div{padding:0.8rem 0.85rem;border-radius:14px;background:rgba(8,22,40,0.52);border:1px solid rgba(126,210,255,0.16)}
.builder-process-list strong{display:block;margin-bottom:0.28rem;color:#edf8ff}
.builder-process-list span{display:block;color:rgba(237,248,255,0.74)}

.builder-submit-card .checkbox{margin-bottom:1rem}
.builder-submit-card .form-actions{margin-top:1rem}
.builder-step-card.is-incomplete{border-color:rgba(255,127,181,0.34)}
.builder-step-card.is-complete{border-color:rgba(126,210,255,0.34)}

.builder-form input[type=text],
.builder-form input[type=tel],
.builder-form input[type=email],
.builder-form select,
.builder-form textarea{margin-top:0}

.checkbox .builder-label-text{gap:0.38rem}

.builder-submit-card .checkbox{
  display:flex;
  align-items:center;
  gap:0.75rem;
  flex-wrap:nowrap;
}

.builder-submit-card .checkbox input{
  flex:0 0 auto;
  margin:0;
}

.builder-submit-card .checkbox .builder-label-text{
  display:block;
  flex:1 1 auto;
  line-height:1.5;
}

/* Floating call button */
.floating-call{
  position:fixed;
  right:18px;
  bottom:18px;
  display:none;
  align-items:center;
  justify-content:center;
  padding:0.7rem 1rem;
  border-radius:999px;
  border:1px solid rgba(126,210,255,0.55);
  background:linear-gradient(180deg, rgba(64,209,255,0.98), rgba(34,168,235,0.98));
  color:#03203b;
  text-decoration:none;
  font-size:1rem;
  font-weight:800;
  line-height:1;
  letter-spacing:0.01em;
  white-space:nowrap;
  box-shadow:0 10px 30px rgba(49,195,255,0.28);
  z-index:80;
}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}

/* Responsive */
@media (max-width:900px){
  .header-inner{position:relative}
  .hero-content{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .website-builder-cta{grid-template-columns:1fr}
  .website-builder-cta-actions{justify-content:flex-start}
  .service-detail-grid{grid-template-columns:1fr}
  .builder-hero-grid,
  .builder-grid,
  .builder-field-grid.two-col,
  .builder-field-grid.three-col,
  .website-type-grid,
  .feature-card-grid,
  .style-card-grid,
  .builder-check-grid,
  .builder-pill-group,
  .builder-hero-points{grid-template-columns:1fr}
  .builder-sidebar{position:static}
  .builder-site-stage-group{grid-template-columns:1fr}
  .container{padding:1.2rem}
  .hero-cta{flex-wrap:wrap}
  .trust-bullets{flex-wrap:wrap;gap:0.9rem 1.1rem}
  .plan-head{flex-direction:column;align-items:flex-start;gap:0.35rem}
  .contact-method{grid-template-columns:1fr}
  .issue-type-options{grid-template-columns:1fr}
  .nav{display:none}
  .nav.mobile-open{
    display:flex;
    flex-direction:column;
    gap:0.2rem;
    position:absolute;
    top:calc(100% + 0.35rem);
    right:1.2rem;
    left:1.2rem;
    padding:0.6rem;
    border-radius:10px;
    background:rgba(12,22,38,0.96);
    border:1px solid rgba(255,255,255,0.08);
    box-shadow:0 10px 30px rgba(0,0,0,0.45);
    z-index:85;
  }
  .nav.mobile-open a{padding:0.7rem 0.6rem}
  .nav.mobile-open .nav-more{width:100%}
  .nav.mobile-open .nav-more > summary{width:100%;justify-content:space-between}
  .nav.mobile-open .nav-more-menu{
    position:static;
    min-width:0;
    margin-top:0.2rem;
    padding:0.3rem;
    box-shadow:none;
    background:rgba(8,18,32,0.45);
  }
  .mobile-menu{display:inline-block}
  .call-desktop{display:none}
  .floating-call{display:inline-flex}
}

@media (min-width:1200px){
  .container{max-width:1240px}
  .hero{padding:5.2rem 0 4.15rem}
  .section.intro-video{padding-top:0.8rem}
  .intro-video .container{padding-top:0.2rem}
  .hero-content{grid-template-columns:minmax(0,1.1fr) 420px;gap:2.6rem}
  .hero-text h1{font-size:clamp(2.35rem,3vw,3.45rem);max-width:18ch}
  .lead{font-size:1.28rem;max-width:62ch}
  .trust-bullets{margin-top:1.5rem;gap:2rem}
  .section{padding:4.2rem 0}
  .services{padding-top:5rem}
}

@media (min-width:1600px){
  .container{max-width:1360px}
  .hero-content{grid-template-columns:minmax(0,1.16fr) 460px}
  .section-title{font-size:clamp(1.6rem,2.3vw,2.25rem)}
}

@media (max-width:480px){
  .hero{padding:2rem 0 1.8rem}
  .section.intro-video{padding-top:0.5rem}
  .intro-video .container{padding-top:0.08rem}
  .hero-text h1{font-size:1.4rem}
}

@media (max-width:760px){
  .section{padding:2.4rem 0}
  .services{padding-top:3.2rem}
  .services-maintenance-plans{
    padding-top:4rem;
    scroll-margin-top:96px;
  }
  .services-maintenance-plans .section-title{
    max-width:none;
    font-size:1.38rem;
  }
  .package-sections .package-group .section-title{font-size:clamp(1.2rem,5vw,1.38rem)}
  .maintenance-intro{
    max-width:34rem;
    margin-bottom:1.8rem;
  }
  .maintenance-intro h3{font-size:1.04rem}
  .package-sections .package-group{scroll-margin-top:96px}
  .package-sections .package-group + .package-group{margin-top:3.6rem}
  .package-subheading{margin-bottom:1.8rem}
  .cards-grid,
  .plans-grid,
  .steps-grid,
  .services-grid{
    grid-template-columns:1fr;
  }
  .btn{width:100%;justify-content:center}
  .hero-cta .btn{width:auto}
  .form-actions{flex-direction:column;align-items:stretch}
  .form-actions .btn{width:100%}
  .contact-form .form-actions .btn.btn-gold{width:auto;align-self:flex-start}
  .why-grid{grid-template-columns:1fr}
  .why-card h3{min-height:0}
  .choice-card,
  .feature-card,
  .style-card{padding:1rem}
  .choice-card strong,
  .feature-card strong,
  .style-copy strong{min-height:0}
  .choice-card small,
  .feature-card small,
  .style-copy small{max-width:none}
  .builder-check-grid label,
  .builder-pill-group label{min-height:0;padding:0.76rem 0.8rem}
}

@media (max-width:560px){
  .container{padding:1rem}
  .hero-text h1{font-size:clamp(1.35rem,8vw,1.9rem);line-height:1.18}
  .lead{font-size:1.05rem}
  .trust-bullets{flex-direction:column;align-items:flex-start;gap:0.6rem}
  .faq-q{font-size:1rem}
  .chatbot-panel{max-height:min(72vh,520px)}
  .chatbot-form{flex-wrap:wrap}
  .chatbot-send{width:100%}
  .contact-form{padding:1rem}
  .plan-card{padding:1.15rem}
  .services-maintenance-plans{
    padding-top:3.4rem;
    scroll-margin-top:88px;
  }
  .services-maintenance-plans .section-title{font-size:1.16rem}
  .package-sections .package-group .section-title{font-size:clamp(1rem,5.4vw,1.16rem)}
  .maintenance-intro{margin-bottom:1.55rem}
  .maintenance-intro p{font-size:0.96rem}
  .package-sections .package-group{scroll-margin-top:88px}
  .package-sections .package-group + .package-group{margin-top:3rem}
  .package-subheading{margin-bottom:1.45rem}
  .package-best-for{font-size:0.9rem}
  .service-need{padding:0.72rem}
  .builder-hero-copy,
  .builder-sidebar-card,
  .builder-progress,
  .builder-step-card,
  .builder-hero-showcase{border-radius:14px}
  .builder-step-head{flex-direction:column}
  .builder-step-number{min-width:46px;height:46px;border-radius:14px}
  .builder-step-card{padding:1.05rem}
  .builder-hero{padding-top:2.2rem}
  .builder-hero-showcase{min-height:320px}
  .showcase-window-main{inset:18px 18px 26px 18px}
  .showcase-window-floating.one{width:138px;right:10px;top:24px}
  .showcase-window-floating.two{width:156px;right:4px;bottom:12px}
  .builder-site-stage-group label{min-height:0}
  .choice-card::after,
  .feature-card::after,
  .style-card::after{top:0.9rem;right:0.9rem}
  .choice-icon{font-size:1.15rem}
  .builder-submit-card .checkbox{align-items:flex-start}
}

@media (max-width:380px){
  .container{padding:0.82rem}
  .site-header{backdrop-filter:blur(6px)}
  .hero{padding:1.55rem 0 1.6rem}
  .section.intro-video{padding-top:0.44rem}
  .intro-video .container{padding-top:0.05rem}
  .hero-text h1{font-size:clamp(1.15rem,8.2vw,1.52rem);line-height:1.16}
  .lead{font-size:1rem;margin-bottom:0.9rem}
  .btn{padding:0.62rem 0.78rem;font-size:1rem}
  .service-card,
  .plan-card,
  .why-card,
  .contact-form{border-radius:12px}
  .section{padding:1.95rem 0}
  .section-title{font-size:1.22rem}
  .package-sections .package-group .section-title{
    white-space:normal;
    text-wrap:balance;
  }
  .chatbot-panel{width:calc(100vw - 16px);right:8px}
}

/* Chat + mobile FAB overrides (restored) */
.floating-call{
  right:var(--mobile-fab-right);
  bottom:18px;
  padding:0.7rem 1rem;
  display:none;
  align-items:center;
  justify-content:center;
  border-radius:999px;
}

.chatbot-toggle{
  position:fixed;
  right:18px;
  bottom:84px;
  min-width:92px;
  height:46px;
  padding:0 0.9rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.16);
  background:linear-gradient(180deg,var(--gold),#b88b2a);
  color:#050505;
  font-weight:800;
  font-size:1rem;
  letter-spacing:0.2px;
  box-shadow:0 12px 30px rgba(0,0,0,0.4);
  z-index:95;
  cursor:pointer;
}

.chatbot-panel{
  position:fixed;
  right:18px;
  bottom:148px;
  width:min(360px,calc(100vw - 24px));
  max-height:min(520px,calc(100vh - 120px));
  display:none;
  flex-direction:column;
  background:#0d1c30;
  border:1px solid rgba(255,255,255,0.12);
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 18px 50px rgba(0,0,0,0.55);
  z-index:95;
}
.chatbot-panel.open{display:flex}
.chatbot-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:0.75rem 0.9rem;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.chatbot-title{font-family:Orbitron,Inter,sans-serif;color:var(--gold);font-size:1rem}
.chatbot-close{border:0;background:transparent;color:var(--text);font-size:1rem;cursor:pointer}
.chatbot-messages{
  padding:0.75rem;
  display:flex;
  flex-direction:column;
  gap:0.55rem;
  overflow:auto;
  background:#0d1c30;
}
.chatbot-options{
  display:none;
  flex-wrap:wrap;
  gap:0.4rem;
  padding:0 0.7rem 0.7rem;
  background:#0d1c30;
}
.chatbot-option{
  border:1px solid rgba(255,255,255,0.14);
  background:#18324d;
  color:var(--text);
  border-radius:999px;
  padding:0.38rem 0.65rem;
  font-size:1rem;
  cursor:pointer;
}
.chatbot-option:hover{border-color:rgba(212,175,55,0.6);color:var(--gold)}
.chatbot-msg{max-width:90%;padding:0.55rem 0.65rem;border-radius:10px;line-height:1.55;font-size:1rem}
.chatbot-msg.bot{background:#1a3754;border:1px solid rgba(255,255,255,0.08);align-self:flex-start}
.chatbot-msg.user{background:#d4af37;border:1px solid rgba(212,175,55,0.34);color:#0b1118;align-self:flex-end}
.chatbot-form{display:flex;gap:0.5rem;padding:0.7rem;border-top:1px solid rgba(255,255,255,0.08);background:#0d1c30}
.chatbot-input{flex:1;min-width:0;background:#10233b;color:var(--text);border:1px solid rgba(255,255,255,0.1);border-radius:10px;padding:0.58rem 0.65rem;font-size:1rem;line-height:1.45}
.chatbot-send{border:1px solid rgba(255,255,255,0.12);background:var(--gold);color:#050505;border-radius:10px;padding:0.58rem 0.75rem;font-weight:700;font-size:1rem;line-height:1.4;cursor:pointer}

@media (max-width:900px){
  .floating-call{display:inline-flex}
  .chatbot-toggle{
    width:var(--chatbot-toggle-mobile-width);
    min-width:var(--chatbot-toggle-mobile-width);
    padding:0;
    right:var(--mobile-fab-right);
    bottom:calc(18px + var(--mobile-call-stack-height) + var(--mobile-fab-gap));
  }
  .chatbot-panel{
    right:12px;
    bottom:calc(18px + var(--mobile-call-stack-height) + var(--mobile-fab-gap) + 56px);
    width:calc(100vw - 24px);
  }
}

/* small tweaks for hover accents */
.card:hover h3,.plan-card:hover h3{color:var(--gold)}
.request-btn{border:1px solid rgba(255,255,255,0.04)}
.request-btn:hover{box-shadow:0 6px 30px rgba(49,195,255,0.18);border-color:var(--gold)}

/* ============================================================
   BUTTON SIZE VARIANT
   ============================================================ */
.btn-sm{padding:0.42rem 0.9rem;font-size:0.875rem;border-radius:8px}

/* ============================================================
   FOOTER – REDESIGNED
   ============================================================ */
.site-footer{
  border-top:1px solid rgba(49,195,255,0.2);
  background:
    radial-gradient(900px 380px at 0% 120%, rgba(49,195,255,0.055), transparent 55%),
    radial-gradient(600px 280px at 100% -10%, rgba(143,120,255,0.04), transparent 52%),
    linear-gradient(145deg, rgba(2,7,14,0.99), rgba(5,14,29,0.99) 48%, rgba(1,5,12,0.99));
  margin-top:3rem;
  padding:0;
  clear:both;
  overflow:hidden;
  isolation:isolate;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:3rem;
  padding:3.8rem 0 2.8rem;
}

/* Brand column */
.footer-logo{
  font-family:Orbitron,Inter,sans-serif;
  font-size:1.38rem;
  font-weight:700;
  color:#ffffff;
  text-decoration:none;
  letter-spacing:0.05em;
  display:inline-block;
  margin-bottom:0.9rem;
  text-shadow:0 0 22px rgba(49,195,255,0.22);
  transition:color .25s ease, text-shadow .25s ease;
}
.footer-logo:hover{
  color:var(--neon);
  text-shadow:0 0 30px rgba(49,195,255,0.5);
}

.footer-tagline{
  color:rgba(245,247,255,0.58);
  font-size:0.88rem;
  line-height:1.68;
  margin:0 0 1.15rem;
  max-width:28ch;
}

.footer-phone-link{
  display:inline-flex;
  align-items:center;
  gap:0.5rem;
  color:var(--neon);
  text-decoration:none;
  font-weight:700;
  font-size:0.95rem;
  transition:color .25s ease, text-shadow .25s ease;
}
.footer-phone-link:hover{
  color:#a8eeff;
  text-shadow:0 0 14px rgba(49,195,255,0.42);
}

/* Column headings */
.footer-heading{
  font-family:Orbitron,Inter,sans-serif;
  font-size:0.8rem;
  font-weight:700;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--neon);
  margin:0 0 1.15rem;
}

/* Navigation links */
.footer-links{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:0.72rem;
}
.footer-links a{
  color:rgba(245,247,255,0.56);
  text-decoration:none;
  font-size:0.92rem;
  display:inline-block;
  transition:color .22s ease, padding-left .22s ease;
}
.footer-links a:hover{
  color:var(--neon);
  padding-left:0.28rem;
}

/* Hours column */
.footer-hours-detail{
  color:rgba(245,247,255,0.58);
  font-size:0.9rem;
  line-height:1.62;
  margin:0 0 0.9rem;
}
.footer-hours-detail strong{color:rgba(245,247,255,0.9)}

/* CTA button – solid neon, overrides btn-outline */
.footer-contact-btn{margin-top:0.65rem}
a.btn.footer-contact-btn,
a.btn.footer-contact-btn:link,
a.btn.footer-contact-btn:visited{
  background:linear-gradient(135deg,rgba(49,195,255,0.94),rgba(22,162,222,0.94));
  border:1px solid rgba(49,195,255,0.55);
  color:#031c2e;
  font-weight:800;
  box-shadow:0 4px 18px rgba(49,195,255,0.22),0 0 0 1px rgba(49,195,255,0.12) inset;
  letter-spacing:0.01em;
}
a.btn.footer-contact-btn:hover{
  background:linear-gradient(135deg,rgba(64,210,255,0.99),rgba(34,175,238,0.99));
  border-color:rgba(49,195,255,0.75);
  color:#021624;
  transform:translateY(-2px);
  box-shadow:0 8px 26px rgba(49,195,255,0.38),0 0 0 1px rgba(49,195,255,0.2) inset;
}

/* Bottom bar */
.footer-bottom{
  border-top:1px solid rgba(49,195,255,0.13);
  padding:1.3rem 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}
.footer-copy{
  color:rgba(245,247,255,0.36);
  font-size:0.83rem;
  margin:0;
}
.footer-legal-links{
  display:flex;
  align-items:center;
  gap:0.65rem;
  font-size:0.83rem;
}
.footer-legal-links a{
  color:rgba(245,247,255,0.36);
  text-decoration:none;
  transition:color .22s ease;
}
.footer-legal-links a:hover{color:var(--neon)}
.footer-legal-links .footer-sep{color:rgba(245,247,255,0.18)}

@media (max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.4rem;padding:3rem 0 2.2rem}
  .footer-tagline{max-width:none}
}
@media (max-width:640px){
  .footer-grid{grid-template-columns:1fr;gap:2rem;padding:2.4rem 0 1.8rem}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:0.5rem}
  .footer-legal-links{flex-wrap:wrap}
}

/* ============================================================
   COOKIE CONSENT BANNER
   ============================================================ */
.cookie-banner{
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  z-index:300;
  background:rgba(6,16,32,0.97);
  border-top:1px solid rgba(126,210,255,0.18);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  padding:1rem 0;
  transform:translateY(100%);
  transition:transform .4s ease;
  box-shadow:0 -8px 32px rgba(0,0,0,0.45);
}
.cookie-banner.cookie-banner-visible{transform:translateY(0)}
.cookie-banner-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.5rem;
  max-width:1240px;
  margin:0 auto;
  padding:0 1.5rem;
}
.cookie-banner-text{
  margin:0;
  color:var(--muted);
  font-size:0.9rem;
  line-height:1.55;
}
.cookie-banner-text i{color:var(--gold);margin-right:0.45rem}
.cookie-banner-text a{color:var(--neon);text-decoration:underline}
.cookie-banner-actions{
  display:flex;
  gap:0.65rem;
  flex-shrink:0;
  align-items:center;
}
.cookie-banner-actions .btn{
  width:auto;
  white-space:nowrap;
}
@media (max-width:640px){
  .cookie-banner-inner{flex-direction:column;align-items:flex-start;gap:0.9rem}
  .cookie-banner-actions{width:100%;justify-content:flex-end;flex-wrap:wrap}
}

/* ============================================================
   BLOG / ARTICLES PAGE
   ============================================================ */
.blog-page-hero{
  padding:3.5rem 0 2.5rem;
  text-align:center;
}
.blog-page-hero h1{margin-bottom:0.6rem}
.blog-page-hero .section-sub{max-width:54ch;margin:0 auto 2rem}
.blog-filter-bar{
  display:flex;
  flex-wrap:wrap;
  gap:0.5rem;
  justify-content:center;
  margin-bottom:2.5rem;
}
.blog-filter-btn{
  background:rgba(13,30,58,0.7);
  border:1px solid rgba(126,210,255,0.2);
  color:var(--muted);
  border-radius:999px;
  padding:0.42rem 1.1rem;
  font-size:0.875rem;
  cursor:pointer;
  transition:all .22s;
  font-family:Inter,sans-serif;
}
.blog-filter-btn:hover,.blog-filter-btn.active{
  background:rgba(49,195,255,0.12);
  border-color:rgba(49,195,255,0.45);
  color:var(--text);
}
.articles-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.6rem;
  margin-bottom:3rem;
}
.article-card{
  background:var(--panel);
  border:1px solid var(--panel-border);
  border-radius:16px;
  padding:1.6rem;
  display:flex;
  flex-direction:column;
  gap:0.75rem;
  transition:transform .25s,box-shadow .25s,border-color .25s;
  text-decoration:none;
  color:inherit;
}
.article-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 36px rgba(0,0,0,0.35);
  border-color:rgba(126,210,255,0.36);
}
.article-tag{
  display:inline-flex;
  align-items:center;
  gap:0.35rem;
  font-size:0.75rem;
  font-weight:600;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--neon);
  margin:0;
}
.article-card h2{
  font-size:1.05rem;
  font-weight:700;
  margin:0;
  line-height:1.4;
}
.article-card p{
  color:var(--muted);
  font-size:0.9rem;
  line-height:1.6;
  margin:0;
  flex:1;
}
.article-card-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-top:auto;
  padding-top:0.75rem;
  border-top:1px solid rgba(255,255,255,0.06);
  font-size:0.82rem;
  color:rgba(245,247,255,0.45);
}
.article-card-footer .read-more{
  color:var(--gold);
  font-weight:600;
  display:flex;
  align-items:center;
  gap:0.3rem;
}
.article-card-coming{
  opacity:0.55;
  pointer-events:none;
  cursor:default;
}
.article-card-coming:hover{transform:none;box-shadow:none}
.article-badge-soon{
  font-size:0.72rem;
  font-weight:700;
  letter-spacing:0.06em;
  text-transform:uppercase;
  background:rgba(143,120,255,0.18);
  border:1px solid rgba(143,120,255,0.35);
  color:var(--violet);
  border-radius:999px;
  padding:0.2rem 0.55rem;
}
.blog-cta-strip{
  background:var(--panel);
  border:1px solid var(--panel-border);
  border-radius:16px;
  padding:2rem;
  text-align:center;
  margin-bottom:3rem;
}
.blog-cta-strip h2{margin:0 0 0.5rem;font-size:1.3rem}
.blog-cta-strip p{color:var(--muted);font-size:0.95rem;margin:0 0 1.2rem;max-width:48ch;margin-left:auto;margin-right:auto}
@media (max-width:900px){.articles-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.articles-grid{grid-template-columns:1fr}}

/* ============================================================
   COURSES PAGE
   ============================================================ */
.courses-page-hero{
  padding:3.5rem 0 2.5rem;
  text-align:center;
}
.courses-page-hero h1{margin-bottom:0.6rem}
.courses-page-hero .section-sub{max-width:56ch;margin:0 auto 2rem}
.courses-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.6rem;
  margin-bottom:3rem;
}
.course-card{
  background:var(--panel);
  border:1px solid var(--panel-border);
  border-radius:16px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.course-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 36px rgba(0,0,0,0.35);
  border-color:rgba(126,210,255,0.36);
}
.course-card-banner{
  background:linear-gradient(135deg,rgba(49,195,255,0.15) 0%,rgba(143,120,255,0.15) 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:2rem;
  font-size:2.4rem;
  color:var(--neon);
  border-bottom:1px solid rgba(255,255,255,0.06);
  min-height:110px;
}
.course-card-banner.violet{color:var(--violet);background:linear-gradient(135deg,rgba(143,120,255,0.15) 0%,rgba(49,195,255,0.1) 100%)}
.course-card-banner.gold{color:var(--gold);background:linear-gradient(135deg,rgba(230,200,120,0.12) 0%,rgba(49,195,255,0.08) 100%)}
.course-card-body{
  padding:1.4rem;
  display:flex;
  flex-direction:column;
  gap:0.6rem;
  flex:1;
}
.course-level{
  font-size:0.75rem;
  font-weight:700;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--neon);
}
.course-level.intermediate{color:var(--gold)}
.course-level.advanced{color:var(--violet)}
.course-card-body h2{
  font-size:1rem;
  font-weight:700;
  margin:0;
  line-height:1.4;
}
.course-card-body p{
  color:var(--muted);
  font-size:0.88rem;
  line-height:1.6;
  margin:0;
  flex:1;
}
.course-card-foot{
  padding:0 1.4rem 1.2rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:0.5rem;
}
.course-status{
  font-size:0.78rem;
  font-weight:600;
  letter-spacing:0.04em;
}
.course-status.available{color:#4ad07a}
.course-status.coming-soon{color:rgba(245,247,255,0.38)}
.courses-cta-strip{
  background:var(--panel);
  border:1px solid var(--panel-border);
  border-radius:16px;
  padding:2rem;
  text-align:center;
  margin-bottom:3rem;
}
.courses-cta-strip h2{margin:0 0 0.5rem;font-size:1.3rem}
.courses-cta-strip p{color:var(--muted);font-size:0.95rem;margin:0 0 1.2rem;max-width:50ch;margin-left:auto;margin-right:auto}
@media (max-width:900px){.courses-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.courses-grid{grid-template-columns:1fr}}

/* ============================================================
   PORTFOLIO / CLIENT SHOWCASE PAGE
   ============================================================ */
.portfolio-page-hero{
  padding:3.5rem 0 2rem;
  text-align:center;
}
.portfolio-page-hero h1{margin-bottom:0.6rem}
.portfolio-page-hero .section-sub{max-width:60ch;margin:0 auto 0}

.portfolio-intro{
  background:var(--panel);
  border:1px solid var(--panel-border);
  border-radius:16px;
  padding:1.8rem 2.2rem;
  margin:2rem 0 2.8rem;
  display:flex;
  align-items:flex-start;
  gap:1.5rem;
}
.portfolio-intro-icon{
  flex-shrink:0;
  font-size:1.8rem;
  color:var(--neon);
  margin-top:0.15rem;
}
.portfolio-intro-copy{flex:1}
.portfolio-intro-copy p{margin:0;color:var(--muted);font-size:0.95rem;line-height:1.7}
.portfolio-intro-copy strong{color:var(--text)}

.portfolio-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.6rem;
  margin-bottom:2rem;
}

.portfolio-card{
  background:var(--panel);
  border:1px solid var(--panel-border);
  border-radius:18px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:transform .28s,box-shadow .28s,border-color .28s;
}
.portfolio-card:hover{
  transform:translateY(-5px);
  box-shadow:0 16px 42px rgba(0,0,0,0.38);
  border-color:rgba(126,210,255,0.38);
}

.portfolio-card-head{
  padding:1.5rem 1.5rem 0;
  display:flex;
  align-items:flex-start;
  gap:1rem;
}
.portfolio-icon{
  flex-shrink:0;
  width:46px;
  height:46px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.15rem;
}
.portfolio-icon.neon{
  background:rgba(49,195,255,0.13);
  color:var(--neon);
  border:1px solid rgba(49,195,255,0.22);
}
.portfolio-icon.violet{
  background:rgba(143,120,255,0.13);
  color:var(--violet);
  border:1px solid rgba(143,120,255,0.22);
}
.portfolio-icon.gold{
  background:rgba(230,200,120,0.13);
  color:var(--gold);
  border:1px solid rgba(230,200,120,0.22);
}
.portfolio-tags{
  display:flex;
  flex-wrap:wrap;
  gap:0.35rem;
  padding-top:0.15rem;
}
.ptag{
  font-size:0.72rem;
  font-weight:700;
  letter-spacing:0.06em;
  text-transform:uppercase;
  background:rgba(126,210,255,0.08);
  border:1px solid rgba(126,210,255,0.16);
  color:rgba(245,247,255,0.65);
  border-radius:999px;
  padding:0.22rem 0.6rem;
  white-space:nowrap;
}

.portfolio-card-body{
  padding:1.1rem 1.5rem 0.9rem;
  flex:1;
  display:flex;
  flex-direction:column;
  gap:0.5rem;
}
.portfolio-card-body h2{
  font-size:1.02rem;
  font-weight:700;
  margin:0;
  line-height:1.4;
  color:var(--text);
}
.portfolio-card-body p{
  color:var(--muted);
  font-size:0.88rem;
  line-height:1.65;
  margin:0;
  flex:1;
}

.portfolio-card-foot{
  padding:0 1.5rem 1.4rem;
}
.btn-preview{
  background:transparent;
  border:1px solid rgba(255,255,255,0.1);
  color:rgba(245,247,255,0.32);
  border-radius:8px;
  padding:0.42rem 0.9rem;
  font-size:0.85rem;
  font-family:Inter,sans-serif;
  cursor:default;
  pointer-events:none;
  display:inline-block;
  line-height:1.4;
}

.portfolio-cta-strip{
  background:var(--panel);
  border:1px solid var(--panel-border);
  border-radius:16px;
  padding:2rem 2.2rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.5rem;
  margin-bottom:3rem;
}
.portfolio-cta-strip h2{margin:0 0 0.35rem;font-size:1.25rem}
.portfolio-cta-strip p{color:var(--muted);font-size:0.92rem;margin:0;max-width:50ch}
.portfolio-cta-btns{display:flex;gap:0.75rem;flex-shrink:0;flex-wrap:wrap}

@media (max-width:1000px){
  .portfolio-grid{grid-template-columns:1fr 1fr}
  .portfolio-cta-strip{flex-direction:column;align-items:flex-start}
}
@media (max-width:580px){
  .portfolio-grid{grid-template-columns:1fr}
  .portfolio-intro{flex-direction:column;gap:0.9rem;padding:1.3rem}
}

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-page{padding-top:3rem}
.about-card{
  background:linear-gradient(180deg,rgba(18,45,74,0.76),rgba(12,29,50,0.72));
  border:1px solid rgba(126,210,255,0.22);
  border-radius:20px;
  padding:2.2rem 2.4rem;
  box-shadow:0 20px 48px rgba(0,0,0,0.36),inset 0 1px 0 rgba(255,255,255,0.08);
  max-width:820px;
  margin:0 auto;
  display:grid;
  gap:1rem;
}
.about-card .section-title{margin-bottom:0.1rem}
.about-card p{color:rgba(245,247,255,0.88);line-height:1.75;margin:0}

.about-highlights{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:0.85rem;
  margin-top:0.5rem;
  padding-top:1.2rem;
  border-top:1px solid rgba(126,210,255,0.14);
}
.about-highlight{
  display:flex;
  align-items:flex-start;
  gap:0.75rem;
  padding:0.95rem 1rem;
  border-radius:12px;
  background:rgba(8,22,42,0.52);
  border:1px solid rgba(126,210,255,0.16);
}
.about-highlight i{
  font-size:1.2rem;
  color:var(--neon);
  flex-shrink:0;
  margin-top:0.15rem;
  text-shadow:0 0 12px rgba(49,195,255,0.28);
}
.about-highlight span{font-size:0.9rem;color:rgba(245,247,255,0.85);line-height:1.5}
.about-highlight strong{color:var(--text);display:block;margin-bottom:0.15rem}
@media (max-width:580px){
  .about-card{padding:1.5rem 1.2rem}
  .about-highlights{grid-template-columns:1fr}
}

/* ============================================================
   SEO / TYPOGRAPHY POLISH
   ============================================================ */
.page-hero-kicker{
  font-size:0.8rem;
  font-weight:700;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--neon);
  margin:0 0 0.65rem;
  display:block;
}
.section-title{scroll-margin-top:5rem}
