:root{
  --bg:#12192a;
  --panel:#151d30;
  --muted:#6b7280;
  --text:#e5e7eb;
  --accent:#8b5cf6;
  --accent-2:#06b6d4;
  --ring: 0 0 0 4px rgba(139,92,246,.35);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background-color: #0b1220;
  background: 
    radial-gradient(ellipse 800px 600px at 10% 20%, rgba(139,92,246,.22), transparent),
    radial-gradient(ellipse 1000px 800px at 90% 0%, rgba(6,182,212,.18), transparent),
    radial-gradient(ellipse 600px 500px at 50% 100%, rgba(99,102,241,.15), transparent),
    radial-gradient(ellipse 900px 700px at 0% 100%, rgba(236,72,153,.10), transparent),
    linear-gradient(180deg, #141824 0%, #12192a 50%, #171e2e 100%);
  background-attachment: fixed;
  position: relative;
  min-height: 100vh;
}
@media (max-width: 768px) {
  body {
    background-attachment: scroll;
  }
}

/* Static mesh gradient overlay - fully optimized to prevent flickering */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background: 
    radial-gradient(circle 600px at 30% 20%, rgba(139,92,246,.08), transparent),
    radial-gradient(circle 800px at 70% 80%, rgba(6,182,212,.06), transparent);
  pointer-events: none;
  z-index: 0;
  opacity: 0.7;
  will-change: auto;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
  contain: layout style paint;
  isolation: isolate;
}

/* Subtle noise texture - fully optimized to prevent flickering */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.03'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
  opacity: 0.4;
  will-change: auto;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
  contain: layout style paint;
  isolation: isolate;
}

/* Ensure content appears above background layers */
.header,
.container,
main,
section,
footer {
  position: relative;
  z-index: 1;
}

