:root{
  --bg:#080a0f;
  --panel:#10141c;
  --panel-soft:rgba(255,255,255,0.06);
  --line:rgba(255,255,255,0.12);
  --text:#f8fafc;
  --muted:#a8b3c5;
  --soft:#d8dee8;
  --gold:#7db7ff;
  --steel:#dce7f3;
  --brand-blue:#5da7f2;
  --teal:#9fb6cc;
  --rose:#7ea7d8;
  --accent-soft:rgba(93,167,242,0.14);
  --accent-line:rgba(125,183,255,0.38);
  --button-gradient:linear-gradient(135deg, #eef6ff, #7db7ff 48%, #2f7fca);
  --shadow:0 24px 80px rgba(0,0,0,0.38);
  --radius:8px;
  --body-bg:
    linear-gradient(180deg, rgba(93,167,242,0.14), transparent 18rem),
    linear-gradient(135deg, #05070c 0%, #111827 48%, #07111d 100%);
  --grid-line:rgba(255,255,255,0.035);
  --nav-bg:rgba(8,10,15,0.76);
  --hero-overlay:
    linear-gradient(90deg, rgba(8,10,15,0.96) 0%, rgba(8,10,15,0.78) 39%, rgba(8,10,15,0.28) 72%, rgba(8,10,15,0.68) 100%),
    linear-gradient(180deg, transparent 0%, #080a0f 98%);
  --hero-mobile-overlay:linear-gradient(180deg, rgba(8,10,15,0.86), rgba(8,10,15,0.96));
  --hero-image:url('assets/krylance-hero.jpg');
  --solid-surface:rgba(16,20,28,0.9);
  --solid-surface-hover:rgba(24,30,40,0.96);
  --glass-surface:rgba(255,255,255,0.045);
  --field-bg:rgba(8,10,15,0.72);
  --field-bg-focus:rgba(8,10,15,0.92);
  --auth-overlay:linear-gradient(90deg, rgba(8,10,15,0.94), rgba(8,10,15,0.64));
  --auth-card-bg:rgba(9,12,18,0.82);
  --button-text:#080a0f;
  color-scheme:dark;
}

:root[data-theme="light"]{
  --bg:#f8fbff;
  --panel:#ffffff;
  --panel-soft:rgba(14,20,29,0.045);
  --line:rgba(18,24,33,0.13);
  --text:#10141c;
  --muted:#5f6877;
  --soft:#2d3543;
  --gold:#1d6fb8;
  --steel:#253040;
  --brand-blue:#1d6fb8;
  --teal:#5f7894;
  --rose:#4f7ead;
  --accent-soft:rgba(29,111,184,0.11);
  --accent-line:rgba(29,111,184,0.24);
  --button-gradient:linear-gradient(135deg, #f8fbff, #d7e8fb 42%, #4b9be0);
  --shadow:0 24px 70px rgba(29,57,89,0.14);
  --body-bg:
    linear-gradient(180deg, rgba(29,111,184,0.14), transparent 18rem),
    linear-gradient(135deg, #f8fbff 0%, #eef5fb 48%, #ffffff 100%);
  --grid-line:rgba(16,24,33,0.055);
  --nav-bg:rgba(248,251,255,0.84);
  --hero-overlay:
    linear-gradient(90deg, rgba(248,251,255,0.96) 0%, rgba(248,251,255,0.84) 44%, rgba(248,251,255,0.36) 76%, rgba(248,251,255,0.78) 100%),
    linear-gradient(180deg, transparent 0%, #f8fbff 98%);
  --hero-mobile-overlay:linear-gradient(180deg, rgba(248,251,255,0.86), rgba(248,251,255,0.98));
  --hero-image:url('assets/krylance-hero-light.jpg');
  --solid-surface:rgba(255,255,255,0.86);
  --solid-surface-hover:rgba(255,255,255,0.98);
  --glass-surface:rgba(255,255,255,0.68);
  --field-bg:rgba(255,255,255,0.72);
  --field-bg-focus:rgba(255,255,255,0.96);
  --auth-overlay:linear-gradient(90deg, rgba(248,251,255,0.94), rgba(248,251,255,0.7));
  --auth-card-bg:rgba(255,255,255,0.84);
  --button-text:#10141c;
  color-scheme:light;
}

*{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  font-family:'Inter', Arial, sans-serif;
  background:var(--body-bg);
  color:var(--text);
  transition:background 220ms ease, color 220ms ease;
}

body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background-image:linear-gradient(var(--grid-line) 1px, transparent 1px), linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,0.4), transparent 72%);
  z-index:-1;
}

a{
  color:inherit;
}

.navbar{
  position:sticky;
  top:0;
  z-index:20;
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:28px;
  width:100%;
  padding:18px clamp(16px, 4vw, 52px);
  background:var(--nav-bg);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(18px);
}

.logo{
  position:relative;
  z-index:2;
  display:inline-flex;
  align-items:center;
  flex-shrink:0;
  text-decoration:none;
  width:min(300px, 42vw);
  min-width:190px;
  padding:5px 8px;
  border-radius:var(--radius);
  background:linear-gradient(90deg, rgba(5,8,14,0.72), rgba(5,8,14,0.24));
  cursor:pointer;
}

:root[data-theme="light"] .logo{
  background:linear-gradient(90deg, rgba(255,255,255,0.82), rgba(255,255,255,0.28));
}

.logo img{
  display:block;
  width:100%;
  height:auto;
  filter:drop-shadow(0 10px 30px rgba(93,167,242,0.18));
  pointer-events:none;
}

.logo .logo-light{
  display:none;
}

:root[data-theme="light"] .logo .logo-dark{
  display:none;
}

:root[data-theme="light"] .logo .logo-light{
  display:block;
}

.nav-links{
  display:flex;
  align-items:center;
  flex:1 1 auto;
  justify-content:center;
  flex-wrap:wrap;
  gap:10px;
  min-width:0;
}

.site-controls{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex:0 1 auto;
  flex-wrap:wrap;
  gap:8px;
  min-width:0;
  max-width:100%;
}

.auth-status{
  display:flex;
  align-items:center;
  gap:8px;
  max-width:min(280px, 34vw);
  min-width:0;
  padding:6px 8px 6px 12px;
  border:1px solid var(--line);
  color:var(--text);
  background:var(--panel-soft);
  border-radius:var(--radius);
}

.auth-status[hidden]{
  display:none;
}

.auth-status span{
  min-width:0;
  overflow:hidden;
  color:var(--muted);
  font-size:13px;
  font-weight:700;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.auth-logout{
  min-height:30px;
  padding:0 10px;
  color:var(--text);
  border-color:var(--accent-line);
  background:var(--accent-soft);
  box-shadow:none;
  font-size:12px;
}

.nav-links a{
  color:var(--muted);
  text-decoration:none;
  padding:10px 12px;
  font-size:15px;
  font-weight:600;
  transition:color 180ms ease, background 180ms ease;
}

.nav-links a:hover{
  color:var(--text);
}

.nav-links .nav-cta{
  color:var(--text);
  border:1px solid var(--accent-line);
  background:var(--accent-soft);
  border-radius:var(--radius);
}

.control-button{
  min-width:44px;
  min-height:40px;
  padding:0 12px;
  color:var(--text);
  border-color:var(--line);
  background:var(--panel-soft);
  box-shadow:none;
}

.password-field{
  position:relative;
  margin-bottom:12px;
}

.auth-card .password-field input{
  margin-bottom:0;
  padding-right:74px;
}

.auth-card .password-toggle{
  position:absolute;
  top:50%;
  right:12px;
  display:grid;
  place-items:center;
  width:46px;
  min-width:46px;
  height:46px;
  min-height:46px;
  max-width:46px;
  padding:0;
  margin:0;
  color:var(--brand-blue);
  border-color:var(--accent-line);
  background:linear-gradient(180deg, var(--accent-soft), rgba(255,255,255,0.04));
  box-shadow:none;
  transform:translateY(-50%);
}

.auth-card .password-toggle:hover{
  transform:translateY(-50%);
  border-color:var(--brand-blue);
  background:var(--solid-surface-hover);
}

.auth-card .password-toggle:focus-visible{
  outline:2px solid var(--brand-blue);
  outline-offset:2px;
}

.password-icon{
  width:21px;
  height:21px;
  fill:none;
  stroke:currentColor;
  stroke-linecap:round;
  stroke-linejoin:round;
  stroke-width:2;
}

.password-icon-closed,
.auth-card .password-toggle.is-visible .password-icon-open{
  display:none;
}

.auth-card .password-toggle.is-visible .password-icon-closed{
  display:block;
}

.hero{
  min-height:calc(100vh - 78px);
  display:flex;
  align-items:center;
  padding:88px clamp(20px, 6vw, 88px) 64px;
  background:
    var(--hero-overlay),
    var(--hero-image) center right / cover no-repeat;
}

.hero-content{
  width:min(680px, 100%);
}

.eyebrow{
  margin:0 0 16px;
  color:var(--brand-blue);
  font-size:12px;
  font-weight:800;
  letter-spacing:0;
  text-transform:uppercase;
}

h1,
h2,
h3,
p{
  margin-top:0;
}

.hero h1{
  margin-bottom:24px;
  font-size:clamp(34px, 5.2vw, 66px);
  line-height:1.04;
  font-weight:800;
  max-width:720px;
}

.hero-copy{
  max-width:650px;
  margin-bottom:34px;
  color:var(--soft);
  font-size:clamp(18px, 2vw, 22px);
  line-height:1.65;
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-bottom:54px;
}

.button,
button,
.price-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  padding:0 22px;
  border:1px solid transparent;
  border-radius:var(--radius);
  font:inherit;
  font-weight:800;
  text-decoration:none;
  cursor:pointer;
  transition:transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.button:hover,
button:hover,
.price-button:hover{
  transform:translateY(-2px);
}

.primary,
button,
.price-button{
  color:var(--button-text);
  background:var(--button-gradient);
  box-shadow:0 18px 50px rgba(93,167,242,0.22);
}

.secondary{
  color:var(--text);
  border-color:var(--line);
  background:rgba(255,255,255,0.07);
}

.site-controls .control-button{
  min-width:44px;
  min-height:40px;
  padding:0 12px;
  color:var(--text);
  border-color:var(--line);
  background:var(--panel-soft);
  box-shadow:none;
}

.hero-stats{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:1px;
  max-width:720px;
  border:1px solid var(--line);
  background:var(--line);
  box-shadow:var(--shadow);
}

.hero-stats div{
  padding:20px;
  background:var(--solid-surface);
  backdrop-filter:blur(14px);
}

.hero-stats strong{
  display:block;
  margin-bottom:6px;
  color:var(--brand-blue);
  font-size:28px;
}

.hero-stats span{
  color:var(--muted);
  font-size:14px;
  line-height:1.45;
}

main{
  overflow:hidden;
}

.intro,
.services,
.why-choose,
.pricing,
.process,
.contact,
.dashboard{
  padding:96px clamp(20px, 6vw, 88px);
}

.intro{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0, 0.92fr) minmax(360px, 0.55fr);
  gap:clamp(28px, 5vw, 76px);
  align-items:center;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:
    linear-gradient(135deg, rgba(125,183,255,0.12), transparent 32%),
    var(--panel-soft);
}

.intro::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size:90px 90px;
  opacity:0.42;
}

.intro-copy,
.intro-panel{
  position:relative;
  z-index:1;
}

.intro-copy{
  max-width:760px;
}

.intro h2,
.section-heading h2,
.contact h2,
.dashboard h1{
  margin:0;
  font-size:clamp(32px, 4.5vw, 58px);
  line-height:1.03;
}

.intro-copy > p,
.contact-copy p,
.dashboard-heading p{
  color:var(--muted);
  font-size:18px;
  line-height:1.75;
}

.intro-copy > p{
  max-width:620px;
  margin:24px 0 28px;
}

.intro-panel{
  padding:28px;
  border:1px solid var(--accent-line);
  border-radius:var(--radius);
  background:
    linear-gradient(180deg, rgba(125,183,255,0.14), transparent),
    var(--solid-surface);
  box-shadow:var(--shadow);
}

.intro-panel-header{
  display:grid;
  gap:8px;
  margin-bottom:22px;
}

.intro-panel-header span{
  color:var(--brand-blue);
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
}

.intro-panel-header strong{
  color:var(--text);
  font-size:clamp(24px, 3vw, 34px);
  line-height:1.08;
}

.intro-list{
  display:grid;
  gap:12px;
  margin:0;
  padding:0;
  list-style:none;
}

.intro-list li{
  position:relative;
  min-height:54px;
  padding:15px 16px 15px 46px;
  border:1px solid var(--line);
  border-radius:calc(var(--radius) - 4px);
  color:var(--soft);
  background:rgba(255,255,255,0.04);
  font-weight:800;
}

.intro-list li::before{
  content:"";
  position:absolute;
  top:50%;
  left:18px;
  width:12px;
  height:12px;
  border:2px solid var(--brand-blue);
  border-radius:50%;
  transform:translateY(-50%);
  box-shadow:0 0 0 5px rgba(125,183,255,0.1);
}

.section-heading{
  max-width:780px;
  margin-bottom:42px;
}

.services-heading{
  max-width:none;
  margin-bottom:58px;
}

.services-heading h2{
  max-width:920px;
}

.cards{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  border:1px solid var(--line);
  background:var(--line);
  box-shadow:var(--shadow);
}

.service-cards{
  position:relative;
  grid-template-columns:0.9fr 1.22fr 0.9fr;
  gap:16px;
  align-items:stretch;
  border:0;
  background:transparent;
  box-shadow:none;
}

.service-cards::before{
  content:"";
  position:absolute;
  inset:-72px 8% auto;
  height:160px;
  pointer-events:none;
  background:radial-gradient(circle, rgba(125,183,255,0.2), transparent 66%);
  filter:blur(18px);
}

.card{
  position:relative;
  min-height:330px;
  padding:34px;
  background:var(--solid-surface);
  transition:transform 220ms ease, border-color 220ms ease, background 220ms ease, box-shadow 220ms ease;
}

.card:hover{
  transform:translateY(-6px);
  background:var(--solid-surface-hover);
}

.service-card{
  isolation:isolate;
  min-height:360px;
  overflow:hidden;
  color:inherit;
  text-decoration:none;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:
    linear-gradient(145deg, rgba(255,255,255,0.08), transparent 34%),
    rgba(255,255,255,0.045);
  box-shadow:0 20px 70px rgba(0,0,0,0.22);
  backdrop-filter:blur(20px);
}

.service-card-link{
  cursor:pointer;
}

.service-card-link:focus-visible{
  outline:3px solid var(--brand-blue);
  outline-offset:4px;
}

.service-card > *{
  position:relative;
  z-index:1;
}

.service-card:nth-child(4){
  grid-column:1 / -1;
  min-height:240px;
}

.service-card::before,
.service-card::after{
  content:"";
  position:absolute;
  pointer-events:none;
  opacity:0;
  transition:opacity 220ms ease, transform 420ms ease;
}

.service-card::before{
  inset:-1px;
  z-index:0;
  border-radius:inherit;
  background:linear-gradient(135deg, transparent, rgba(125,183,255,0.62), transparent 58%);
  transform:translateX(-24%);
}

.service-card::after{
  inset:1px;
  z-index:0;
  border-radius:inherit;
  background:
    radial-gradient(circle at 24% 10%, rgba(125,183,255,0.2), transparent 34%),
    linear-gradient(180deg, rgba(16,20,28,0.92), rgba(16,20,28,0.74));
}

:root[data-theme="light"] .service-card::after{
  background:
    radial-gradient(circle at 24% 10%, rgba(29,111,184,0.16), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(255,255,255,0.8));
}

.service-card:hover{
  transform:translateY(-10px) scale(1.015);
  border-color:rgba(125,183,255,0.56);
  box-shadow:0 30px 110px rgba(93,167,242,0.22);
}

.service-card:hover::before,
.service-card:hover::after{
  opacity:1;
}

.service-card:hover::before{
  animation:borderDrift 1800ms ease-in-out infinite;
}

.featured-card{
  background:linear-gradient(180deg, var(--accent-soft), var(--solid-surface-hover));
}

.service-card-large{
  min-height:430px;
  padding:38px;
  border-color:var(--accent-line);
  background:
    radial-gradient(circle at 22% 0%, rgba(125,183,255,0.24), transparent 34%),
    linear-gradient(180deg, rgba(93,167,242,0.14), var(--solid-surface-hover));
  box-shadow:0 34px 120px rgba(93,167,242,0.24);
}

.service-badge{
  position:absolute;
  top:22px;
  right:22px;
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:0 12px;
  color:var(--button-text);
  background:var(--button-gradient);
  border-radius:999px;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  box-shadow:0 14px 34px rgba(93,167,242,0.28);
}

.service-icon{
  display:grid;
  place-items:center;
  width:58px;
  height:58px;
  margin-bottom:34px;
  color:#dcecff;
  border:1px solid rgba(125,183,255,0.32);
  background:
    radial-gradient(circle at 35% 25%, rgba(255,255,255,0.18), transparent 34%),
    linear-gradient(145deg, rgba(125,183,255,0.2), rgba(255,255,255,0.04));
  border-radius:18px;
  box-shadow:0 18px 46px rgba(93,167,242,0.2), inset 0 1px 0 rgba(255,255,255,0.18);
  transition:transform 220ms ease, box-shadow 220ms ease;
}

.service-icon svg{
  width:28px;
  height:28px;
  fill:none;
  stroke:currentColor;
  stroke-linecap:round;
  stroke-linejoin:round;
  stroke-width:1.7;
}

.service-card:hover .service-icon{
  transform:translateY(-3px) scale(1.07);
  box-shadow:0 24px 62px rgba(93,167,242,0.3), inset 0 1px 0 rgba(255,255,255,0.22);
}

.card-number{
  display:block;
  margin-bottom:26px;
  color:var(--brand-blue);
  font-size:13px;
  font-weight:800;
}

.card h3,
.timeline h3{
  margin-bottom:12px;
  font-size:24px;
}

.card p,
.price-card p,
.timeline p,
.message-card p{
  color:var(--muted);
  line-height:1.7;
}

.service-card p{
  max-width:560px;
  color:var(--soft);
}

.services-cta{
  display:flex;
  justify-content:center;
  margin-top:34px;
}

.why-choose{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:
    radial-gradient(circle at 78% 12%, rgba(93,167,242,0.12), transparent 32%),
    var(--panel-soft);
}

.why-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:16px;
}

.why-grid article{
  min-height:230px;
  padding:28px;
  border:1px solid var(--line);
  background:var(--glass-surface);
  border-radius:var(--radius);
  box-shadow:0 18px 60px rgba(0,0,0,0.16);
  transition:transform 220ms ease, border-color 220ms ease, background 220ms ease;
}

.why-grid article:hover{
  transform:translateY(-6px);
  border-color:var(--accent-line);
  background:var(--solid-surface-hover);
}

.why-grid span{
  display:block;
  margin-bottom:42px;
  color:var(--brand-blue);
  font-size:13px;
  font-weight:900;
}

.why-grid h3{
  margin-bottom:12px;
  font-size:22px;
}

.why-grid p{
  margin-bottom:0;
  color:var(--muted);
  line-height:1.7;
}

@keyframes borderDrift{
  0%{
    transform:translateX(-28%);
  }

  50%{
    transform:translateX(28%);
  }

  100%{
    transform:translateX(-28%);
  }
}

.pricing{
  background:linear-gradient(180deg, transparent, var(--panel-soft));
}

.pricing-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
  align-items:stretch;
}

.pricing .section-heading > p:not(.eyebrow){
  max-width:850px;
  margin:18px auto 0;
  color:var(--soft);
  font-size:18px;
  line-height:1.7;
}

.price-card{
  position:relative;
  display:flex;
  flex-direction:column;
  min-height:280px;
  padding:30px;
  border:1px solid var(--line);
  background:var(--solid-surface);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
  transition:transform 220ms ease, border-color 220ms ease, background 220ms ease, box-shadow 220ms ease;
}

.price-card::after{
  content:"";
  position:absolute;
  inset:-80% 0 auto;
  height:70%;
  pointer-events:none;
  background:linear-gradient(180deg, transparent, rgba(125,183,255,0.16), transparent);
  opacity:0;
  transform:translateY(-40%);
}

.price-card:hover{
  border-color:var(--accent-line);
  background:var(--solid-surface-hover);
}

.price-card:hover::after{
  opacity:1;
  animation:offerSweep 1500ms ease-in-out infinite;
}

.pricing-grid .price-card:hover:not(.ultimate-price),
.maintenance-grid .price-card:hover:not(.ultimate-price){
  transform:translateY(-6px);
}

.featured-price{
  border-color:var(--accent-line);
  background:linear-gradient(180deg, var(--accent-soft), var(--solid-surface-hover));
}