a{color:inherit;text-decoration:none}
.container{max-width:1160px;margin:0 auto;padding:0 16px}
.button{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 26px;border-radius:12px;
  border:1px solid rgba(51,65,85,.6);
  background:linear-gradient(180deg, rgba(30,41,59,.75), rgba(15,23,42,.85));
  color:#e2e8f0;font-weight:600;font-size:15px;line-height:1.2;cursor:pointer;
  transition:.2s all ease;
  box-shadow:0 2px 8px rgba(0,0,0,.15);
  position:relative;
}
.button:hover{
  transform:translateY(-1px);
  box-shadow:0 4px 16px rgba(0,0,0,.25);
  border-color:rgba(71,85,105,.8);
  color:#f1f5f9;
}
.button--primary{
  background:linear-gradient(135deg, #7c3aed 0%, #6d28d9 100%);
  border:1px solid rgba(124,58,237,.4);
  color:#fff;
  box-shadow:0 4px 16px rgba(139,92,246,.25), 0 0 0 1px rgba(139,92,246,.1);
}
.button--primary:hover{
  transform:translateY(-2px);
  background:linear-gradient(135deg, #8b5cf6 0%, #7c3aed 100%);
  box-shadow:0 8px 24px rgba(139,92,246,.35), 0 0 0 1px rgba(139,92,246,.15);
  border-color:rgba(139,92,246,.5);
}
.button--primary:active{
  transform:translateY(0);
}
.button--ghost{
  background:rgba(15,23,42,.6);
  border-color:rgba(71,85,105,.5);
}
.button--ghost:hover{
  background:rgba(30,41,59,.7);
  border-color:rgba(100,116,139,.7);
}
.badge{
  display:inline-block;padding:7px 14px;
  border:1px solid rgba(139,92,246,.35);border-radius:999px;
  color:#a78bfa;
  background:rgba(139,92,246,.12);
  font-size:13px;font-weight:600;letter-spacing:0.8px;text-transform:uppercase;
  box-shadow:0 2px 12px rgba(139,92,246,.15);
  transition:all .3s ease;
}
.badge:hover{
  background:rgba(139,92,246,.12);
  box-shadow:0 4px 20px rgba(139,92,246,.25);
  border-color:rgba(139,92,246,.5);
}
/* .header{position:static;background:rgba(15,23,42,.85);border-bottom:1px solid rgba(139,92,246,.2);box-shadow:0 4px 24px rgba(0,0,0,.1)} */
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0}
.nav__left{display:flex;align-items:center;gap:16px}
.nav__logo{display:flex;align-items:center;gap:10px}
.nav__links{display:flex;gap:14px;align-items:center}
.nav__link{padding:10px 12px;border-radius:10px;color:#cbd5e1}
.nav__link:hover{background:#0b1220}
.nav__menu{display:none}
.hero{padding:28px 0 32px}
.hero__grid{display:grid;grid-template-columns:1fr;gap:24px;align-items:center}
.hero h1{
  font-size:clamp(26px,3.2vw,42px) !important;
  line-height:1.25 !important;
  margin:14px 0 14px !important;
  font-weight:800 !important;
  color:#f1f5f9 !important;
  letter-spacing:-0.01em !important;
  text-shadow:0 1px 2px rgba(0,0,0,.3) !important;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif !important;
  text-align:left !important;
  max-width:100% !important;
  width:auto !important;
  display:block !important;
  padding:0 !important;
  border:none !important;
  background:none !important;
}
.hero h1 .hero__highlight{
  background:linear-gradient(135deg, #8b5cf6 0%, #06b6d4 100%) !important;
  -webkit-background-clip:text !important;
  background-clip:text !important;
  -webkit-text-fill-color:transparent !important;
  font-weight:900 !important;
  display:inline !important;
}
/* Адаптивность h1 для разных экранов */
@media (max-width: 768px){
  .hero h1{
    font-size:clamp(24px,5vw,32px) !important;
    line-height:1.3 !important;
  }
}
@media (max-width: 480px){
  .hero h1{
    font-size:clamp(22px,6vw,28px) !important;
    line-height:1.35 !important;
  }
}
.hero h1::selection{
  background:rgba(139,92,246,.3);
  -webkit-text-fill-color:#fff;
}
.hero p{
  color:#cbd5e1;
  font-size:clamp(15px,1.9vw,19px);
  line-height:1.65;
  font-weight:400;
  max-width:680px;
}
.hero p strong{
  color:#e2e8f0;
  font-weight:600;
  position:relative;
  padding:0 2px;
}
.hero p strong::after{
  content:'';
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:8px;
  background:linear-gradient(90deg, rgba(139,92,246,.15), rgba(99,102,241,.15));
  z-index:-1;
  border-radius:2px;
}
.hero__features{
  list-style:none;
  padding:0;
  margin:18px 0 0 0;
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:12px;
  max-width:700px;
}
.hero__feature{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  background:rgba(15,23,42,.5);
  border:1px solid rgba(139,92,246,.2);
  border-radius:10px;
  color:#cbd5e1;
  font-size:15px;
  transition:all .25s ease;
}
.hero__feature:hover{
  background:rgba(15,23,42,.7);
  border-color:rgba(139,92,246,.35);
  transform:translateX(4px);
}
@media (max-width: 640px){
  .hero__features{
    grid-template-columns:1fr;
    max-width:100%;
  }
  .hero__feature{
    padding:11px 13px;
    font-size:14px;
  }
}
@media (max-width: 480px){
  .hero__feature{
    padding:10px 12px;
    font-size:13px;
    gap:10px;
  }
  .hero__icon{
    width:18px;
    height:18px;
  }
}
.hero__icon{
  flex-shrink:0;
  width:20px;
  height:20px;
  color:#a78bfa;
}
.hero__feature strong{
  color:#e2e8f0;
  font-weight:600;
}
.kpis{display:flex;gap:16px;flex-wrap:wrap;margin-top:14px}
.kpi{padding:10px 14px;border:1px solid rgba(139,92,246,.25);border-radius:12px;background:rgba(15,23,42,.8);font-size:14px;color:#e2e8f0;box-shadow:0 4px 12px rgba(0,0,0,.15)}
@media (max-width: 640px){
  .kpis{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .kpi{text-align:center}
}
.workbench{padding:18px 0 10px}
.panels{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.panel{
  background:linear-gradient(135deg, rgba(15,23,42,.9) 0%, rgba(11,18,32,.92) 100%);
  border:1px solid rgba(139,92,246,.25);
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 8px 24px rgba(0,0,0,.3), 0 0 0 1px rgba(139,92,246,.08), inset 0 1px 0 rgba(255,255,255,.03);
}
.panel__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 18px;
  border-bottom:1px solid rgba(139,92,246,.2);
  background:linear-gradient(135deg, rgba(139,92,246,.08) 0%, rgba(99,102,241,.06) 100%);
}
.panel__title{
  font-weight:700;
  font-size:16px;
  color:#f1f5f9;
  letter-spacing:-0.01em;
  text-shadow:0 1px 2px rgba(0,0,0,.3);
}
.panel__content{
  padding:18px;
  background:rgba(0,0,0,.1);
}
.form-group{display:grid;gap:8px;margin-bottom:12px}
.label{font-size:14px;color:#cbd5e1}
.input, .select, .textarea, .range{
  width:100%;padding:12px 12px;border-radius:12px;
  background:rgba(11,18,32,.85);
  border:1px solid rgba(139,92,246,.25);color:#e5e7eb;outline:none;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.input:focus, .select:focus, .textarea:focus{
  border-color:rgba(139,92,246,.5);
  box-shadow:0 0 0 3px rgba(139,92,246,.15);
}
.textarea{min-height:140px;resize:vertical}
.range{appearance:none;height:6px;border-radius:999px;background:#0b1220}
.range::-webkit-slider-thumb{appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent);border:2px solid #a78bfa;box-shadow:var(--ring)}
.helper{font-size:12px;color:#94a3b8}
.output{
  position:relative;
  display:grid;
  place-items:center;
  min-height:380px;
  border:2px dashed rgba(139,92,246,.25);
  border-radius:16px;
  background:linear-gradient(135deg, rgba(15,23,42,.5) 0%, rgba(11,18,32,.6) 50%, rgba(15,23,42,.55) 100%);
  overflow:hidden;
  box-shadow:inset 0 2px 8px rgba(0,0,0,.2);
}
.output__placeholder{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:20px;
  padding:32px 24px;
  max-width:420px;
}
.output__icon{
  width:80px;
  height:80px;
  padding:18px;
  border-radius:50%;
  background:linear-gradient(135deg, rgba(139,92,246,.15), rgba(99,102,241,.12));
  border:2px solid rgba(139,92,246,.25);
  color:#a78bfa;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 16px rgba(139,92,246,.15), inset 0 1px 0 rgba(255,255,255,.08);
}
.output__icon svg{
  width:100%;
  height:100%;
  stroke-width:1.5;
}
.output__text{
  text-align:center;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.output__text strong{
  color:#e2e8f0;
  font-size:17px;
  font-weight:700;
  letter-spacing:-0.01em;
  line-height:1.3;
}
.output__text p{
  margin:0;
  color:#94a3b8;
  font-size:14px;
  line-height:1.6;
}
.output__watermark{position:absolute;bottom:10px;right:12px;font-size:12px;color:#94a3b8;background:rgba(2,6,23,.6);padding:6px 8px;border-radius:8px;border:1px solid #334155}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.section{padding:40px 0}
.section h2{font-size:clamp(22px,3vw,30px);margin:0 0 10px}
.section p{color:#cbd5e1}
.seo{line-height:1.75;color:#cbd5e1}
.seo h3{margin-top:18px;margin-bottom:8px;color:#e5e7eb}
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.card{
  padding:16px;border:1px solid rgba(139,92,246,.2);border-radius:16px;
  background:linear-gradient(135deg, rgba(15,23,42,.85) 0%, rgba(11,18,32,.95) 100%);
  box-shadow:0 4px 16px rgba(0,0,0,.2), inset 0 1px 0 rgba(255,255,255,.02);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover{
  transform:translateY(-2px);
  border-color:rgba(139,92,246,.35);
  box-shadow:0 8px 24px rgba(0,0,0,.3), inset 0 1px 0 rgba(255,255,255,.04);
}

.footer{
  border-top:1px solid rgba(139,92,246,.15);
  padding:24px 0;margin-top:26px;color:#94a3b8;
  background:linear-gradient(180deg, rgba(15,23,42,.7) 0%, rgba(11,18,32,.85) 100%);
}
small, .muted{color:#94a3b8}

@media (max-width: 1024px){
  .hero__grid{grid-template-columns:1fr}
  .panels{grid-template-columns:1fr}
  .features{grid-template-columns:1fr 1fr}
}
@media (max-width: 640px){
  .nav__links{display:none}
  .nav__menu{display:inline-flex}
  .features{grid-template-columns:1fr}
}
@media (max-width: 360px){
  .kpis{gap:10px}
  .panel__head{flex-wrap:wrap;gap:8px}
}

/* --- FAQ --- */
.faq .container{max-width:1000px}
.faq__list{display:flex;flex-direction:column;gap:14px;margin-top:18px}
.faq__item{
  background:linear-gradient(135deg, rgba(15,23,42,.85) 0%, rgba(11,18,32,.95) 100%);
  border:1px solid rgba(139,92,246,.2);
  border-radius:16px;
  overflow:hidden;
  box-shadow: 0 8px 24px rgba(0,0,0,.3), inset 0 1px 0 rgba(255,255,255,.03);
}
.faq__summary{
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:18px 20px;
  cursor:pointer;
  position:relative;
}
.faq__summary::-webkit-details-marker{display:none}
.faq__summary h3{
  margin:0;
  font-size:20px;
  line-height:1.3;
}
.faq__icon{
  width:20px;height:20px;flex:0 0 20px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  display:inline-block;
  position:relative;
}
.faq__icon::before, .faq__icon::after{
  content:"";
  position:absolute;
  top:50%;left:50%;
  width:10px;height:2px;
  background:currentColor;
  transform:translate(-50%,-50%);
}
.faq__icon::after{transform:translate(-50%,-50%) rotate(90deg)}
.faq__item[open] .faq__icon::after{opacity:0}
.faq__content{
  padding:0 20px 18px 20px;
  color:var(--text);
  opacity:.96;
}
.faq__content p{margin:0}
/* hover/focus */
.faq__summary:focus-visible{outline:var(--ring)}
.faq__item:hover{border-color:rgba(139,92,246,.45)}

.button--telegram{
  background: linear-gradient(180deg,#2563eb,#1d4ed8);
  border-color:#1e3a8a;
  box-shadow:0 8px 20px rgba(37,99,235,.18), inset 0 1px 0 rgba(255,255,255,.06);
}
.button--telegram:hover{
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(59,130,246,.35), inset 0 1px 0 rgba(255,255,255,.1);
  filter: saturate(120%);
}

.button--telegram:hover,.button--telegram:focus{filter:brightness(0.95);}
/* --- Align preview with prompt: added by ChatGPT --- */
.panel:last-child .output,
.panel:last-child .preview,
.panel:last-child .result__image,
.panel.panel--result .output,
.panel.panel--result .preview,
.panel.panel--result .result__image {
  margin-top: 28px; /* adjust 20–40px if needed */
  box-sizing: border-box;
}

/* Actions row under the preview output */
.output__actions{
  display:flex;justify-content:space-between;gap:12px;margin-top:12px;
}
.output__actions .button{
  flex:1;
  min-width:0;
  justify-content:center;
}


/* --- Added: make any image inside the preview fit the box without stretching --- */
.output { position: relative; }
.output img, .output__image, .output__media {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain; /* preserve aspect ratio, no cropping */
  display: block;
}
/* Hide placeholder when the real image is present */
.output:has(img), .output:has(.output__image), .output:has(.output__media) {
  border-style: solid; /* optional: solid border once image is there */
}
.output:has(img) .output__placeholder,
.output:has(.output__image) .output__placeholder,
.output:has(.output__media) .output__placeholder {
  display: none;
}


/* Support case where preview uses background-image on .output */
.output[style*="background-image"] {
  background-size: contain !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}



/* Feature cards — glassmorphism gradient with hover glow */
.features{gap:18px}
.features .feature-card{
  position:relative;
  padding:22px 22px 20px;
  border-radius:20px;
  background:
    linear-gradient(180deg, rgba(15,23,42,0.9), rgba(2,6,23,0.9)) padding-box,
    linear-gradient(135deg, rgba(99,102,241,.6), rgba(236,72,153,.5), rgba(45,212,191,.6)) border-box;
  border:1px solid transparent;
  box-shadow: 0 8px 24px rgba(2,6,23,.35), inset 0 1px 0 rgba(255,255,255,.04);
  transition: transform .25s ease, box-shadow .25s ease;
  min-height: 142px;
}
.features .feature-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 40px rgba(2,6,23,.5), inset 0 1px 0 rgba(255,255,255,.06);
}

.features .feature-card h3{
  margin: 4px 0 8px;
  font-size: clamp(16px, 1.6vw, 20px);
  line-height: 1.2;
}
.features .feature-card p{
  color:#cbd5e1;
  font-size: clamp(14px, 1.35vw, 16px);
}

/* Icon pill */
.features .feature-icon{
  width:42px; height:42px;
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:12px;
  margin-bottom:10px;
  color:#e2e8f0;
  background: radial-gradient(120% 120% at 30% 20%, rgba(99,102,241,.75), rgba(59,130,246,.35) 50%, rgba(2,6,23,.0) 70%),
              linear-gradient(180deg, rgba(2,6,23,.35), rgba(2,6,23,.1));
  border:1px solid rgba(148,163,184,.25);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 6px 18px rgba(2,6,23,.45);
}

/* Responsive tuning: keep three -> two -> one columns, already defined in CSS media queries;
   here we only allow cards to stretch nicely */
.features .feature-card{display:flex;flex-direction:column}


/* --- Fix: align grid-2 fields when one label wraps to two lines (e.g., "Соотношение сторон") --- */
.grid-2 .label{
  display:block;
  line-height:1.2;
  min-height:calc(1.2em * 2); /* reserve two lines so selects align horizontally */
}


/* --- Fix: consistent control heights for inputs/selects across mobile browsers --- */
:root { --control-h: 44px; }
.input, .select {
  height: var(--control-h);
  padding-top: 0;
  padding-bottom: 0;
  line-height: 1.2;
}
@supports (-webkit-touch-callout: none) {
  .select { min-height: var(--control-h); }
}


/* Blog article typography (applies to all posts) */
.post .content { line-height: 1.8; }
.post .content h2 { font-size: clamp(20px,2.4vw,28px); font-weight: 800; margin: 18px 0 10px; }
.post .content h3 { font-size: clamp(18px,2vw,22px); font-weight: 700; margin: 14px 0 8px; }
.post .content p { margin: 10px 0; }
.post .content ul, .post .content ol { margin: 10px 0 10px 0; padding-left: 24px; list-style-position: outside; }
.post .content ul { list-style-type: disc; }
.post .content ol { list-style-type: decimal; }
.post .content img { max-width: 100%; height: auto; border-radius: 12px; }


.footer__inner{min-height:56px}

/* === Overlay Loader (25s) === */
.output {
  position: relative;
}
.output .loader-overlay {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,0.78);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  border-radius: 16px;
  z-index: 10;
  transition: opacity .25s ease;
}
.loader-overlay[hidden] { display: none; }
.loader {
  width: clamp(120px, 22vmin, 180px);
  aspect-ratio: 1 / 1;
  position: relative;
  display: grid;
  place-items: center;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji";
}
.loader__ring {
  --p: 0; /* 0..100 */
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background:
    conic-gradient(currentColor calc(var(--p)*1%), rgba(0,0,0,0) 0);
  mask:
    radial-gradient(circle at 50% 50%, transparent 56%, black 57%);
  -webkit-mask:
    radial-gradient(circle at 50% 50%, transparent 56%, black 57%);
}
.loader__bg {
  position: absolute; inset: 10% 10% 10% 10%;
  border-radius: 50%;
  background: white;
  box-shadow: 0 2px 12px rgba(0,0,0,.08) inset;
}
.loader__pct {
  position: relative;
  font-weight: 700;
  font-size: clamp(18px, 4.2vmin, 28px);
  line-height: 1;
  color: #111;
}
.loader__label {
  position: absolute; bottom: -28px; left: 50%; transform: translateX(-50%);
  font-size: 12px; letter-spacing: .08em; text-transform: uppercase;
  color: rgba(0,0,0,.55);
}
/* Accent color ties into existing theme if available */
.output .loader { color: var(--accent, #2f6df6); }


/* === Overlay Loader — refined glass design === */
.output{ position:relative }
.loader-overlay{
  position:absolute; inset:0; display:grid; place-items:center;
  background: rgba(245,247,250,.72);
  -webkit-backdrop-filter: blur(6px) saturate(1.1);
  backdrop-filter: blur(6px) saturate(1.1);
  border-radius: 20px;
  box-shadow: 0 8px 30px rgba(0,0,0,.10) inset, 0 2px 10px rgba(0,0,0,.04);
  z-index: 10;
  transition: opacity .28s ease, transform .28s ease;
}
.loader-overlay[hidden]{ display:none }
.loader-card{
  position:relative;
  padding: 28px 28px 34px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.65), rgba(255,255,255,.40));
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
  border: 1px solid rgba(255,255,255,.6);
  display:grid; gap:18px; justify-items:center;
}
.loader-ring{
  --p:0;
  width: clamp(120px, 20vmin, 200px);
  aspect-ratio: 1/1;
  position: relative;
  display:grid; place-items:center;
  color: var(--accent, #2f6df6);
}
.loader-ring::before{
  content:"";
  position:absolute; inset:0;
  border-radius:50%;
  background:
    conic-gradient(currentColor calc(var(--p)*1%), transparent 0);
  -webkit-mask: radial-gradient(circle at 50% 50%, transparent 60%, black 61%);
          mask: radial-gradient(circle at 50% 50%, transparent 60%, black 61%);
  filter: drop-shadow(0 2px 8px rgba(0,0,0,.10));
}
.loader-track{
  position:absolute; inset:8%;
  border-radius:50%;
  background: radial-gradient(transparent 58%, rgba(0,0,0,.06) 60%);
}
.loader-pct{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
  font-weight: 800;
  font-size: clamp(18px, 4.4vmin, 28px);
  line-height: 1;
  letter-spacing: .02em;
  color: #0f172a;
  text-shadow: 0 1px 0 rgba(255,255,255,.6);
}
.loader-sub{
  margin-top: -2px;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(15,23,42,.62);
}
.loader-tips{
  font-size: 12px;
  color: rgba(15,23,42,.66);
  text-align: center;
  max-width: 360px;
}

/* Logo override: prevent global rounding on logo */
.logo-img{ border-radius:0 !important; }


/* ===== Patch: Beautiful loader overlay design ===== */
.loader-overlay{
  background: 
    radial-gradient(circle at 30% 20%, rgba(139,92,246,.12), transparent 50%),
    radial-gradient(circle at 70% 80%, rgba(99,102,241,.1), transparent 50%),
    radial-gradient(circle at 50% 50%, rgba(6,182,212,.08), transparent 60%),
    repeating-linear-gradient(45deg, transparent, transparent 30px, rgba(139,92,246,.015) 30px, rgba(139,92,246,.015) 60px),
    linear-gradient(135deg, rgba(15,23,42,.95) 0%, rgba(11,18,32,.97) 50%, rgba(15,23,42,.96) 100%) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  z-index: 9999 !important;
  border-radius: 16px !important;
  box-shadow: inset 0 0 60px rgba(139,92,246,.08) !important;
}

.loader-card{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.loader-sub,
.loader-tips{
  display: none !important;
}

.loader-pct{
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  z-index: 1 !important;
  color: #f1f5f9 !important;
  text-shadow: 0 2px 12px rgba(139,92,246,.4), 0 0 40px rgba(139,92,246,.3) !important;
  font-weight: 800 !important;
}

/* Purple ring on dark background */
.loader-ring{
  color: #a78bfa !important;
  filter: drop-shadow(0 0 20px rgba(139,92,246,.4)) !important;
}
.loader-track{
  filter: none !important;
}
/* ===== End patch ===== */



/* Patch 2: remove inner gray circle inside loader */
.loader-track{ display:none !important; }