.ultimate-price{
  transform:translateY(-10px);
  border-color:var(--brand-blue);
  background:
    linear-gradient(145deg, rgba(125,183,255,0.24), transparent 46%),
    linear-gradient(180deg, var(--accent-soft), var(--solid-surface-hover));
  box-shadow:0 28px 90px rgba(93,167,242,0.28);
}

.ultimate-price:hover{
  transform:translateY(-14px);
}

.price-card[id^="offer-"]{
  scroll-margin-top:110px;
}

.price-card[id^="offer-"]:target{
  border-color:var(--brand-blue);
  box-shadow:0 0 0 3px rgba(125,183,255,0.2), 0 30px 110px rgba(93,167,242,0.34);
}

.popular-badge{
  position:absolute;
  top:18px;
  right:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:30px;
  padding:0 12px;
  color:var(--button-text);
  background:var(--button-gradient);
  border-radius:999px;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  box-shadow:0 14px 34px rgba(93,167,242,0.24);
}

.price-label{
  min-height:34px;
  margin-bottom:32px;
  padding-right:92px;
  color:var(--brand-blue);
  font-size:13px;
  font-weight:800;
  text-transform:uppercase;
}

.price-card:not(.ultimate-price) .price-label{
  padding-right:0;
}

.price-card h3{
  margin-bottom:14px;
  color:var(--text);
  font-size:clamp(42px, 5vw, 64px);
  line-height:1;
}

.price-card h3 .price-period{
  display:block;
  margin-top:8px;
  color:var(--muted);
  font-size:16px;
  line-height:1.3;
}

.price-features{
  display:grid;
  gap:10px;
  margin:18px 0 28px;
  padding:0;
  list-style:none;
  transform:translateY(0);
}

.price-features li{
  position:relative;
  padding-left:24px;
  color:var(--soft);
  font-size:14px;
  line-height:1.45;
}

.price-features li::before{
  content:"";
  position:absolute;
  top:0.62em;
  left:0;
  width:10px;
  height:10px;
  border:2px solid var(--brand-blue);
  border-radius:50%;
  transform:translateY(-50%);
}

.price-card:hover .price-features{
  animation:offerFeatureScroll 1700ms ease-in-out infinite alternate;
}

.price-actions{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  width:100%;
  margin-top:auto;
  position:relative;
  z-index:1;
}

.price-button{
  width:min(360px,100%);
  max-width:360px;
}

.price-button-soft{
  color:var(--text);
  border-color:var(--line);
  background:rgba(255,255,255,0.04);
  box-shadow:none;
}

.price-button-soft:hover{
  border-color:var(--accent-line);
  background:var(--solid-surface-hover);
}

.pricing-note{
  display:grid;
  justify-items:center;
  gap:18px;
  max-width:780px;
  margin:34px auto 0;
  text-align:center;
}

.pricing-note p{
  margin:0;
  color:var(--soft);
  font-size:17px;
  line-height:1.7;
}

.contact-options{
  display:grid;
  gap:12px;
  margin:24px 0;
}

.contact-options div{
  position:relative;
  display:grid;
  gap:6px;
  padding:16px 16px 16px 44px;
  border:1px solid var(--line);
  border-radius:calc(var(--radius) - 4px);
  background:rgba(255,255,255,0.04);
}

.contact-options div::before{
  content:"";
  position:absolute;
  left:18px;
  top:18px;
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--brand-blue);
  box-shadow:0 0 0 6px rgba(27,111,194,0.14);
}

.contact-options strong{
  color:var(--brand-blue);
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
}

.contact-options span{
  color:var(--soft);
  line-height:1.55;
}

@keyframes offerSweep{
  0%{
    transform:translateY(-42%);
  }

  100%{
    transform:translateY(230%);
  }
}

@keyframes offerFeatureScroll{
  0%{
    transform:translateY(0);
  }

  100%{
    transform:translateY(-10px);
  }
}

.maintenance-offers{
  margin-top:34px;
}

.compact-heading{
  max-width:760px;
  margin-bottom:22px;
}

.compact-heading h3{
  margin-bottom:10px;
  color:var(--text);
  font-size:clamp(30px, 4vw, 46px);
  line-height:1.08;
}

.compact-heading p:last-child{
  color:var(--muted);
  line-height:1.7;
}

.maintenance-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
}

.maintenance-card{
  min-height:300px;
}

.process{
  background:linear-gradient(180deg, rgba(255,255,255,0.03), transparent);
}

.timeline{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:16px;
}

.timeline div{
  padding:26px;
  border:1px solid var(--line);
  background:var(--glass-surface);
  border-radius:var(--radius);
}

.timeline span{
  display:grid;
  place-items:center;
  width:34px;
  height:34px;
  margin-bottom:28px;
  color:#091016;
  background:linear-gradient(135deg, #dcecff, var(--brand-blue));
  border-radius:50%;
  font-weight:800;
}

.contact-panel{
  display:grid;
  grid-template-columns:minmax(0, 0.85fr) minmax(320px, 0.65fr);
  gap:36px;
  align-items:stretch;
  padding:42px;
  border:1px solid var(--accent-line);
  background:
    linear-gradient(135deg, var(--accent-soft), transparent 42%),
    var(--glass-surface);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}

.contact-copy a,
.message-card a{
  color:var(--brand-blue);
  font-weight:800;
  text-decoration:none;
}

.contact-form{
  display:grid;
  gap:14px;
}

.contact-form label{
  display:grid;
  gap:8px;
}

.contact-form label span,
.form-help{
  color:var(--muted);
  font-size:13px;
  font-weight:800;
}

.form-help{
  margin:-4px 0 2px;
  font-weight:600;
  line-height:1.5;
}

.contact-form.is-locked input,
.contact-form.is-locked select,
.contact-form.is-locked textarea{
  opacity:0.62;
  cursor:not-allowed;
}

.contact-auth-note{
  margin:2px 0 0;
  color:var(--muted);
  font-size:14px;
  line-height:1.5;
}

.contact-form:not(.is-locked) .contact-auth-note{
  display:none;
}

input,
select,
textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--field-bg);
  color:var(--text);
  font:inherit;
  outline:none;
  padding:17px 18px;
  transition:border-color 180ms ease, background 180ms ease;
}

input:focus,
select:focus,
textarea:focus{
  border-color:var(--brand-blue);
  background:var(--field-bg-focus);
}

select{
  appearance:none;
}

textarea{
  min-height:150px;
  resize:vertical;
}

.auth-page,
.dashboard-page{
  min-height:100vh;
}

.auth-shell{
  min-height:calc(100vh - 78px);
  display:grid;
  place-items:center;
  padding:52px 20px;
  background:
    var(--auth-overlay),
    var(--hero-image) center / cover no-repeat;
}

.auth-card{
  width:min(520px, 100%);
  padding:42px;
  border:1px solid var(--line);
  background:var(--auth-card-bg);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  backdrop-filter:blur(20px);
}

.auth-card h1{
  margin-bottom:6px;
  font-size:44px;
}

.auth-card h2{
  margin-bottom:28px;
  color:var(--muted);
  font-size:20px;
  font-weight:600;
}

.auth-card input{
  margin-bottom:12px;
}

.auth-card button{
  width:100%;
  margin-top:10px;
}

.admin-entry{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  margin-top:12px;
  color:var(--text);
  border:1px solid var(--accent-line);
  background:var(--accent-soft);
  border-radius:var(--radius);
  font-weight:800;
  text-decoration:none;
}

.admin-entry[hidden],
.admin-nav-link[hidden]{
  display:none;
}

#switch-text{
  margin:24px 0 0;
  color:var(--muted);
  text-align:center;
}

#switch-text span{
  color:var(--brand-blue);
  cursor:pointer;
  font-weight:800;
}

.dashboard{
  max-width:1180px;
  margin:0 auto;
}

.dashboard-heading{
  max-width:720px;
  margin-bottom:34px;
}

.dashboard-summary{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:14px;
  margin-bottom:18px;
}

.admin-management{
  display:grid;
  gap:18px;
  margin-bottom:18px;
}

.dashboard-summary article{
  padding:20px;
  border:1px solid var(--line);
  background:var(--solid-surface);
  border-radius:var(--radius);
}

.dashboard-summary span{
  display:block;
  margin-bottom:10px;
  color:var(--muted);
  font-size:13px;
  font-weight:800;
}

.dashboard-summary strong{
  display:block;
  overflow:hidden;
  font-size:28px;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.admin-panel{
  display:grid;
  grid-template-columns:minmax(220px, 0.6fr) minmax(0, 1fr);
  gap:24px;
  align-items:start;
  padding:24px;
  border:1px solid var(--accent-line);
  background:var(--glass-surface);
  border-radius:var(--radius);
}

.admin-panel h2{
  margin:0 0 8px;
  font-size:24px;
}

.admin-panel p{
  margin:0;
  color:var(--muted);
}

.price-editor{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}

.price-editor label{
  display:grid;
  gap:8px;
}

.price-editor label span{
  color:var(--muted);
  font-size:13px;
  font-weight:800;
}

.price-editor button{
  grid-column:1 / -1;
}

.admin-filters{
  display:grid;
  grid-template-columns:minmax(220px, 0.6fr) minmax(0, 1fr);
  gap:24px;
  align-items:center;
  margin-bottom:18px;
  padding:20px;
  border:1px solid var(--line);
  background:var(--solid-surface);
  border-radius:var(--radius);
}

.admin-filters h2{
  margin:0;
  font-size:22px;
}

.filter-controls{
  display:grid;
  grid-template-columns:minmax(220px, 1fr) repeat(3, minmax(150px, 0.45fr)) auto;
  gap:12px;
}

.messages-grid{
  display:grid;
  gap:16px;
}

.message-card,
.empty-state{
  padding:24px;
  border:1px solid var(--line);
  background:var(--glass-surface);
  border-radius:var(--radius);
}

.message-topline{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:8px;
}

.message-topline h3{
  margin:0;
  font-size:22px;
}

.message-topline span,
.empty-state{
  color:var(--muted);
}

.message-timestamp{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:4px;
  padding:8px 12px;
  background:var(--accent-soft);
  border:1px solid var(--accent-line);
  border-radius:var(--radius);
  font-size:13px;
}

.message-timestamp strong{
  color:var(--brand-blue);
  font-weight:600;
}

.message-timestamp span{
  color:var(--text);
  font-weight:500;
  font-family:monospace;
}

.command-summary{
  margin:14px 0;
  padding:16px;
  border:1px solid var(--accent-line);
  background:var(--accent-soft);
  border-radius:calc(var(--radius) - 4px);
}

.command-summary strong{
  display:inline-flex;
  margin-bottom:6px;
  color:var(--brand-blue);
  font-size:14px;
  letter-spacing:0;
  text-transform:uppercase;
}

.command-summary p{
  margin:0;
  color:var(--text);
}

.admin-workflow{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
  margin:16px 0;
  padding:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,0.035);
  border-radius:var(--radius);
}

.admin-workflow label{
  display:grid;
  gap:8px;
}

.admin-workflow span{
  color:var(--muted);
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
}

.admin-workflow .admin-note{
  grid-column:1 / -1;
}

.admin-workflow textarea{
  min-height:84px;
}

.message-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}

.admin-action{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 16px;
  border:1px solid var(--line);
  color:var(--text);
  background:var(--solid-surface);
  border-radius:999px;
  font-weight:800;
  text-decoration:none;
}

.admin-action.danger{
  color:#ffffff;
  background:#b42318;
  border-color:#b42318;
}

.site-footer{
  padding:28px clamp(20px, 6vw, 88px);
  border-top:1px solid var(--line);
  background:var(--nav-bg);
  color:var(--muted);
  text-align:center;
}

.site-footer p{
  margin:0;
  font-size:14px;
  font-weight:700;
}

@media (max-width:900px){
  .navbar{
    align-items:flex-start;
    flex-direction:column;
    padding-right:20px;
  }

  .nav-links{
    width:100%;
    flex-wrap:wrap;
    justify-content:flex-start;
  }

  .site-controls{
    position:absolute;
    top:18px;
    right:20px;
    max-width:calc(100% - 40px);
    justify-content:flex-end;
  }

  .hero{
    min-height:auto;
    padding-top:74px;
  }

  .hero-stats,
  .intro,
  .services-heading,
  .cards,
  .why-grid,
  .pricing-grid,
  .maintenance-grid,
  .timeline,
  .dashboard-summary,
  .admin-panel,
  .admin-filters,
  .filter-controls,
  .price-editor,
  .admin-workflow,
  .contact-panel{
    grid-template-columns:1fr;
  }

  .card{
    min-height:auto;
  }

  .service-card:nth-child(4){
    grid-column:auto;
  }

  .ultimate-price,
  .ultimate-price:hover{
    transform:none;
  }

  .card-number{
    margin-bottom:42px;
  }
}

@media (max-width:1320px) and (min-width:901px){
  .navbar{
    gap:16px;
  }

  .logo{
    width:250px;
    min-width:220px;
  }

  .nav-links{
    gap:6px;
    justify-content:flex-end;
  }

  .nav-links a{
    padding:9px 10px;
  }

  .auth-status{
    max-width:230px;
  }
}

@media (max-width:1180px) and (min-width:901px){
  .cards,
  .why-grid,
  .pricing-grid,
  .maintenance-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .service-card-large{
    grid-column:span 2;
  }
}

@media (max-width:560px){
  .nav-links a{
    padding:9px 8px;
    font-size:14px;
  }

  .hero{
    background:
      var(--hero-mobile-overlay),
      var(--hero-image) center / cover no-repeat;
  }

  .hero-actions,
  .button{
    width:100%;
  }

  .intro,
  .services,
  .why-choose,
  .pricing,
  .process,
  .contact,
  .dashboard{
    padding:68px 20px;
  }

  .contact-panel,
  .auth-card{
    padding:26px;
  }

  .message-topline{
    display:block;
  }
}

@media (max-width:560px){
  body::before{background-size:42px 42px}
  .navbar{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px 12px;padding:12px 14px 10px}
  .logo{width:min(170px,52vw);min-width:0;padding:4px 6px}
  .site-controls{position:static;gap:6px;max-width:none;flex-wrap:nowrap}
  .site-controls .control-button{min-width:38px;min-height:36px;padding:0 9px;font-size:13px}
  .auth-status{max-width:none;padding:3px}
  .auth-status span{display:none}
  .auth-logout{min-height:30px;padding:0 8px;font-size:11px}
  .nav-links{grid-column:1/-1;display:grid;grid-auto-flow:column;grid-auto-columns:max-content;gap:4px;width:calc(100% + 28px);margin:0 -14px;padding:2px 14px 1px;overflow-x:auto;scrollbar-width:none}
  .nav-links::-webkit-scrollbar{display:none}
  .nav-links a{min-height:36px;padding:8px 10px;font-size:12px;white-space:nowrap}
  .hero{min-height:calc(100svh - 112px);align-items:flex-end;padding:52px 18px 24px;background:var(--hero-mobile-overlay),var(--hero-image) 58% center/cover no-repeat}
  .hero h1{margin-bottom:16px;font-size:clamp(34px,11.5vw,46px);line-height:.98}
  .hero-copy{margin-bottom:22px;font-size:16px;line-height:1.55}
  .eyebrow{margin-bottom:10px;font-size:10px}
  .hero-actions{gap:9px;margin-bottom:24px}
  .button,button,.price-button{min-height:48px;padding:0 16px;font-size:14px}
  .hero-stats{grid-template-columns:repeat(3,minmax(0,1fr));box-shadow:none}
  .hero-stats div{padding:13px 10px}
  .hero-stats strong{margin-bottom:4px;font-size:20px}
  .hero-stats span{font-size:10px;line-height:1.3}
  .contact,.dashboard,.intro,.pricing,.process,.services,.why-choose{padding:52px 18px}
  .intro{gap:28px}
  .contact h2,.dashboard h1,.intro h2,.section-heading h2{font-size:clamp(30px,9.5vw,40px);line-height:1.02}
  .contact-copy p,.dashboard-heading p,.intro-copy>p,.pricing .section-heading>p:not(.eyebrow){font-size:15px;line-height:1.6}
  .intro-copy>p{margin:18px 0 22px}
  .intro-panel{padding:18px}
  .intro-panel-header{margin-bottom:16px}
  .intro-panel-header strong{font-size:24px}
  .intro-list{gap:8px}
  .intro-list li{min-height:48px;padding:13px 12px 13px 40px;font-size:13px}
  .intro-list li::before{left:15px}
  .section-heading,.services-heading{margin-bottom:26px}
  .pricing-grid,.service-cards,.timeline,.why-grid{gap:12px}
  .card,.price-card,.service-card-large,.timeline div,.why-grid article{min-height:auto;padding:22px}
  .service-card:nth-child(4){min-height:auto}
  .service-icon{width:48px;height:48px;margin-bottom:20px;border-radius:14px}
  .service-icon svg{width:24px;height:24px}
  .popular-badge,.service-badge{top:14px;right:14px;min-height:26px;padding:0 9px;font-size:9px}
  .card-number,.why-grid span{margin-bottom:18px}
  .card h3,.timeline h3,.why-grid h3{font-size:20px}
  .card p,.price-card p,.timeline p,.why-grid p{font-size:14px;line-height:1.55}
  .services-cta{margin-top:20px}
  .price-card h3{font-size:48px}
  .price-label{min-height:26px;margin-bottom:20px}
  .price-features{gap:8px;margin:14px 0 22px}
  .pricing-note{gap:12px;margin-top:24px}
  .pricing-note p{font-size:14px;line-height:1.55}
  .timeline span{margin-bottom:18px}
  .contact-panel{gap:28px}
  .auth-card,.contact-panel{padding:20px}
  .contact-options{margin:18px 0}
  .contact-options div{padding:13px 12px 13px 38px}
  .contact-options div::before{top:16px;left:14px}
  .contact-form{gap:11px}
  input,select,textarea{padding:14px;font-size:16px}
  textarea{min-height:120px}
  .auth-shell{min-height:calc(100svh - 112px);padding:30px 14px}
  .auth-card h1{font-size:38px}
  .dashboard-summary,.admin-management,.messages-grid{gap:10px}
  .admin-filters,.admin-panel,.dashboard-summary article,.empty-state,.message-card{padding:18px}
  .message-actions{display:grid}
  .admin-action{width:100%}
  .site-footer{padding:22px 18px}
}

@media (prefers-reduced-motion:reduce){
  .price-card,
  .price-card::after,
  .price-features,
  .service-card,
  .service-card::before,
  .service-card::after,
  .service-icon,
  .why-grid article{
    animation:none !important;
    transition:none;
  }
}
