:root{
  --bg:#f4f7fb;
  --ink:#06101d;
  --navy:#07111d;
  --navy-2:#0b1a2a;
  --blue:#185fd8;
  --blue-2:#2f80ed;
  --ice:#eaf6ff;
  --muted:#667383;
  --line:rgba(6,16,29,.12);
  --white:#fff;
  --shadow:0 32px 90px rgba(7,17,29,.14);
  --radius:24px;
  --rail:180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;min-width:320px;overflow-x:hidden;background:var(--bg);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;line-height:1.45}
body.menu-open{overflow:hidden}
a{text-decoration:none;color:inherit}button,input,select,textarea{font:inherit}button{cursor:pointer}img{display:block;max-width:100%;height:auto}
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:100%;z-index:250;transform-origin:0 50%;transform:scaleX(0);background:linear-gradient(90deg,var(--blue),#78d8c4)}

.side-rail{position:fixed;inset:0 auto 0 0;width:var(--rail);background:linear-gradient(180deg,#07111d,#02070d);color:#fff;z-index:80;display:grid;grid-template-rows:auto 1fr auto;padding:28px 24px}
.rail-logo img{width:130px}
.side-rail nav{display:grid;align-content:center;gap:14px}
.side-rail nav a{display:flex;align-items:center;gap:10px;min-height:42px;padding:0 8px;border-radius:12px;font-size:14px;font-weight:700;color:rgba(255,255,255,.76);transition:.22s ease}
.side-rail nav a:hover,.side-rail nav a.active{color:#fff;background:rgba(255,255,255,.08)}
.rail-contact{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding-top:28px;border-top:1px solid rgba(255,255,255,.18)}
.rail-contact a{height:42px;display:grid;place-items:center;border-radius:12px;background:rgba(255,255,255,.06);font-size:20px}
.mobile-header,.mobile-menu{display:none}
.site-main{margin-left:var(--rail)}
.kicker{display:inline-block;margin-bottom:18px;color:#8bbdff;font-size:12px;font-weight:900;letter-spacing:.16em;text-transform:uppercase}
.kicker.blue{color:var(--blue)}
h1,h2,h3,p{margin-top:0}
h1{font-size:clamp(46px,7vw,86px);line-height:.92;letter-spacing:-.08em;max-width:12ch;margin-bottom:24px}
h2{font-size:clamp(34px,5vw,64px);line-height:.94;letter-spacing:-.07em;max-width:12ch;margin-bottom:20px}
p{font-size:17px;line-height:1.75;color:var(--muted)}
.btn{min-height:54px;display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:14px;padding:0 20px;font-weight:850;transition:.22s ease}
.btn:hover{transform:translateY(-1px)}
.btn.primary{background:linear-gradient(135deg,var(--blue),var(--blue-2));color:#fff;box-shadow:0 18px 44px rgba(24,95,216,.28)}
.btn.glass{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.22);color:#fff;backdrop-filter:blur(10px)}
.btn.full{width:100%}

.hero{position:relative;min-height:100svh;display:grid;align-items:end;overflow:hidden;background:#07111d;color:#fff}
.hero-slices{position:absolute;inset:0;display:grid;grid-template-columns:1.05fr 1.05fr 1fr 1fr}
.slice{position:relative;overflow:hidden;clip-path:polygon(10% 0,100% 0,90% 100%,0 100%);margin-left:-7%}
.slice:first-child{clip-path:polygon(0 0,100% 0,90% 100%,0 100%);margin-left:0}
.slice img{width:100%;height:100%;object-fit:cover;filter:saturate(.96) contrast(1.05);transform:scale(1.05);animation:slowDrift 18s ease-in-out infinite}
.slice-building img{animation-delay:-3s}.slice-interior img{animation-delay:-6s}.slice-winter img{animation-delay:-9s}
.hero-slices:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(5,13,23,.92),rgba(5,13,23,.44) 48%,rgba(5,13,23,.16)),linear-gradient(180deg,rgba(5,13,23,.08),rgba(5,13,23,.58))}
@keyframes slowDrift{0%,100%{transform:scale(1.05) translateX(0)}50%{transform:scale(1.1) translateX(-12px)}}
.hero-content{position:relative;z-index:1;width:min(900px,calc(100% - 64px));margin:0 auto 16vh}
.hero-content p{max-width:650px;color:rgba(255,255,255,.82);font-size:18px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.hero-counter{position:absolute;z-index:2;right:34px;top:50%;transform:translateY(-50%);display:grid;gap:22px;color:#fff}
.hero-counter span{font-weight:900;letter-spacing:.14em;font-size:13px;opacity:.76}

.qualities-section{position:relative;z-index:5;margin:-64px 0 70px;padding:0 40px}
.quality-panel{width:min(920px,calc(100% - 80px));margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);background:rgba(255,255,255,.92);border:1px solid rgba(255,255,255,.9);border-radius:20px;box-shadow:var(--shadow);overflow:hidden}
.quality{min-height:150px;padding:28px 24px;text-align:center;border-right:1px solid var(--line)}
.quality:last-child{border-right:0}
.quality-icon{width:38px;height:38px;margin:0 auto 18px;color:var(--blue)}
.quality-icon svg{width:100%;height:100%}
.quality h3{font-size:15px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}
.quality p{font-size:14px;line-height:1.55;margin:0;color:#333e4a}

.section{padding:90px 48px}
.intro-split{display:grid;grid-template-columns:.85fr 1.15fr;gap:36px;align-items:end}
.section-lead{max-width:700px}
.services-grid{grid-column:1/-1;display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:38px}
.service-card{position:relative;min-height:210px;overflow:hidden;border-radius:18px;background:#111;color:#fff;box-shadow:0 18px 50px rgba(7,17,29,.13)}
.service-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.62) saturate(.92);transform:scale(1.04);transition:.35s ease}
.service-card:hover img{transform:scale(1.1)}
.service-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(4,9,15,.06),rgba(4,9,15,.84))}
.service-body{position:absolute;inset:auto 0 0;z-index:1;padding:18px}
.service-icon{width:46px;height:46px;display:grid;place-items:center;border-radius:14px;background:var(--blue);margin-bottom:36px}
.service-icon svg{width:22px;height:22px}
.service-card h3{font-size:18px;margin-bottom:6px}
.service-card p{color:rgba(255,255,255,.78);font-size:13px;line-height:1.55;margin:0}
.service-card strong{position:absolute;right:18px;bottom:16px;z-index:2;color:#fff}

.journey{padding:96px 48px;background:linear-gradient(180deg,#f5f8fc,#e9f1f7)}
.journey-head{display:grid;grid-template-columns:.75fr 1fr;gap:30px;align-items:end;margin-bottom:34px}
.journey-head p{max-width:620px}
.journey-stack{display:grid;gap:22px}
.journey-card{position:relative;display:grid;grid-template-columns:1fr 1fr;min-height:560px;overflow:hidden;border-radius:30px;background:#fff;box-shadow:var(--shadow)}
.journey-card:nth-child(even){grid-template-columns:1fr 1fr}
.journey-card:nth-child(even) .journey-media{order:2}
.journey-media{position:relative;overflow:hidden}
.journey-media img{width:100%;height:100%;object-fit:cover;transform:scale(1.04)}
.journey-media:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(0,0,0,.2))}
.journey-content{padding:48px;display:flex;flex-direction:column;justify-content:center}
.journey-label{color:var(--blue);font-weight:900;letter-spacing:.14em;text-transform:uppercase;font-size:12px}
.journey-content h3{font-size:clamp(30px,4vw,54px);line-height:.96;letter-spacing:-.06em;margin:18px 0}
.journey-points{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.journey-points span{padding:9px 11px;border-radius:999px;background:#edf3f8;font-size:13px;font-weight:800;color:#314252}
.journey-card.winter{background:#07111d;color:#fff}
.journey-card.winter p{color:rgba(255,255,255,.72)}
.journey-card.winter .journey-points span{background:rgba(255,255,255,.1);color:#fff}

.process-section{background:#fff}
.process-section .section-head{display:grid;grid-template-columns:.8fr 1.2fr;gap:28px;align-items:end;margin-bottom:32px}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.process-card{padding:28px 22px;border:1px solid var(--line);border-radius:18px;background:#f7faff;min-height:260px}
.process-card span{display:block;color:var(--blue);font-size:12px;font-weight:900;letter-spacing:.14em;margin-bottom:70px}
.process-card h3{font-size:24px;letter-spacing:-.04em}
.process-card p{font-size:14px;margin:0}

.contact-section{position:relative;overflow:hidden;color:#fff}
.contact-bg{position:absolute;inset:0}
.contact-bg img{width:100%;height:100%;object-fit:cover;filter:brightness(.42)}
.contact-bg:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#06101d,rgba(6,16,29,.78) 50%,rgba(6,16,29,.42))}
.contact-wrap{position:relative;z-index:1;display:grid;grid-template-columns:.9fr 1.1fr;gap:36px;padding:110px 48px}
.contact-copy h2{color:#fff}.contact-copy p{color:rgba(255,255,255,.75)}
.contact-lines{display:grid;gap:1px;background:rgba(255,255,255,.14);margin:28px 0}
.contact-lines a{display:flex;justify-content:space-between;gap:18px;padding:18px;background:rgba(255,255,255,.08)}
.contact-lines small{color:rgba(255,255,255,.58);font-weight:850}.contact-lines strong{text-align:right}
.muted{font-size:14px!important;color:rgba(255,255,255,.62)!important;margin:8px 0}
.contact-form{display:grid;gap:13px;padding:24px;background:rgba(255,255,255,.94);border-radius:20px;color:var(--ink);box-shadow:var(--shadow)}
label{display:grid;gap:8px;font-weight:850;color:#2c3a48}
input,select,textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:14px;background:#fff;outline:0}
input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(24,95,216,.12)}
.form-note,.form-status{font-size:13px;margin:0}.form-note{color:var(--muted)}.form-status{color:var(--blue);font-weight:800}

.footer{margin-left:var(--rail);display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:30px;padding:30px 48px;background:#02070d;color:#fff}
.footer img{width:260px;margin-bottom:12px}.footer p{font-size:13px;color:rgba(255,255,255,.55);margin:0}
.footer nav,.legal-links{display:grid;gap:8px;align-content:start}
.footer a,.footer button{color:#fff;background:none;border:0;padding:0;text-align:left;font-weight:750}
.modal{border:0;border-radius:20px;width:min(720px,calc(100% - 28px));padding:28px}.modal::backdrop{background:rgba(0,0,0,.62);backdrop-filter:blur(6px)}.modal-close{position:absolute;right:10px;top:10px;border:0;background:#07111d;color:#fff;width:40px;height:40px;border-radius:12px;font-size:24px}
.reveal{opacity:0;transform:translateY(20px);transition:.75s ease}.reveal.show{opacity:1;transform:none}

@media(max-width:1100px){
  :root{--rail:0px}
  .side-rail{display:none}
  .site-main,.footer{margin-left:0}
  .mobile-header{position:sticky;top:0;z-index:80;height:70px;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:rgba(255,255,255,.92);backdrop-filter:blur(18px);box-shadow:0 6px 22px rgba(7,17,29,.06)}
  .mobile-logo img{height:50px;width:auto}
  .menu-btn{width:46px;height:46px;border:1px solid var(--line);border-radius:14px;background:#fff}.menu-btn span{display:block;width:20px;height:2px;background:var(--ink);margin:5px auto}
  .mobile-menu{position:fixed;left:12px;right:12px;top:80px;z-index:85;display:none;padding:14px;border-radius:20px;background:#fff;box-shadow:var(--shadow)}
  .mobile-menu.open{display:grid;gap:12px}
  .mobile-menu nav{display:grid;gap:8px}
  .mobile-menu nav a{padding:14px;border-radius:14px;background:#f4f7fb;font-weight:800}
  .hero{min-height:auto;padding-top:0}
  .hero-slices{position:relative;inset:auto;height:58svh;min-height:460px}
  .hero-content{margin:-170px auto 70px}
  .qualities-section{margin:-40px 0 44px}
  .quality-panel{grid-template-columns:1fr 1fr;width:calc(100% - 24px)}
  .services-grid{grid-template-columns:1fr 1fr}
  .journey-card,.journey-card:nth-child(even){grid-template-columns:1fr}
  .journey-card:nth-child(even) .journey-media{order:0}
  .journey-media{min-height:380px}
  .process-grid{grid-template-columns:1fr 1fr}
  .contact-wrap{grid-template-columns:1fr}
  .footer{grid-template-columns:1fr 1fr}
}
@media(max-width:700px){
  .hero-slices{display:block;height:420px}
  .slice{position:absolute;inset:0;clip-path:none;margin:0;opacity:0;animation:mobileHero 18s infinite}
  .slice-garden{opacity:1}.slice-building{animation-delay:4.5s}.slice-interior{animation-delay:9s}.slice-winter{animation-delay:13.5s}
  @keyframes mobileHero{0%,20%{opacity:1}25%,100%{opacity:0}}
  .hero-content{width:calc(100% - 24px);margin:-120px auto 52px}
  h1{font-size:clamp(38px,12vw,56px);max-width:12ch}h2{font-size:clamp(32px,10vw,46px)}
  .hero-actions{display:grid}.btn{width:100%}.hero-counter{display:none}
  .quality-panel,.services-grid,.process-grid,.footer{grid-template-columns:1fr}
  .quality{border-right:0;border-bottom:1px solid var(--line)}.quality:last-child{border-bottom:0}
  .section,.journey{padding:64px 12px}
  .intro-split,.journey-head,.process-section .section-head{grid-template-columns:1fr}
  .service-card{min-height:250px}
  .journey-card{min-height:auto;border-radius:22px}.journey-media{min-height:300px}.journey-content{padding:24px}
  .contact-wrap{padding:72px 12px}.contact-lines a{display:grid}.contact-lines strong{text-align:left}
  .footer{padding:26px 12px}.footer img{width:220px}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}.slice img,.reveal{animation:none;transition:none}.reveal{opacity:1;transform:none}
}
.admin-body{background:#f4f7fb;color:var(--ink)}
.admin-login{position:fixed;inset:0;display:grid;place-items:center;background:#07111d;padding:18px;z-index:200}
.admin-login-box{width:min(460px,100%);background:#fff;border-radius:22px;padding:26px;box-shadow:var(--shadow)}
.admin-login-box img{width:260px;margin-bottom:20px}
.admin-login-box h1{font-size:48px;line-height:.95;letter-spacing:-.06em;color:var(--ink)}
.admin-layout{display:grid;grid-template-columns:280px 1fr;min-height:100vh}
.admin-side{background:#07111d;color:#fff;padding:24px;position:sticky;top:0;height:100vh}
.admin-side img{width:220px;margin-bottom:20px}
.admin-side p{color:rgba(255,255,255,.65)}
.admin-side nav{display:grid;gap:8px;margin-top:24px}
.admin-side button{min-height:46px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:#fff;border-radius:14px;text-align:left;padding:0 14px;font-weight:800}
.admin-side button.active{background:#fff;color:#07111d}
.admin-main{padding:28px}
.admin-main h1{font-size:54px;letter-spacing:-.07em;line-height:.96;color:var(--ink)}
.admin-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:22px;margin-bottom:16px}
.admin-card h2{font-size:30px;letter-spacing:-.04em}
.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.admin-section{display:none}
.admin-section.active{display:block}
.admin-light{background:#fff!important;color:#07111d!important;border-color:var(--line)!important;margin-left:8px}
.json-editor{width:100%;min-height:560px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;border:1px solid var(--line);border-radius:18px;padding:16px}
.preview-frame{width:100%;height:720px;border:1px solid var(--line);border-radius:18px;background:#fff}
@media(max-width:900px){
  .admin-layout{grid-template-columns:1fr}
  .admin-side{position:relative;height:auto}
  .admin-grid{grid-template-columns:1fr}
  .admin-main{padding:14px}
}

/* Refined update: no background dots, new transparent PNG logo, refreshed image treatment */
.rail-logo{display:block;padding:12px;border-radius:18px;background:rgba(255,255,255,.96);box-shadow:0 12px 28px rgba(0,0,0,.08)}
.rail-logo img{display:block;width:100%;height:auto}
.mobile-logo img{height:42px;width:auto}
.footer img{width:240px;padding:10px;border-radius:16px;background:rgba(255,255,255,.96);box-shadow:0 10px 24px rgba(0,0,0,.08)}
.admin-login-box img{width:260px;max-width:100%;height:auto}
.admin-side img{width:220px;max-width:100%;height:auto;padding:10px;border-radius:16px;background:rgba(255,255,255,.96)}
@media(max-width:1100px){
  .mobile-logo{display:block}
}


/* Desktop Logo Fix – stronger placement, larger brand presence */
@media (min-width:1101px){
  :root{
    --rail:250px;
  }

  .side-rail{
    padding:26px 22px;
  }

  .rail-logo{
    display:flex;
    align-items:center;
    justify-content:center;
    padding:18px 16px;
    min-height:142px;
    border-radius:24px;
    background:rgba(255,255,255,.98);
    box-shadow:0 18px 46px rgba(0,0,0,.16);
  }

  .rail-logo img{
    width:210px !important;
    max-width:100%;
    height:auto;
    object-fit:contain;
  }

  .side-rail nav{
    gap:10px;
    padding-top:22px;
  }

  .side-rail nav a{
    min-height:48px;
    padding:0 14px;
    font-size:15px;
  }

  .rail-contact a{
    height:48px;
  }

  .hero-content{
    width:min(980px,calc(100% - 72px));
    margin-left:clamp(48px,6vw,96px);
    margin-right:auto;
  }

  .desktop-hero-logo{
    width:min(430px,100%);
    margin:0 0 30px 0;
    padding:16px 20px;
    border-radius:24px;
    background:rgba(255,255,255,.96);
    box-shadow:0 22px 60px rgba(0,0,0,.20);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
  }

  .desktop-hero-logo img{
    width:100%;
    height:auto;
    object-fit:contain;
  }
}

@media (max-width:1100px){
  .desktop-hero-logo{
    display:none;
  }
}


/* Transparent Logo Final Fix */
@media (min-width:1101px){
  .brand-card,
  .rail-logo{
    background:transparent !important;
    box-shadow:none !important;
    border:0 !important;
    padding:0 !important;
    min-height:auto !important;
    border-radius:0 !important;
    display:flex !important;
    justify-content:center !important;
    align-items:center !important;
  }

  .brand-card img,
  .rail-logo img{
    width:210px !important;
    max-width:100% !important;
    height:auto !important;
    object-fit:contain !important;
    display:block !important;
  }

  .brand-card span{
    display:none !important;
  }

  .desktop-hero-logo{
    background:transparent !important;
    box-shadow:none !important;
    padding:0 !important;
    border-radius:0 !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
    width:min(440px,100%) !important;
    margin-bottom:34px !important;
  }

  .desktop-hero-logo img{
    width:100% !important;
    height:auto !important;
    object-fit:contain !important;
    display:block !important;
    filter:drop-shadow(0 18px 26px rgba(0,0,0,.35));
  }

  .footer img,
  .footer-brand img{
    background:transparent !important;
    padding:0 !important;
    box-shadow:none !important;
    border-radius:0 !important;
  }
}

.mobile-brand img,
.mobile-logo img{
  background:transparent !important;
  box-shadow:none !important;
  border:0 !important;
  padding:0 !important;
}

.admin-login-box img,
.admin-side img{
  background:transparent !important;
  box-shadow:none !important;
  padding:0 !important;
}


/* Final contrast-safe transparent logo system */
@media (min-width:1101px){
  .rail-logo,
  .brand-card{
    background:transparent !important;
    box-shadow:none !important;
    border:0 !important;
    padding:0 !important;
    min-height:auto !important;
    border-radius:0 !important;
    display:flex !important;
    justify-content:center !important;
    align-items:center !important;
  }

  .rail-logo img,
  .brand-card img{
    width:218px !important;
    max-width:100% !important;
    height:auto !important;
    object-fit:contain !important;
    display:block !important;
    filter:drop-shadow(0 14px 18px rgba(0,0,0,.38));
  }

  .brand-card span{
    display:none !important;
  }

  .desktop-hero-logo{
    background:transparent !important;
    box-shadow:none !important;
    border:0 !important;
    padding:0 !important;
    border-radius:0 !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
    width:min(450px,100%) !important;
    margin:0 0 34px 0 !important;
  }

  .desktop-hero-logo img{
    width:100% !important;
    height:auto !important;
    object-fit:contain !important;
    display:block !important;
    filter:drop-shadow(0 18px 28px rgba(0,0,0,.48));
  }

  .footer img,
  .footer-brand img,
  .site-footer img{
    background:transparent !important;
    box-shadow:none !important;
    border:0 !important;
    padding:0 !important;
    filter:drop-shadow(0 12px 22px rgba(0,0,0,.38));
  }
}

/* Mobile: logo must be readable, bigger, and no white footer/logo boxes */
@media (max-width:1100px){
  .mobile-header{
    background:rgba(247,249,252,.96) !important;
  }

  .mobile-logo{
    width:min(255px, calc(100vw - 86px)) !important;
    display:flex !important;
    align-items:center !important;
  }

  .mobile-logo img{
    width:100% !important;
    max-height:50px !important;
    height:auto !important;
    object-fit:contain !important;
    background:transparent !important;
    box-shadow:none !important;
    border:0 !important;
    padding:0 !important;
  }

  .mobile-brand{
    width:min(255px, calc(100vw - 86px)) !important;
    min-width:0 !important;
  }

  .mobile-brand img{
    width:100% !important;
    max-height:50px !important;
    height:auto !important;
    object-fit:contain !important;
    background:transparent !important;
    box-shadow:none !important;
    border:0 !important;
    padding:0 !important;
  }

  .mobile-brand span{
    display:none !important;
  }

  .footer,
  .site-footer{
    background:#09111f !important;
    color:#fff !important;
  }

  .footer img,
  .footer-brand img,
  .site-footer img{
    background:transparent !important;
    box-shadow:none !important;
    border:0 !important;
    padding:0 !important;
    width:min(280px, 100%) !important;
    filter:drop-shadow(0 12px 22px rgba(0,0,0,.38));
  }
}

.admin-login-box img,
.admin-side img{
  background:transparent !important;
  box-shadow:none !important;
  border:0 !important;
  padding:0 !important;
}


/* Admin login reliability fix */
.admin-layout[hidden]{
  display:none;
}

body.admin-unlocked .admin-layout{
  display:grid !important;
}

body.admin-unlocked .admin-login{
  display:none !important;
}


/* Professional PHP Admin Editor */
.admin-pro-body{
  background:#eef3f8;
  color:#0d1623;
}

.admin-pro-layout{
  display:grid;
  grid-template-columns:290px 1fr;
  min-height:100vh;
}

.admin-pro-sidebar{
  position:sticky;
  top:0;
  height:100vh;
  overflow:auto;
  padding:24px;
  background:#09111f;
  color:#fff;
}

.admin-pro-sidebar img{
  width:220px;
  max-width:100%;
  margin-bottom:18px;
}

.admin-pro-sidebar p{
  color:rgba(255,255,255,.68);
  font-size:.94rem;
}

.admin-pro-sidebar nav{
  display:grid;
  gap:8px;
  margin:22px 0;
}

.admin-pro-sidebar nav a,
.admin-preview-link{
  min-height:44px;
  display:flex;
  align-items:center;
  padding:0 14px;
  border-radius:14px;
  background:rgba(255,255,255,.07);
  color:#fff;
  font-weight:800;
}

.admin-pro-main{
  padding:24px;
}

.admin-pro-topbar{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  margin-bottom:18px;
}

.admin-pro-topbar h1{
  color:#0d1623;
  max-width:none;
  margin-bottom:8px;
}

.admin-pro-card{
  background:#fff;
  border:1px solid rgba(13,22,35,.08);
  border-radius:24px;
  box-shadow:0 20px 60px rgba(9,17,31,.08);
  padding:24px;
  margin-bottom:18px;
}

.admin-pro-card h2{
  font-size:clamp(1.6rem,3vw,2.5rem);
  color:#0d1623;
  max-width:none;
}

.admin-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.admin-grid .wide{
  grid-column:1/-1;
}

.admin-pro-card label{
  color:#243246;
  font-weight:800;
}

.admin-pro-card input,
.admin-pro-card select,
.admin-pro-card textarea{
  width:100%;
  min-height:48px;
  margin-top:8px;
  border:1px solid rgba(13,22,35,.12);
  border-radius:14px;
  padding:13px 14px;
  background:#fff;
  color:#0d1623;
}

.admin-pro-card textarea{
  min-height:120px;
  resize:vertical;
}

.admin-note{
  background:#f4f7fb;
  border:1px solid rgba(13,22,35,.08);
  border-radius:16px;
  padding:14px;
  color:#526174;
}

.admin-feature-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
}

.admin-feature-grid article,
.repeat-editor-card,
.service-admin-card,
.image-editor-card{
  background:#f7f9fc;
  border:1px solid rgba(13,22,35,.08);
  border-radius:20px;
  padding:16px;
}

.admin-feature-grid strong{
  display:block;
  margin-bottom:8px;
}

.admin-feature-grid span{
  color:#66758a;
  font-size:.94rem;
}

.service-admin-card{
  display:grid;
  grid-template-columns:260px 1fr;
  gap:18px;
  margin-bottom:14px;
}

.service-admin-preview,
.image-preview{
  min-height:180px;
  border-radius:18px;
  background:#e8eef5;
  overflow:hidden;
  display:grid;
  place-items:center;
}

.service-admin-preview img,
.image-preview img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.image-editor-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}

.image-editor-copy{
  display:grid;
  gap:10px;
  margin-top:12px;
}

.button.small{
  min-height:42px;
  border-radius:12px;
  font-size:.88rem;
}

.checkline{
  display:flex !important;
  align-items:center;
  gap:10px;
  margin-top:8px;
}

.checkline input{
  width:auto !important;
  min-height:auto !important;
  margin:0 !important;
}

.admin-save-status{
  padding:14px 16px;
  border-radius:16px;
  background:#e8fff2;
  color:#0d6b39;
  font-weight:900;
  margin-bottom:18px;
}

.admin-save-status.visible{
  display:block;
}

.sticky-save{
  position:sticky;
  bottom:14px;
  z-index:10;
  box-shadow:0 18px 48px rgba(47,128,237,.28);
}

@media(max-width:1100px){
  .admin-pro-layout{
    grid-template-columns:1fr;
  }
  .admin-pro-sidebar{
    position:relative;
    height:auto;
  }
  .admin-grid,
  .image-editor-grid,
  .admin-feature-grid,
  .service-admin-card{
    grid-template-columns:1fr;
  }
  .admin-pro-topbar{
    display:grid;
  }
}


/* Privacy + SMTP additions */
.privacy-text{white-space:pre-line;color:#667383;line-height:1.75;font-size:15px;max-height:70vh;overflow:auto;padding-right:6px}.privacy-check{display:flex!important;grid-template-columns:auto 1fr;align-items:flex-start;gap:10px;font-weight:700}.privacy-check input{width:auto!important;margin-top:5px}.hp-field{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;overflow:hidden!important}.contact-form button[disabled]{opacity:.65;cursor:not-allowed}.admin-pro-card code{background:#edf3f8;padding:2px 6px;border-radius:6px}.admin-pro-sidebar nav a{margin-bottom:8px}


/* Cookie Consent */
.cookie-consent{
  position:fixed;
  inset:0;
  z-index:9999;
  display:grid;
  align-items:end;
  justify-items:center;
  padding:18px;
  background:rgba(5,10,18,.45);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}

.cookie-consent[hidden]{
  display:none !important;
}

.cookie-card{
  width:min(920px,100%);
  border-radius:28px;
  background:rgba(255,255,255,.98);
  color:#0d1623;
  box-shadow:0 30px 100px rgba(0,0,0,.28);
  border:1px solid rgba(255,255,255,.86);
  padding:24px;
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:22px;
}

.cookie-copy h2{
  font-size:clamp(1.8rem,3vw,2.7rem);
  line-height:1;
  letter-spacing:-.05em;
  color:#0d1623;
  margin:0 0 12px;
}

.cookie-copy p{
  color:#556274;
  margin-bottom:0;
}

.cookie-eyebrow{
  display:inline-block;
  font-size:.76rem;
  font-weight:900;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:#2f80ed;
  margin-bottom:10px;
}

.cookie-options{
  display:grid;
  gap:10px;
}

.cookie-option{
  display:flex !important;
  align-items:flex-start;
  gap:12px;
  padding:14px;
  border-radius:18px;
  background:#f4f7fb;
  border:1px solid rgba(13,22,35,.08);
  cursor:pointer;
  color:#0d1623;
}

.cookie-option input{
  width:20px !important;
  height:20px !important;
  min-height:auto !important;
  margin:2px 0 0 !important;
  accent-color:#2f80ed;
}

.cookie-option strong{
  display:block;
  margin-bottom:4px;
}

.cookie-option small{
  display:block;
  color:#66758a;
  line-height:1.5;
}

.cookie-option.required{
  opacity:.88;
}

.cookie-actions{
  grid-column:1/-1;
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:10px;
}

.cookie-btn{
  min-height:46px;
  padding:0 16px;
  border-radius:14px;
  border:1px solid rgba(13,22,35,.12);
  font-weight:850;
  cursor:pointer;
}

.cookie-btn.primary{
  background:linear-gradient(135deg,#2f80ed,#4f97ff);
  color:#fff;
  border-color:transparent;
}

.cookie-btn.soft{
  background:#eef4fb;
  color:#0d1623;
}

.cookie-btn.ghost{
  background:#fff;
  color:#0d1623;
}

@media(max-width:760px){
  .cookie-consent{
    align-items:end;
    padding:10px;
  }

  .cookie-card{
    grid-template-columns:1fr;
    border-radius:24px;
    padding:18px;
    max-height:calc(100vh - 20px);
    overflow:auto;
  }

  .cookie-actions{
    display:grid;
    grid-template-columns:1fr;
  }

  .cookie-btn{
    width:100%;
  }
}


/* Cookie banner compact professional fix */
.cookie-card{
  max-width:820px !important;
}

.cookie-copy h2{
  margin-bottom:8px !important;
}

.cookie-copy p{
  font-size:.95rem !important;
  line-height:1.55 !important;
}

.cookie-options{
  gap:8px !important;
}

.cookie-option{
  padding:12px !important;
  border-radius:16px !important;
}

.cookie-option small{
  font-size:.82rem !important;
  line-height:1.35 !important;
}

.cookie-actions{
  gap:8px !important;
}

.cookie-btn{
  min-height:42px !important;
  padding:0 14px !important;
}

@media(max-width:760px){
  .cookie-consent{
    padding:8px !important;
    align-items:end !important;
  }

  .cookie-card{
    width:100% !important;
    max-height:78vh !important;
    overflow:auto !important;
    border-radius:20px !important;
    padding:14px !important;
    gap:12px !important;
  }

  .cookie-copy h2{
    font-size:1.45rem !important;
    letter-spacing:-.03em !important;
    margin-bottom:6px !important;
  }

  .cookie-eyebrow{
    font-size:.68rem !important;
    margin-bottom:6px !important;
  }

  .cookie-copy p{
    font-size:.86rem !important;
    line-height:1.45 !important;
  }

  .cookie-option{
    padding:10px !important;
    gap:9px !important;
    border-radius:14px !important;
  }

  .cookie-option input{
    width:18px !important;
    height:18px !important;
  }

  .cookie-option strong{
    font-size:.92rem !important;
    margin-bottom:2px !important;
  }

  .cookie-option small{
    font-size:.76rem !important;
    line-height:1.28 !important;
  }

  .cookie-actions{
    grid-template-columns:1fr !important;
    gap:7px !important;
  }

  .cookie-btn{
    min-height:40px !important;
    font-size:.9rem !important;
    border-radius:12px !important;
  }
}


/* Contact form select readability + real WhatsApp sidebar icon */
.contact-form select,
.contact-form select:focus,
.contact-form select:active{
  color:#06101d !important;
  background:#ffffff !important;
  -webkit-text-fill-color:#06101d !important;
  opacity:1 !important;
  appearance:auto !important;
  -webkit-appearance:menulist !important;
}

.contact-form select option,
.contact-form select optgroup{
  color:#06101d !important;
  background:#ffffff !important;
}

.contact-form input,
.contact-form textarea{
  color:#06101d !important;
  background:#ffffff !important;
  -webkit-text-fill-color:#06101d !important;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder{
  color:#7a8797 !important;
  -webkit-text-fill-color:#7a8797 !important;
}

.rail-contact a.whatsapp-rail{
  color:#25D366 !important;
}

.rail-contact a.whatsapp-rail:hover{
  background:rgba(37,211,102,.14) !important;
  color:#25D366 !important;
}

.whatsapp-icon{
  width:24px;
  height:24px;
  display:block;
}

@media(max-width:760px){
  .contact-form select{
    min-height:52px !important;
    font-size:16px !important;
    color:#06101d !important;
    background:#ffffff !important;
  }

  .contact-form select option{
    color:#06101d !important;
    background:#ffffff !important;
  }
}


/* Professional message modal + admin inbox */
.email-modal{
  width:min(960px,calc(100vw - 24px));
  border:0;
  border-radius:30px;
  padding:0;
  background:transparent;
  color:#0d1623;
}
.email-modal::backdrop{
  background:rgba(5,10,18,.62);
  backdrop-filter:blur(10px);
}
.email-modal-grid{
  position:relative;
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:0;
  overflow:hidden;
  border-radius:30px;
  background:#fff;
  box-shadow:0 34px 120px rgba(0,0,0,.35);
}
.email-modal-intro{
  padding:34px;
  background:linear-gradient(145deg,#09111f,#13233a);
  color:#fff;
}
.email-modal-intro h2{
  color:#fff;
  font-size:clamp(2rem,4vw,3.4rem);
  line-height:.95;
  margin:0 0 14px;
}
.email-modal-intro p{
  color:rgba(255,255,255,.74);
}
.email-modal-info{
  display:grid;
  gap:8px;
  margin-top:26px;
  padding:18px;
  border-radius:20px;
  background:rgba(255,255,255,.08);
}
.email-modal-info strong{font-size:1.05rem}
.email-modal-info span{color:rgba(255,255,255,.78)}
.email-modal-form{
  padding:34px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.email-modal-form label{
  color:#27344a;
  font-weight:850;
}
.email-modal-form label span{font-weight:650;color:#6e7b8e}
.email-modal-form .wide{grid-column:1/-1}
.email-modal-form input,
.email-modal-form textarea{
  width:100%;
  margin-top:8px;
  border:1px solid rgba(13,22,35,.12);
  border-radius:16px;
  background:#f8fafc;
  color:#071421;
  -webkit-text-fill-color:#071421;
  padding:14px;
  min-height:50px;
}
.email-modal-form textarea{resize:vertical;min-height:150px}
.email-modal-form input::placeholder,
.email-modal-form textarea::placeholder{color:#7b8796;-webkit-text-fill-color:#7b8796}
.email-modal-form .privacy-check{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:.9rem;
  line-height:1.45;
}
.email-modal-form .privacy-check input{
  width:18px;
  min-height:18px;
  margin:2px 0 0;
  padding:0;
}
.email-close{
  position:absolute;
  top:14px;
  right:14px;
  z-index:2;
  width:42px;
  height:42px;
  border-radius:999px;
  background:rgba(255,255,255,.9);
  color:#071421;
  border:0;
  font-size:24px;
  cursor:pointer;
}
.message-list{display:grid;gap:14px}
.message-card{
  border:1px solid rgba(13,22,35,.08);
  background:#f8fafc;
  border-radius:22px;
  padding:18px;
}
.message-card.is-new{
  background:#eef6ff;
  border-color:rgba(47,128,237,.25);
  box-shadow:inset 4px 0 0 #2f80ed;
}
.message-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start}
.message-head h3{margin:8px 0 4px;color:#0d1623;font-size:1.25rem}
.message-head p{margin:0;color:#657387;font-size:.9rem}
.message-badge,
.message-status{
  display:inline-flex;
  min-height:28px;
  align-items:center;
  padding:0 10px;
  border-radius:999px;
  font-size:.78rem;
  font-weight:900;
  background:#e8eef5;
  color:#1b2a3e;
  margin-right:6px;
}
.message-status.sent{background:#e8fff2;color:#0b6b39}
.message-status.failed{background:#fff0f0;color:#9d1f1f}
.message-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.button.danger{color:#9d1f1f!important;background:#fff0f0!important}
.message-meta{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:8px 16px;
  margin:16px 0;
  color:#334259;
}
.message-meta span{background:#fff;border-radius:12px;padding:10px}
.message-body{
  white-space:pre-wrap;
  line-height:1.65;
  background:#fff;
  border-radius:16px;
  padding:16px;
  color:#1a2638;
}
.message-error{
  margin-top:12px;
  padding:12px;
  border-radius:14px;
  background:#fff0f0;
  color:#9d1f1f;
}
@media(max-width:760px){
  .email-modal{width:calc(100vw - 16px);max-height:calc(100vh - 16px)}
  .email-modal-grid{grid-template-columns:1fr;max-height:calc(100vh - 16px);overflow:auto;border-radius:24px}
  .email-modal-intro{padding:22px}
  .email-modal-intro h2{font-size:2rem}
  .email-modal-form{padding:20px;grid-template-columns:1fr;gap:12px}
  .email-modal-form .wide{grid-column:auto}
  .message-head{display:grid}
  .message-actions{justify-content:flex-start}
  .message-meta{grid-template-columns:1fr}
}


/* Pro modules, message center and better forms */
[data-feature][hidden]{
  display:none !important;
}

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

.form-row.two{
  grid-template-columns:repeat(2,minmax(0,1fr));
}

.form-row.three{
  grid-template-columns:repeat(3,minmax(0,1fr));
}

.form-step{
  padding:18px;
  border-radius:22px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(13,22,35,.08);
  display:grid;
  gap:14px;
}

.form-step h3{
  margin:0;
  color:#0d1623;
}

.quote-section,
.gallery-section,
.testimonials-section,
.area-section,
.faq-section{
  padding:clamp(72px,9vw,130px) clamp(20px,6vw,90px);
  margin-left:var(--rail);
}

.quote-form{
  width:min(980px,100%);
  margin:32px auto 0;
  display:grid;
  gap:16px;
  padding:clamp(18px,3vw,32px);
  border-radius:30px;
  background:linear-gradient(135deg,rgba(255,255,255,.94),rgba(245,249,253,.88));
  box-shadow:0 28px 90px rgba(9,17,31,.12);
  border:1px solid rgba(13,22,35,.08);
}

.quote-form label,
.pro-contact-form label,
.email-dialog-form label{
  color:#132033;
  font-weight:850;
}

.quote-form input,
.quote-form select,
.quote-form textarea,
.pro-contact-form input,
.pro-contact-form select,
.pro-contact-form textarea,
.email-dialog-form input,
.email-dialog-form select,
.email-dialog-form textarea{
  color:#06101d !important;
  background:#fff !important;
  -webkit-text-fill-color:#06101d !important;
  border:1px solid rgba(13,22,35,.13);
  border-radius:16px;
}

.gallery-grid,
.testimonial-grid{
  width:min(1120px,100%);
  margin:34px auto 0;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}

.gallery-card,
.testimonial-card{
  border-radius:26px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 22px 70px rgba(9,17,31,.10);
  border:1px solid rgba(13,22,35,.08);
}

.gallery-card img{
  width:100%;
  height:240px;
  object-fit:cover;
  display:block;
}

.gallery-card div,
.testimonial-card{
  padding:20px;
}

.gallery-card h3,
.testimonial-card strong{
  display:block;
  color:#0d1623;
  margin-bottom:8px;
}

.gallery-card p,
.testimonial-card p,
.testimonial-card span{
  color:#5f6c7f;
}

.stars{
  color:#e1a900;
  letter-spacing:.08em;
  margin-bottom:12px;
}

.area-card{
  width:min(1120px,100%);
  margin:auto;
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:28px;
  align-items:center;
  padding:clamp(24px,4vw,48px);
  border-radius:34px;
  background:#09111f;
  color:#fff;
  box-shadow:0 30px 100px rgba(9,17,31,.22);
}

.area-card h2,
.area-card p{
  color:#fff;
}

.area-map{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.area-map span{
  padding:13px 16px;
  border-radius:999px;
  background:rgba(255,255,255,.1);
  color:#fff;
  font-weight:850;
}

.faq-list{
  width:min(980px,100%);
  margin:28px auto 0;
  display:grid;
  gap:12px;
}

.faq-item{
  background:#fff;
  border:1px solid rgba(13,22,35,.08);
  border-radius:20px;
  padding:18px 20px;
  box-shadow:0 16px 48px rgba(9,17,31,.08);
}

.faq-item summary{
  cursor:pointer;
  font-weight:900;
  color:#0d1623;
}

.faq-item p{
  color:#5f6c7f;
  margin:12px 0 0;
}

.email-dialog{
  width:min(760px,calc(100% - 24px));
  border:0;
  border-radius:30px;
  padding:0;
  box-shadow:0 40px 140px rgba(0,0,0,.35);
}

.email-dialog::backdrop{
  background:rgba(5,10,18,.58);
  backdrop-filter:blur(8px);
}

.email-dialog-form{
  padding:clamp(22px,4vw,36px);
  display:grid;
  gap:16px;
  background:#fff;
}

.email-dialog-form h2{
  color:#0d1623;
  margin:0;
  max-width:none;
}

.toggle-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}

.toggle-line{
  display:flex !important;
  align-items:center;
  gap:12px;
  padding:14px;
  border-radius:16px;
  background:#f4f7fb;
  border:1px solid rgba(13,22,35,.08);
  font-weight:900;
}

.toggle-line input{
  width:auto !important;
  min-height:auto !important;
  margin:0 !important;
  transform:scale(1.15);
}

.message-filter{
  display:grid;
  grid-template-columns:1fr 180px auto auto;
  gap:10px;
  align-items:center;
  margin-bottom:18px;
}

.message-list{
  display:grid;
  gap:14px;
}

.message-card{
  background:#f7f9fc;
  border:1px solid rgba(13,22,35,.08);
  border-left:6px solid #aeb9c8;
  border-radius:20px;
  padding:16px;
}

.message-card.new{
  border-left-color:#2f80ed;
}

.message-card.done{
  border-left-color:#39a96b;
}

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

.message-head strong{
  display:block;
  color:#0d1623;
  font-size:1.1rem;
}

.message-head span,
.message-meta{
  color:#69778a;
  font-size:.9rem;
}

.message-body p{
  color:#26364b;
}

.message-actions-inline{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:flex-end;
}

.message-card textarea{
  margin-top:10px;
}

.attachment-list{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.attachment-list a{
  padding:8px 10px;
  border-radius:12px;
  background:#fff;
  font-weight:800;
}

.danger{
  color:#b42318 !important;
}

@media(max-width:1100px){
  .quote-section,
  .gallery-section,
  .testimonials-section,
  .area-section,
  .faq-section{
    margin-left:0;
    padding:72px 16px;
  }

  .gallery-grid,
  .testimonial-grid,
  .area-card,
  .form-row.two,
  .form-row.three,
  .toggle-grid,
  .message-filter{
    grid-template-columns:1fr;
  }

  .message-head{
    display:grid;
  }
}

@media(max-width:760px){
  .quote-form{
    border-radius:22px;
    padding:16px;
  }

  .form-step{
    padding:14px;
    border-radius:18px;
  }

  .gallery-card img{
    height:220px;
  }

  .email-dialog{
    width:calc(100% - 16px);
    border-radius:22px;
  }

  .email-dialog-form{
    padding:18px;
  }
}


/* Nav + section spacing + premium mail overlay fix */
@media (min-width:1101px){
  .side-rail{
    gap:14px !important;
  }

  .side-rail nav{
    gap:6px !important;
    padding-top:12px !important;
  }

  .side-rail nav a{
    min-height:36px !important;
    padding:0 12px !important;
    font-size:13px !important;
    border-radius:12px !important;
  }

  .rail-contact{
    gap:8px !important;
  }

  .rail-contact a{
    height:42px !important;
  }
}

/* The new sections should start quickly after Kontakt, not feel endlessly far away */
.quote-section,
.gallery-section,
.testimonials-section,
.area-section,
.faq-section{
  padding-top:clamp(42px,5vw,76px) !important;
  padding-bottom:clamp(42px,5vw,76px) !important;
}

.contact + .quote-section,
#kontakt + #angebot{
  padding-top:clamp(26px,4vw,54px) !important;
}

.section-head{
  margin-bottom:20px !important;
}

.quote-form{
  margin-top:18px !important;
}

/* Premium sidebar email overlay */
.email-dialog-premium{
  width:min(980px,calc(100% - 28px)) !important;
  border:0 !important;
  border-radius:34px !important;
  padding:0 !important;
  overflow:hidden !important;
  background:transparent !important;
  box-shadow:0 46px 150px rgba(0,0,0,.42) !important;
}

.email-dialog-premium::backdrop{
  background:rgba(4,10,18,.72) !important;
  backdrop-filter:blur(14px) !important;
  -webkit-backdrop-filter:blur(14px) !important;
}

.email-premium-form{
  display:grid !important;
  grid-template-columns:.92fr 1.18fr !important;
  gap:0 !important;
  padding:0 !important;
  background:#fff !important;
}

.email-premium-intro{
  min-height:100%;
  padding:clamp(26px,4vw,42px);
  background:
    linear-gradient(145deg,rgba(7,17,29,.94),rgba(15,39,64,.94)),
    url("assets/img/building.jpg") center/cover;
  color:#fff;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  position:relative;
  overflow:hidden;
}

.email-premium-intro::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 20% 15%,rgba(47,128,237,.32),transparent 35%),
             linear-gradient(180deg,rgba(7,17,29,.1),rgba(7,17,29,.78));
  pointer-events:none;
}

.email-premium-intro > *{
  position:relative;
  z-index:1;
}

.email-premium-intro img{
  width:240px;
  max-width:86%;
  margin-bottom:auto;
  filter:drop-shadow(0 18px 28px rgba(0,0,0,.36));
}

.email-premium-intro h2{
  color:#fff;
  margin:10px 0 12px;
  font-size:clamp(2.2rem,4vw,4.4rem);
  letter-spacing:-.07em;
  max-width:9ch;
}

.email-premium-intro p{
  color:rgba(255,255,255,.82);
  max-width:32ch;
}

.email-premium-points{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:18px;
}

.email-premium-points span{
  padding:9px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  color:#fff;
  font-weight:850;
  font-size:.86rem;
}

.email-premium-fields{
  padding:clamp(22px,4vw,42px);
  display:grid;
  gap:15px;
  background:
    radial-gradient(circle at 100% 0%,rgba(47,128,237,.08),transparent 30%),
    #fff;
}

.email-premium-fields label{
  color:#142238 !important;
  font-weight:850;
}

.email-premium-fields input,
.email-premium-fields textarea,
.email-premium-fields select{
  background:#f7f9fc !important;
  color:#06101d !important;
  -webkit-text-fill-color:#06101d !important;
  border:1px solid rgba(13,22,35,.12) !important;
  border-radius:16px !important;
}

.email-premium-fields textarea{
  min-height:160px;
}

.email-close{
  z-index:3 !important;
  top:18px !important;
  right:18px !important;
  background:rgba(255,255,255,.9) !important;
  color:#07111d !important;
  box-shadow:0 10px 30px rgba(0,0,0,.22) !important;
}

@media(max-width:900px){
  .email-dialog-premium{
    width:calc(100% - 18px) !important;
    border-radius:24px !important;
    max-height:calc(100vh - 18px);
  }

  .email-premium-form{
    grid-template-columns:1fr !important;
    max-height:calc(100vh - 18px);
    overflow:auto;
  }

  .email-premium-intro{
    min-height:240px;
    padding:22px;
  }

  .email-premium-intro img{
    width:190px;
    margin-bottom:26px;
  }

  .email-premium-intro h2{
    font-size:2.2rem;
    max-width:none;
  }

  .email-premium-fields{
    padding:18px;
  }
}

@media(max-width:760px){
  .quote-section,
  .gallery-section,
  .testimonials-section,
  .area-section,
  .faq-section{
    padding-top:36px !important;
    padding-bottom:42px !important;
  }

  .contact + .quote-section,
  #kontakt + #angebot{
    padding-top:22px !important;
  }
}


/* FINAL FIX: New modules after Kontakt are visible, compact and professionally designed */
.pro-module-section,
.quote-section,
.gallery-section,
.testimonials-section,
.area-section,
.faq-section{
  position:relative !important;
  margin-left:var(--rail) !important;
  padding:clamp(34px,4.5vw,62px) clamp(20px,5vw,70px) !important;
  overflow:hidden !important;
  min-height:auto !important;
}

/* No invisible white areas: these modules do not depend on reveal animation */
.pro-module-section .reveal,
.pro-module-section .module-head,
.pro-module-section .module-form,
.quote-section .reveal,
.gallery-section .reveal,
.testimonials-section .reveal,
.area-section .reveal,
.faq-section .reveal{
  opacity:1 !important;
  transform:none !important;
  visibility:visible !important;
}

/* Direct compact connection after contact */
.contact-section{
  margin-bottom:0 !important;
}

.contact-wrap{
  padding-bottom:clamp(58px,6vw,82px) !important;
}

.contact-section + .pro-module-section,
#kontakt + #angebot,
.contact-section + .quote-section{
  padding-top:clamp(30px,4vw,46px) !important;
}

/* Shared module headings */
.pro-module-section .module-head,
.pro-module-section .section-head{
  width:min(980px,100%) !important;
  margin:0 auto clamp(18px,3vw,26px) !important;
  text-align:left !important;
  display:grid !important;
  gap:10px !important;
}

.pro-module-section .module-head h2,
.pro-module-section .section-head h2{
  max-width:860px !important;
  margin:0 !important;
  color:#07111d !important;
  font-size:clamp(2.3rem,5vw,5.4rem) !important;
  line-height:.92 !important;
  letter-spacing:-.075em !important;
}

.pro-module-section .module-head p,
.pro-module-section .section-head p{
  max-width:720px !important;
  color:#5f6c7e !important;
  font-size:clamp(1rem,1.4vw,1.18rem) !important;
}

/* Angebot: not white-on-white, premium card on soft background */
.pro-quote{
  background:
    radial-gradient(circle at 0% 0%,rgba(47,128,237,.14),transparent 34%),
    linear-gradient(180deg,#eef5fb,#f8fbff) !important;
}

.pro-quote .quote-form{
  width:min(1040px,100%) !important;
  margin:0 auto !important;
  display:grid !important;
  gap:14px !important;
  padding:clamp(16px,3vw,28px) !important;
  border-radius:30px !important;
  background:rgba(255,255,255,.96) !important;
  border:1px solid rgba(7,17,29,.10) !important;
  box-shadow:0 26px 80px rgba(7,17,29,.14) !important;
  color:#07111d !important;
}

.pro-quote .form-step{
  background:linear-gradient(180deg,#f7fafc,#eef4f9) !important;
  border:1px solid rgba(7,17,29,.09) !important;
  border-radius:22px !important;
  padding:18px !important;
  display:grid !important;
  gap:12px !important;
}

.pro-quote .form-step h3{
  color:#07111d !important;
  margin:0 0 4px !important;
  font-size:1.15rem !important;
}

.pro-quote label,
.pro-gallery label,
.pro-testimonials label,
.pro-area label,
.pro-faq label{
  color:#142238 !important;
}

.pro-quote input,
.pro-quote select,
.pro-quote textarea{
  color:#06101d !important;
  background:#ffffff !important;
  -webkit-text-fill-color:#06101d !important;
  border:1px solid rgba(7,17,29,.14) !important;
  border-radius:15px !important;
}

/* Galerie: image-led, no empty grid */
.pro-gallery{
  background:#07111d !important;
  color:#fff !important;
}

.pro-gallery::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 20% 0%,rgba(47,128,237,.22),transparent 28%),
    radial-gradient(circle at 100% 60%,rgba(120,170,120,.14),transparent 34%);
  pointer-events:none;
}

.pro-gallery > *{
  position:relative;
  z-index:1;
}

.pro-gallery .module-head h2,
.pro-gallery .section-head h2,
.pro-gallery .module-head p,
.pro-gallery .section-head p{
  color:#fff !important;
}

.pro-gallery .module-head p,
.pro-gallery .section-head p{
  color:rgba(255,255,255,.72) !important;
}

.pro-gallery .gallery-grid{
  width:min(1120px,100%) !important;
  margin:0 auto !important;
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:14px !important;
}

.pro-gallery .gallery-card{
  min-height:390px !important;
  display:flex !important;
  flex-direction:column !important;
  border-radius:26px !important;
  overflow:hidden !important;
  background:rgba(255,255,255,.08) !important;
  border:1px solid rgba(255,255,255,.14) !important;
  box-shadow:none !important;
  color:#fff !important;
}

.pro-gallery .gallery-card img{
  width:100% !important;
  height:260px !important;
  object-fit:cover !important;
  display:block !important;
  filter:saturate(.96) contrast(1.02) !important;
}

.pro-gallery .gallery-card div{
  padding:18px !important;
}

.pro-gallery .gallery-card h3{
  color:#fff !important;
  margin:0 0 8px !important;
}

.pro-gallery .gallery-card p{
  color:rgba(255,255,255,.74) !important;
  margin:0 !important;
}

/* Bewertungen */
.pro-testimonials{
  background:linear-gradient(180deg,#f7fafc,#eef4f9) !important;
}

.pro-testimonials .testimonial-grid{
  width:min(1120px,100%) !important;
  margin:0 auto !important;
  display:grid !important;
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  gap:16px !important;
}

.pro-testimonials .testimonial-card{
  min-height:260px !important;
  border-radius:28px !important;
  padding:24px !important;
  background:#fff !important;
  border:1px solid rgba(7,17,29,.08) !important;
  box-shadow:0 24px 70px rgba(7,17,29,.10) !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:space-between !important;
}

.pro-testimonials .testimonial-card p{
  color:#334155 !important;
  font-size:1.05rem !important;
}

.pro-testimonials .testimonial-card strong{
  color:#07111d !important;
}

.pro-testimonials .testimonial-card span{
  color:#6b7788 !important;
}

/* Einsatzgebiet */
.pro-area{
  background:#eef5fb !important;
}

.pro-area .area-card{
  width:min(1120px,100%) !important;
  margin:0 auto !important;
  display:grid !important;
  grid-template-columns:.9fr 1.1fr !important;
  gap:28px !important;
  align-items:center !important;
  padding:clamp(24px,4vw,42px) !important;
  border-radius:34px !important;
  background:
    linear-gradient(135deg,rgba(7,17,29,.96),rgba(15,39,64,.94)),
    url("assets/img/building.jpg") center/cover !important;
  color:#fff !important;
  box-shadow:0 26px 90px rgba(7,17,29,.22) !important;
}

.pro-area .area-card h2{
  color:#fff !important;
  margin:8px 0 12px !important;
  font-size:clamp(2.1rem,4vw,4.8rem) !important;
  line-height:.95 !important;
  letter-spacing:-.065em !important;
}

.pro-area .area-card p{
  color:rgba(255,255,255,.76) !important;
}

.pro-area .area-map{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:10px !important;
}

.pro-area .area-map span{
  padding:13px 16px !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.12) !important;
  border:1px solid rgba(255,255,255,.16) !important;
  color:#fff !important;
  font-weight:850 !important;
}

/* FAQ */
.pro-faq{
  background:#f7fafc !important;
  padding-bottom:clamp(54px,6vw,90px) !important;
}

.pro-faq .faq-list{
  width:min(980px,100%) !important;
  margin:0 auto !important;
  display:grid !important;
  gap:12px !important;
}

.pro-faq .faq-item{
  background:#fff !important;
  border:1px solid rgba(7,17,29,.08) !important;
  border-radius:22px !important;
  padding:18px 20px !important;
  box-shadow:0 18px 54px rgba(7,17,29,.08) !important;
}

.pro-faq .faq-item summary{
  color:#07111d !important;
  cursor:pointer !important;
  font-weight:900 !important;
  list-style:none !important;
}

.pro-faq .faq-item summary::-webkit-details-marker{
  display:none !important;
}

.pro-faq .faq-item summary::after{
  content:"+";
  float:right;
  font-size:1.4rem;
  line-height:1;
  color:#2f80ed;
}

.pro-faq .faq-item[open] summary::after{
  content:"–";
}

.pro-faq .faq-item p{
  color:#5f6c7e !important;
  margin:12px 0 0 !important;
}

/* Footer should attach normally after FAQ */
.footer{
  margin-top:0 !important;
}

/* Sidebar anchors must not overcrowd but must remain visible */
@media(min-width:1101px){
  .side-rail nav{
    overflow:visible !important;
  }

  .side-rail nav a{
    min-height:34px !important;
    font-size:12.5px !important;
  }
}

@media(max-width:1100px){
  .pro-module-section,
  .quote-section,
  .gallery-section,
  .testimonials-section,
  .area-section,
  .faq-section{
    margin-left:0 !important;
    padding:42px 16px !important;
  }

  .pro-gallery .gallery-grid,
  .pro-testimonials .testimonial-grid,
  .pro-area .area-card,
  .form-row.two,
  .form-row.three{
    grid-template-columns:1fr !important;
  }

  .pro-area .area-card{
    padding:22px !important;
  }
}

@media(max-width:760px){
  .contact-wrap{
    padding-bottom:42px !important;
  }

  .pro-module-section,
  .quote-section,
  .gallery-section,
  .testimonials-section,
  .area-section,
  .faq-section{
    padding-top:34px !important;
    padding-bottom:38px !important;
  }

  .pro-module-section .module-head h2,
  .pro-module-section .section-head h2{
    font-size:2.1rem !important;
    letter-spacing:-.045em !important;
  }

  .pro-quote .quote-form{
    padding:14px !important;
    border-radius:22px !important;
  }

  .pro-quote .form-step{
    padding:13px !important;
  }

  .pro-gallery .gallery-card{
    min-height:auto !important;
  }

  .pro-gallery .gallery-card img{
    height:220px !important;
  }

  .pro-testimonials .testimonial-card{
    min-height:auto !important;
  }
}


/* Customer review submit + admin */
.pro-review-submit{
  background:
    radial-gradient(circle at 100% 0%,rgba(47,128,237,.16),transparent 34%),
    linear-gradient(180deg,#f8fbff,#eef5fb) !important;
}

.review-submit-card{
  width:min(1120px,100%);
  margin:0 auto;
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:24px;
  align-items:start;
  padding:clamp(22px,4vw,42px);
  border-radius:34px;
  background:#fff;
  border:1px solid rgba(7,17,29,.08);
  box-shadow:0 26px 80px rgba(7,17,29,.12);
}

.review-submit-copy h2{
  color:#07111d;
  font-size:clamp(2.2rem,4.5vw,5rem);
  line-height:.94;
  letter-spacing:-.07em;
  margin:10px 0 14px;
}

.review-submit-copy p{
  color:#5f6c7e;
  max-width:520px;
}

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

.review-form label{
  color:#142238;
  font-weight:850;
}

.review-form input,
.review-form select,
.review-form textarea{
  color:#06101d !important;
  background:#f7f9fc !important;
  -webkit-text-fill-color:#06101d !important;
  border:1px solid rgba(7,17,29,.12) !important;
  border-radius:15px !important;
}

.message-card.pending{
  border-left-color:#f59e0b;
}

.message-card.approved{
  border-left-color:#39a96b;
}

.message-card.hidden{
  border-left-color:#64748b;
}

.review-admin-form{
  display:grid;
  gap:12px;
}

@media(max-width:900px){
  .review-submit-card{
    grid-template-columns:1fr;
    padding:18px;
    border-radius:24px;
  }

  .review-submit-copy h2{
    font-size:2.1rem;
  }
}


/* Modern compact mobile navigation */
@media(max-width:1100px){
  .mobile-header{
    height:64px !important;
    padding:8px 12px !important;
    background:rgba(248,250,253,.82) !important;
    backdrop-filter:blur(22px) saturate(1.25) !important;
    -webkit-backdrop-filter:blur(22px) saturate(1.25) !important;
    border-bottom:1px solid rgba(7,17,29,.08) !important;
    box-shadow:0 10px 30px rgba(7,17,29,.08) !important;
  }

  .mobile-logo img{
    max-height:44px !important;
    width:auto !important;
  }

  .modern-menu-btn,
  .menu-btn{
    width:42px !important;
    height:42px !important;
    min-width:42px !important;
    border:1px solid rgba(7,17,29,.12) !important;
    border-radius:999px !important;
    background:
      radial-gradient(circle at 32% 24%,rgba(255,255,255,.95),rgba(255,255,255,.72)),
      rgba(255,255,255,.72) !important;
    box-shadow:0 12px 34px rgba(7,17,29,.12) !important;
    display:grid !important;
    place-items:center !important;
    padding:0 !important;
    position:relative !important;
    overflow:hidden !important;
  }

  .modern-menu-btn::after,
  .menu-btn::after{
    content:"" !important;
    width:5px !important;
    height:5px !important;
    border-radius:50% !important;
    background:#2f80ed !important;
    position:absolute !important;
    right:10px !important;
    bottom:10px !important;
    transform:scale(.85) !important;
    opacity:.9 !important;
  }

  .modern-menu-btn span,
  .menu-btn span{
    width:17px !important;
    height:2px !important;
    margin:0 !important;
    border-radius:999px !important;
    background:#07111d !important;
    position:absolute !important;
    left:12px !important;
    transition:transform .22s ease, top .22s ease, opacity .22s ease !important;
  }

  .modern-menu-btn span:first-child,
  .menu-btn span:first-child{
    top:15px !important;
  }

  .modern-menu-btn span:last-child,
  .menu-btn span:last-child{
    top:24px !important;
  }

  .modern-menu-btn.is-open span:first-child,
  .menu-btn.is-open span:first-child{
    top:20px !important;
    transform:rotate(45deg) !important;
  }

  .modern-menu-btn.is-open span:last-child,
  .menu-btn.is-open span:last-child{
    top:20px !important;
    transform:rotate(-45deg) !important;
  }

  .modern-menu-btn.is-open::after,
  .menu-btn.is-open::after{
    opacity:0 !important;
  }

  .modern-mobile-menu,
  .mobile-menu{
    position:fixed !important;
    left:10px !important;
    right:10px !important;
    top:72px !important;
    z-index:120 !important;
    display:grid !important;
    gap:12px !important;
    padding:12px !important;
    border-radius:24px !important;
    background:rgba(7,17,29,.76) !important;
    color:#fff !important;
    border:1px solid rgba(255,255,255,.16) !important;
    box-shadow:0 28px 90px rgba(0,0,0,.34) !important;
    backdrop-filter:blur(22px) saturate(1.25) !important;
    -webkit-backdrop-filter:blur(22px) saturate(1.25) !important;
    transform:translateY(-10px) scale(.98) !important;
    opacity:0 !important;
    pointer-events:none !important;
    visibility:hidden !important;
    max-height:calc(100svh - 86px) !important;
    overflow:auto !important;
  }

  .modern-mobile-menu.open,
  .mobile-menu.open{
    opacity:1 !important;
    transform:translateY(0) scale(1) !important;
    pointer-events:auto !important;
    visibility:visible !important;
    display:grid !important;
  }

  .modern-mobile-menu nav,
  .mobile-menu nav{
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:8px !important;
  }

  .modern-mobile-menu nav a,
  .mobile-menu nav a{
    min-height:40px !important;
    padding:0 11px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    border-radius:999px !important;
    background:rgba(255,255,255,.08) !important;
    color:rgba(255,255,255,.88) !important;
    border:1px solid rgba(255,255,255,.10) !important;
    font-size:13px !important;
    line-height:1 !important;
    font-weight:820 !important;
    letter-spacing:-.01em !important;
    box-shadow:none !important;
  }

  .modern-mobile-menu nav a.active,
  .modern-mobile-menu nav a:hover,
  .mobile-menu nav a.active,
  .mobile-menu nav a:hover{
    background:rgba(47,128,237,.24) !important;
    border-color:rgba(139,189,255,.28) !important;
    color:#fff !important;
  }

  .modern-mobile-menu .btn,
  .mobile-menu .btn{
    min-height:42px !important;
    width:100% !important;
    border-radius:999px !important;
    font-size:13px !important;
    font-weight:900 !important;
    box-shadow:0 14px 36px rgba(47,128,237,.28) !important;
  }

  body.menu-open::before{
    content:"" !important;
    position:fixed !important;
    inset:0 !important;
    z-index:110 !important;
    background:rgba(3,8,14,.18) !important;
    backdrop-filter:blur(2px) !important;
    -webkit-backdrop-filter:blur(2px) !important;
    pointer-events:none !important;
  }
}

@media(max-width:390px){
  .modern-mobile-menu nav,
  .mobile-menu nav{
    grid-template-columns:1fr !important;
  }

  .modern-mobile-menu nav a,
  .mobile-menu nav a{
    min-height:38px !important;
  }
}


/* FINAL mobile refinement: 90% feel, premium button, compact menu */
@media(max-width:760px){
  html{
    font-size:90% !important;
  }

  body{
    --mobile-ui-scale:.9;
  }

  .site-main,
  .footer{
    font-size:.9rem !important;
  }

  h1{
    font-size:clamp(34px,10.8vw,50px) !important;
  }

  h2{
    font-size:clamp(28px,8.8vw,41px) !important;
  }

  p{
    font-size:15px !important;
    line-height:1.62 !important;
  }

  .btn{
    min-height:48px !important;
    border-radius:13px !important;
    font-size:.94rem !important;
  }

  .mobile-header{
    height:58px !important;
    padding:7px 10px !important;
    background:rgba(250,252,255,.86) !important;
    border-bottom:1px solid rgba(7,17,29,.07) !important;
    box-shadow:0 8px 22px rgba(7,17,29,.07) !important;
  }

  .mobile-logo img{
    max-height:39px !important;
  }

  .hero-slices{
    height:378px !important;
  }

  .hero-content{
    width:calc(100% - 22px) !important;
    margin:-108px auto 42px !important;
    padding:22px !important;
    border-radius:24px !important;
  }

  .section,
  .journey,
  .pro-module-section,
  .quote-section,
  .gallery-section,
  .testimonials-section,
  .area-section,
  .faq-section{
    padding-top:31px !important;
    padding-bottom:34px !important;
  }

  .contact-wrap{
    padding:58px 14px 38px !important;
  }
}

/* Clean premium mobile menu button */
@media(max-width:1100px){
  .premium-menu-btn,
  .menu-btn.premium-menu-btn{
    width:38px !important;
    height:38px !important;
    min-width:38px !important;
    border:0 !important;
    border-radius:15px !important;
    background:
      linear-gradient(145deg,#07111d,#10243a) !important;
    box-shadow:
      0 12px 28px rgba(7,17,29,.20),
      inset 0 1px 0 rgba(255,255,255,.12) !important;
    display:grid !important;
    place-items:center !important;
    gap:0 !important;
    padding:0 !important;
    position:relative !important;
    overflow:hidden !important;
  }

  .premium-menu-btn::before{
    content:"" !important;
    position:absolute !important;
    inset:1px !important;
    border-radius:14px !important;
    background:linear-gradient(145deg,rgba(255,255,255,.12),transparent 55%) !important;
    pointer-events:none !important;
  }

  .premium-menu-btn::after{
    display:none !important;
  }

  .premium-menu-btn i{
    width:16px !important;
    height:2px !important;
    border-radius:999px !important;
    background:#fff !important;
    position:absolute !important;
    left:11px !important;
    transition:transform .22s ease, top .22s ease, opacity .18s ease, width .18s ease !important;
    box-shadow:0 0 12px rgba(139,189,255,.35) !important;
  }

  .premium-menu-btn i:nth-child(1){
    top:12px !important;
    width:14px !important;
  }

  .premium-menu-btn i:nth-child(2){
    top:18px !important;
    width:16px !important;
  }

  .premium-menu-btn i:nth-child(3){
    top:24px !important;
    width:10px !important;
  }

  .premium-menu-btn.is-open i:nth-child(1){
    top:18px !important;
    width:16px !important;
    transform:rotate(45deg) !important;
  }

  .premium-menu-btn.is-open i:nth-child(2){
    opacity:0 !important;
    transform:translateX(8px) !important;
  }

  .premium-menu-btn.is-open i:nth-child(3){
    top:18px !important;
    width:16px !important;
    transform:rotate(-45deg) !important;
  }

  .premium-menu-btn span{
    display:none !important;
  }
}

/* Much smaller mobile overlay: compact bottom sheet */
@media(max-width:1100px){
  .modern-mobile-menu,
  .mobile-menu{
    left:12px !important;
    right:12px !important;
    top:auto !important;
    bottom:12px !important;
    width:auto !important;
    max-height:min(48svh,360px) !important;
    padding:10px !important;
    border-radius:22px !important;
    background:rgba(8,18,31,.84) !important;
    border:1px solid rgba(255,255,255,.13) !important;
    box-shadow:0 24px 70px rgba(0,0,0,.34) !important;
    backdrop-filter:blur(24px) saturate(1.25) !important;
    -webkit-backdrop-filter:blur(24px) saturate(1.25) !important;
    overflow:auto !important;
    display:grid !important;
    gap:9px !important;
    transform:translateY(18px) scale(.985) !important;
    opacity:0 !important;
    pointer-events:none !important;
    visibility:hidden !important;
  }

  .modern-mobile-menu.open,
  .mobile-menu.open{
    opacity:1 !important;
    transform:translateY(0) scale(1) !important;
    pointer-events:auto !important;
    visibility:visible !important;
  }

  .modern-mobile-menu nav,
  .mobile-menu nav{
    display:grid !important;
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
    gap:6px !important;
  }

  .modern-mobile-menu nav a,
  .mobile-menu nav a{
    min-height:32px !important;
    padding:0 8px !important;
    border-radius:999px !important;
    background:rgba(255,255,255,.075) !important;
    border:1px solid rgba(255,255,255,.095) !important;
    color:rgba(255,255,255,.88) !important;
    font-size:11.5px !important;
    line-height:1 !important;
    font-weight:800 !important;
    letter-spacing:-.015em !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    white-space:nowrap !important;
  }

  .modern-mobile-menu nav a.active,
  .mobile-menu nav a.active{
    background:rgba(47,128,237,.30) !important;
    border-color:rgba(139,189,255,.30) !important;
    color:#fff !important;
  }

  .modern-mobile-menu .btn,
  .mobile-menu .btn{
    min-height:34px !important;
    width:100% !important;
    border-radius:999px !important;
    font-size:12px !important;
    font-weight:900 !important;
    padding:0 12px !important;
    box-shadow:0 10px 26px rgba(47,128,237,.22) !important;
  }

  body.menu-open::before{
    background:rgba(3,8,14,.10) !important;
    backdrop-filter:blur(1px) !important;
    -webkit-backdrop-filter:blur(1px) !important;
  }
}

@media(max-width:430px){
  .modern-mobile-menu,
  .mobile-menu{
    max-height:min(52svh,380px) !important;
  }

  .modern-mobile-menu nav,
  .mobile-menu nav{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }

  .modern-mobile-menu nav a,
  .mobile-menu nav a{
    min-height:32px !important;
    font-size:11.8px !important;
  }
}

@media(max-width:340px){
  .modern-mobile-menu nav,
  .mobile-menu nav{
    grid-template-columns:1fr !important;
  }
}


/* Final mobile fullscreen text menu */
@media(max-width:1100px){
  .fullscreen-mobile-menu,
  .modern-mobile-menu.fullscreen-mobile-menu,
  .mobile-menu.fullscreen-mobile-menu{
    position:fixed !important;
    inset:0 !important;
    width:100vw !important;
    height:100svh !important;
    max-height:none !important;
    z-index:300 !important;
    padding:clamp(22px,6vw,44px) !important;
    border:0 !important;
    border-radius:0 !important;
    background:
      radial-gradient(circle at 82% 12%,rgba(47,128,237,.22),transparent 30%),
      radial-gradient(circle at 12% 88%,rgba(120,216,196,.13),transparent 28%),
      linear-gradient(145deg,#050b13,#07111d 48%,#0c1c2d) !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
    overflow:hidden !important;
    display:grid !important;
    place-items:center !important;
    transform:translateY(0) scale(1.02) !important;
    opacity:0 !important;
    visibility:hidden !important;
    pointer-events:none !important;
    transition:opacity .28s ease, visibility .28s ease, transform .28s ease !important;
  }

  .fullscreen-mobile-menu.open,
  .modern-mobile-menu.fullscreen-mobile-menu.open,
  .mobile-menu.fullscreen-mobile-menu.open{
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
    transform:translateY(0) scale(1) !important;
  }

  .fullscreen-menu-inner{
    width:min(520px,100%) !important;
    display:grid !important;
    gap:clamp(18px,4vw,28px) !important;
    text-align:center !important;
    align-content:center !important;
  }

  .fullscreen-menu-label{
    color:rgba(255,255,255,.48) !important;
    font-size:11px !important;
    font-weight:900 !important;
    letter-spacing:.18em !important;
    text-transform:uppercase !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:clamp(7px,1.2vh,12px) !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    min-height:auto !important;
    padding:0 !important;
    border:0 !important;
    border-radius:0 !important;
    background:transparent !important;
    box-shadow:none !important;
    color:rgba(255,255,255,.86) !important;
    font-size:clamp(25px,7.2vw,42px) !important;
    line-height:1.02 !important;
    font-weight:850 !important;
    letter-spacing:-.055em !important;
    justify-content:center !important;
    text-align:center !important;
    transition:color .2s ease, transform .2s ease, opacity .2s ease !important;
  }

  .fullscreen-mobile-menu nav a:hover,
  .fullscreen-mobile-menu nav a.active,
  .modern-mobile-menu.fullscreen-mobile-menu nav a:hover,
  .modern-mobile-menu.fullscreen-mobile-menu nav a.active,
  .mobile-menu.fullscreen-mobile-menu nav a:hover,
  .mobile-menu.fullscreen-mobile-menu nav a.active{
    color:#8bbdff !important;
    background:transparent !important;
    border:0 !important;
    transform:translateY(-1px) !important;
  }

  .fullscreen-menu-cta{
    justify-self:center !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    min-height:42px !important;
    padding:0 20px !important;
    border-radius:999px !important;
    background:rgba(255,255,255,.10) !important;
    border:1px solid rgba(255,255,255,.18) !important;
    color:#fff !important;
    font-size:13px !important;
    font-weight:900 !important;
    letter-spacing:.01em !important;
    box-shadow:none !important;
  }

  .mobile-menu-close{
    position:fixed !important;
    top:calc(env(safe-area-inset-top,0px) + 16px) !important;
    right:18px !important;
    z-index:320 !important;
    width:44px !important;
    height:44px !important;
    display:grid !important;
    place-items:center !important;
    border:0 !important;
    border-radius:999px !important;
    background:transparent !important;
    color:#fff !important;
    font-size:38px !important;
    line-height:1 !important;
    font-weight:300 !important;
    box-shadow:none !important;
  }

  .mobile-menu-close:hover{
    color:#8bbdff !important;
  }

  body.menu-open::before{
    display:none !important;
  }

  body.menu-open .mobile-header{
    z-index:80 !important;
  }
}

@media(max-width:430px){
  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(23px,7vw,34px) !important;
  }

  .fullscreen-menu-inner{
    gap:16px !important;
  }
}

@media(max-height:720px){
  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:6px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(21px,5.6vh,34px) !important;
  }
}


/* Final mobile stability + smaller fullscreen menu + modern drag/drop upload */
@media(max-width:1100px){
  html,
  body{
    width:100% !important;
    max-width:100% !important;
    overflow-x:hidden !important;
    overscroll-behavior-x:none !important;
  }

  html.menu-lock{
    overflow:hidden !important;
    height:100% !important;
  }

  body.menu-lock{
    position:fixed !important;
    left:0 !important;
    right:0 !important;
    width:100% !important;
    overflow:hidden !important;
  }

  .site-main,
  .mobile-header,
  .footer{
    max-width:100vw !important;
    overflow-x:hidden !important;
  }

  .fullscreen-mobile-menu,
  .modern-mobile-menu.fullscreen-mobile-menu,
  .mobile-menu.fullscreen-mobile-menu{
    position:fixed !important;
    left:0 !important;
    right:0 !important;
    top:0 !important;
    bottom:0 !important;
    width:100vw !important;
    height:100vh !important;
    height:100dvh !important;
    min-height:100vh !important;
    min-height:100dvh !important;
    max-height:none !important;
    padding:
      calc(env(safe-area-inset-top,0px) + 28px)
      24px
      calc(env(safe-area-inset-bottom,0px) + 28px) !important;
    overflow:hidden !important;
    touch-action:none !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
  }

  .fullscreen-menu-inner{
    width:min(420px,100%) !important;
    max-height:calc(100dvh - 120px) !important;
    overflow:auto !important;
    overscroll-behavior:contain !important;
    -webkit-overflow-scrolling:touch !important;
    gap:14px !important;
    padding:0 !important;
  }

  .fullscreen-menu-label{
    font-size:10px !important;
    margin-bottom:2px !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:5px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(18px,5.2vw,27px) !important;
    line-height:1.08 !important;
    letter-spacing:-.038em !important;
    font-weight:780 !important;
    opacity:.94 !important;
  }

  .fullscreen-menu-cta{
    margin-top:10px !important;
    min-height:36px !important;
    padding:0 16px !important;
    font-size:12px !important;
  }

  .mobile-menu-close{
    top:calc(env(safe-area-inset-top,0px) + 13px) !important;
    right:14px !important;
    width:40px !important;
    height:40px !important;
    font-size:33px !important;
  }
}

@media(max-height:720px){
  .fullscreen-menu-inner{
    gap:10px !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:3px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(16px,4.6vh,24px) !important;
    line-height:1.04 !important;
  }
}

@media(max-width:380px){
  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(17px,5vw,24px) !important;
  }
}

/* Prevent visual horizontal movement in mobile sections */
@media(max-width:760px){
  .hero-content,
  .quality-panel,
  .service-card,
  .journey-card,
  .process-card,
  .contact-wrap,
  .quote-form,
  .gallery-card,
  .testimonial-card,
  .review-submit-card,
  .area-card,
  .faq-item{
    max-width:100% !important;
  }

  .hero-slices,
  .slice,
  .slice img{
    max-width:100vw !important;
  }

  .slice img{
    transform:none !important;
  }
}

/* Modern public drag & drop upload */
.native-file-input{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  opacity:0 !important;
  pointer-events:none !important;
}

.upload-dropzone{
  margin-top:8px;
  width:100%;
  min-height:132px;
  border-radius:22px;
  border:1.5px dashed rgba(47,128,237,.36);
  background:
    radial-gradient(circle at 0% 0%,rgba(47,128,237,.10),transparent 30%),
    linear-gradient(180deg,#f8fbff,#eef5fb);
  display:grid;
  grid-template-columns:auto 1fr;
  gap:16px;
  align-items:center;
  padding:18px;
  color:#07111d;
  cursor:pointer;
  transition:transform .2s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease;
}

.upload-dropzone:hover,
.upload-dropzone.is-dragover{
  transform:translateY(-1px);
  border-color:rgba(47,128,237,.72);
  background:
    radial-gradient(circle at 0% 0%,rgba(47,128,237,.18),transparent 34%),
    linear-gradient(180deg,#ffffff,#eef6ff);
  box-shadow:0 18px 46px rgba(47,128,237,.14);
}

.upload-dropzone.has-files{
  border-style:solid;
  border-color:rgba(57,169,107,.58);
}

.upload-icon{
  width:54px;
  height:54px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:#07111d;
  color:#fff;
  box-shadow:0 14px 32px rgba(7,17,29,.18);
}

.upload-icon svg{
  width:26px;
  height:26px;
}

.upload-dropzone strong{
  display:block;
  color:#07111d;
  font-size:1rem;
  margin-bottom:4px;
}

.upload-dropzone span{
  display:block;
  color:#4b5b70;
  font-weight:750;
  font-size:.92rem;
  margin-bottom:4px;
}

.upload-dropzone small{
  display:block;
  color:#7b8797;
  font-weight:700;
  font-size:.78rem;
}

.upload-file-list{
  grid-column:1/-1;
  margin:0;
  color:#1f7a49;
  font-size:.86rem;
  line-height:1.35;
  font-weight:800;
}

@media(max-width:760px){
  .upload-dropzone{
    min-height:112px;
    grid-template-columns:1fr;
    text-align:center;
    justify-items:center;
    padding:14px;
    gap:10px;
    border-radius:18px;
  }

  .upload-icon{
    width:46px;
    height:46px;
    border-radius:16px;
  }
}


/* Fix mobile header visibility + elegant fullscreen menu spacing */
@media(max-width:1100px){
  .mobile-header{
    position:sticky !important;
    top:0 !important;
    z-index:260 !important;
    display:flex !important;
    visibility:visible !important;
    opacity:1 !important;
    transform:none !important;
    height:62px !important;
    padding:8px 12px !important;
    background:rgba(250,252,255,.90) !important;
    border-bottom:1px solid rgba(7,17,29,.07) !important;
    box-shadow:0 10px 28px rgba(7,17,29,.08) !important;
    backdrop-filter:blur(22px) saturate(1.15) !important;
    -webkit-backdrop-filter:blur(22px) saturate(1.15) !important;
  }

  .mobile-logo{
    display:flex !important;
    align-items:center !important;
    min-width:0 !important;
  }

  .mobile-logo img{
    display:block !important;
    max-height:42px !important;
    width:auto !important;
    opacity:1 !important;
    visibility:visible !important;
  }

  body.menu-open .mobile-header{
    z-index:360 !important;
    background:transparent !important;
    border-bottom-color:transparent !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
  }

  body.menu-open .mobile-logo img{
    filter:brightness(0) invert(1) drop-shadow(0 10px 24px rgba(0,0,0,.35)) !important;
  }

  body.menu-open .premium-menu-btn{
    opacity:0 !important;
    pointer-events:none !important;
  }

  .fullscreen-mobile-menu,
  .modern-mobile-menu.fullscreen-mobile-menu,
  .mobile-menu.fullscreen-mobile-menu{
    z-index:300 !important;
    padding:
      calc(env(safe-area-inset-top,0px) + 92px)
      24px
      calc(env(safe-area-inset-bottom,0px) + 34px) !important;
  }

  .mobile-menu-close{
    z-index:380 !important;
    top:calc(env(safe-area-inset-top,0px) + 12px) !important;
    right:14px !important;
    width:44px !important;
    height:44px !important;
    font-size:34px !important;
  }

  .fullscreen-menu-inner{
    width:min(430px,100%) !important;
    max-height:calc(100dvh - 150px) !important;
    gap:22px !important;
    align-self:center !important;
  }

  .fullscreen-menu-label{
    margin-bottom:4px !important;
    font-size:10px !important;
    letter-spacing:.22em !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:14px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(19px,5.1vw,28px) !important;
    line-height:1.22 !important;
    letter-spacing:-.035em !important;
    font-weight:780 !important;
    padding:2px 0 !important;
  }

  .fullscreen-menu-cta{
    margin-top:6px !important;
  }
}

@media(max-width:430px){
  .fullscreen-menu-inner{
    gap:19px !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:12px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(18px,5.6vw,25px) !important;
    line-height:1.24 !important;
  }
}

@media(max-height:720px){
  .fullscreen-mobile-menu,
  .modern-mobile-menu.fullscreen-mobile-menu,
  .mobile-menu.fullscreen-mobile-menu{
    padding-top:calc(env(safe-area-inset-top,0px) + 78px) !important;
  }

  .fullscreen-menu-inner{
    gap:14px !important;
    max-height:calc(100dvh - 120px) !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:8px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(16px,4.6vh,23px) !important;
    line-height:1.16 !important;
  }
}


/* Final fix: mobile header always visible after navigation + smaller menu text */
@media(max-width:1100px){
  .mobile-header{
    position:fixed !important;
    top:0 !important;
    left:0 !important;
    right:0 !important;
    z-index:420 !important;
    display:flex !important;
    visibility:visible !important;
    opacity:1 !important;
    transform:none !important;
    height:60px !important;
    padding:8px 12px !important;
    background:rgba(250,252,255,.92) !important;
    border-bottom:1px solid rgba(7,17,29,.07) !important;
    box-shadow:0 10px 28px rgba(7,17,29,.08) !important;
    backdrop-filter:blur(22px) saturate(1.15) !important;
    -webkit-backdrop-filter:blur(22px) saturate(1.15) !important;
  }

  .site-main{
    padding-top:60px !important;
  }

  .hero{
    margin-top:-60px !important;
  }

  .mobile-logo,
  .mobile-logo img{
    display:block !important;
    visibility:visible !important;
    opacity:1 !important;
  }

  .mobile-logo{
    display:flex !important;
    align-items:center !important;
  }

  .mobile-logo img{
    max-height:40px !important;
    width:auto !important;
  }

  body.menu-open .mobile-header{
    z-index:430 !important;
    background:transparent !important;
    border-bottom-color:transparent !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
  }

  body.menu-open .mobile-logo img{
    filter:brightness(0) invert(1) drop-shadow(0 10px 24px rgba(0,0,0,.35)) !important;
  }

  .fullscreen-mobile-menu,
  .modern-mobile-menu.fullscreen-mobile-menu,
  .mobile-menu.fullscreen-mobile-menu{
    z-index:400 !important;
  }

  .mobile-menu-close{
    z-index:450 !important;
  }

  .fullscreen-menu-inner{
    width:min(390px,100%) !important;
    gap:18px !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:10px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(16px,4.7vw,24px) !important;
    line-height:1.18 !important;
    letter-spacing:-.03em !important;
    font-weight:760 !important;
  }
}

@media(max-width:430px){
  .fullscreen-menu-inner{
    gap:16px !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:9px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(15px,4.9vw,22px) !important;
    line-height:1.2 !important;
  }
}

@media(max-height:720px){
  .fullscreen-menu-inner{
    gap:12px !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:6px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(14px,4.1vh,20px) !important;
    line-height:1.12 !important;
  }
}


/* Business Suite: availability, trust, packages, before/after, admin dashboard */
.pro-availability{
  background:linear-gradient(180deg,#f8fbff,#eef5fb) !important;
}

.availability-grid{
  width:min(1120px,100%);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}

.availability-card{
  border-radius:26px;
  padding:24px;
  background:#fff;
  border:1px solid rgba(7,17,29,.08);
  box-shadow:0 20px 62px rgba(7,17,29,.08);
}

.availability-card h3{
  color:#07111d;
  margin:0 0 10px;
}

.availability-card p{
  margin:0;
  color:#5f6c7e;
}

.pro-trust{
  background:#07111d !important;
  color:#fff;
}

.trust-card{
  width:min(1120px,100%);
  margin:0 auto;
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:28px;
  align-items:center;
  padding:clamp(24px,4vw,46px);
  border-radius:34px;
  background:
    radial-gradient(circle at 0% 0%,rgba(47,128,237,.22),transparent 35%),
    linear-gradient(135deg,rgba(255,255,255,.09),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.12);
}

.trust-card h2,
.trust-card p{
  color:#fff !important;
}

.trust-card p{
  color:rgba(255,255,255,.72) !important;
}

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

.trust-item{
  padding:18px;
  border-radius:22px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
}

.trust-item strong{
  display:block;
  color:#fff;
  margin-bottom:6px;
}

.trust-item span{
  display:block;
  color:rgba(255,255,255,.72);
  line-height:1.55;
}

.pro-packages{
  background:linear-gradient(180deg,#eef5fb,#f8fbff) !important;
}

.packages-grid{
  width:min(1120px,100%);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}

.package-card{
  border-radius:28px;
  padding:24px;
  background:#fff;
  border:1px solid rgba(7,17,29,.08);
  box-shadow:0 24px 70px rgba(7,17,29,.10);
  display:flex;
  flex-direction:column;
  min-height:320px;
}

.package-card h3{
  color:#07111d;
  margin:0 0 10px;
}

.package-card p{
  color:#5f6c7e;
  margin-bottom:18px;
}

.package-card div{
  margin-top:auto;
  display:grid;
  gap:8px;
}

.package-card span{
  display:block;
  padding:9px 11px;
  border-radius:999px;
  background:#eef5fb;
  color:#163253;
  font-weight:850;
  font-size:.88rem;
}

.pro-before-after{
  background:#07111d !important;
  color:#fff;
}

.pro-before-after .module-head h2,
.pro-before-after .module-head p{
  color:#fff !important;
}

.pro-before-after .module-head p{
  color:rgba(255,255,255,.72) !important;
}

.before-after-grid{
  width:min(1120px,100%);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}

.before-after-card{
  overflow:hidden;
  border-radius:30px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
}

.ba-images{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1px;
}

.ba-images figure{
  margin:0;
  position:relative;
  min-height:260px;
  overflow:hidden;
}

.ba-images img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.ba-images figcaption{
  position:absolute;
  left:12px;
  top:12px;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(7,17,29,.74);
  color:#fff;
  font-size:.78rem;
  font-weight:900;
}

.ba-copy{
  padding:22px;
}

.ba-copy span{
  color:#8bbdff;
  font-weight:900;
  font-size:.78rem;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.ba-copy h3{
  color:#fff;
  margin:8px 0 8px;
}

.ba-copy p{
  color:rgba(255,255,255,.72);
  margin:0;
}

/* Upload preview with remove buttons */
.upload-preview-list{
  grid-column:1/-1;
  display:grid;
  gap:8px;
  width:100%;
}

.upload-preview-item{
  display:grid;
  grid-template-columns:54px 1fr auto;
  gap:10px;
  align-items:center;
  padding:8px;
  border-radius:16px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(7,17,29,.08);
}

.upload-thumb{
  width:54px;
  height:44px;
  border-radius:12px;
  overflow:hidden;
  display:grid;
  place-items:center;
  background:#07111d;
  color:#fff;
  font-weight:900;
  font-size:.72rem;
}

.upload-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.upload-meta strong{
  display:block;
  color:#07111d;
  font-size:.86rem;
  line-height:1.2;
  word-break:break-word;
}

.upload-meta span{
  color:#6b7788;
  font-size:.75rem;
}

.upload-remove{
  min-height:32px;
  border:0;
  border-radius:999px;
  padding:0 10px;
  background:#fff0f0;
  color:#b42318;
  font-weight:900;
}

/* Admin dashboard and image manager */
.dashboard-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  margin-bottom:22px;
}

.dashboard-stat{
  padding:18px;
  border-radius:20px;
  background:#f4f7fb;
  border:1px solid rgba(7,17,29,.08);
}

.dashboard-stat strong{
  display:block;
  font-size:2rem;
  color:#07111d;
  letter-spacing:-.05em;
}

.dashboard-stat span{
  color:#657386;
  font-weight:850;
}

.dashboard-recent{
  display:grid;
  gap:8px;
}

.dashboard-recent div{
  display:flex;
  justify-content:space-between;
  gap:16px;
  padding:12px 14px;
  border-radius:14px;
  background:#f7f9fc;
}

.dashboard-recent strong{
  color:#07111d;
}

.dashboard-recent span{
  color:#657386;
}

.admin-details{
  margin-top:12px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(7,17,29,.08);
  padding:12px;
}

.admin-details summary{
  cursor:pointer;
  font-weight:900;
  color:#07111d;
}

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

.image-manager-card{
  border-radius:18px;
  overflow:hidden;
  background:#f7f9fc;
  border:1px solid rgba(7,17,29,.08);
}

.image-manager-preview{
  height:150px;
  display:grid;
  place-items:center;
  background:#07111d;
  color:#fff;
}

.image-manager-preview img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.image-manager-card > div:last-child{
  padding:12px;
  display:grid;
  gap:6px;
}

.image-manager-card strong{
  color:#07111d;
  word-break:break-word;
}

.image-manager-card span{
  color:#657386;
  font-size:.86rem;
}

.before-after-admin-preview{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4px;
}

.before-after-admin-preview img{
  height:150px;
  object-fit:cover;
}

.message-card.in_progress{
  border-left-color:#8b5cf6;
}

.message-card.offer_created{
  border-left-color:#2f80ed;
}

@media(max-width:1100px){
  .availability-grid,
  .trust-card,
  .trust-grid,
  .packages-grid,
  .before-after-grid,
  .dashboard-grid,
  .image-manager-grid{
    grid-template-columns:1fr !important;
  }

  .package-card{
    min-height:auto;
  }

  .ba-images figure{
    min-height:210px;
  }
}

@media(max-width:760px){
  .upload-preview-item{
    grid-template-columns:46px 1fr;
  }

  .upload-remove{
    grid-column:1/-1;
  }

  .dashboard-recent div{
    display:grid;
  }
}


/* Desktop sidebar fit fix: all categories + contact buttons visible */
@media(min-width:1101px){
  :root{
    --rail:172px !important;
  }

  .side-rail{
    width:var(--rail) !important;
    padding:18px 16px 16px !important;
    grid-template-rows:auto minmax(0,1fr) auto !important;
    gap:10px !important;
    overflow:hidden !important;
  }

  .rail-logo{
    display:flex !important;
    justify-content:center !important;
    align-items:center !important;
    min-height:66px !important;
  }

  .rail-logo img{
    width:108px !important;
    max-height:64px !important;
    object-fit:contain !important;
  }

  .side-rail nav{
    align-content:center !important;
    gap:3px !important;
    padding:4px 0 !important;
    overflow:hidden !important;
  }

  .side-rail nav a{
    min-height:28px !important;
    height:28px !important;
    padding:0 8px !important;
    border-radius:9px !important;
    font-size:11.4px !important;
    line-height:1 !important;
    font-weight:760 !important;
    letter-spacing:-.01em !important;
  }

  .rail-contact{
    display:grid !important;
    grid-template-columns:repeat(3,1fr) !important;
    gap:6px !important;
    padding-top:10px !important;
    border-top:1px solid rgba(255,255,255,.16) !important;
    min-height:42px !important;
  }

  .rail-contact a{
    height:34px !important;
    min-height:34px !important;
    border-radius:10px !important;
    font-size:16px !important;
    display:grid !important;
    place-items:center !important;
  }

  .rail-contact .whatsapp-icon{
    width:19px !important;
    height:19px !important;
  }
}

@media(min-width:1101px) and (max-height:760px){
  .side-rail{
    padding:14px 14px 12px !important;
    gap:6px !important;
  }

  .rail-logo{
    min-height:54px !important;
  }

  .rail-logo img{
    width:94px !important;
    max-height:52px !important;
  }

  .side-rail nav{
    gap:2px !important;
  }

  .side-rail nav a{
    min-height:24px !important;
    height:24px !important;
    font-size:10.6px !important;
    border-radius:8px !important;
  }

  .rail-contact{
    padding-top:7px !important;
  }

  .rail-contact a{
    height:30px !important;
    min-height:30px !important;
  }

  .rail-contact .whatsapp-icon{
    width:17px !important;
    height:17px !important;
  }
}


/* Final mobile menu: fixed fullscreen, no scroll, X works, all items fit */
@media(max-width:1100px){
  html.menu-lock,
  body.menu-lock{
    overflow:hidden !important;
    height:100% !important;
    overscroll-behavior:none !important;
    touch-action:none !important;
  }

  .fullscreen-mobile-menu,
  .modern-mobile-menu.fullscreen-mobile-menu,
  .mobile-menu.fullscreen-mobile-menu{
    position:fixed !important;
    inset:0 !important;
    width:100vw !important;
    height:100vh !important;
    height:100dvh !important;
    min-height:100vh !important;
    min-height:100dvh !important;
    max-height:100dvh !important;
    z-index:600 !important;
    padding:
      calc(env(safe-area-inset-top,0px) + 78px)
      18px
      calc(env(safe-area-inset-bottom,0px) + 24px) !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    overflow:hidden !important;
    touch-action:none !important;
    overscroll-behavior:none !important;
    border:0 !important;
    border-radius:0 !important;
    background:
      radial-gradient(circle at 82% 10%,rgba(47,128,237,.22),transparent 31%),
      radial-gradient(circle at 12% 90%,rgba(120,216,196,.12),transparent 28%),
      linear-gradient(145deg,#050b13,#07111d 50%,#0b1b2c) !important;
    opacity:0 !important;
    visibility:hidden !important;
    pointer-events:none !important;
    transform:none !important;
    transition:opacity .22s ease, visibility .22s ease !important;
  }

  .fullscreen-mobile-menu.open,
  .modern-mobile-menu.fullscreen-mobile-menu.open,
  .mobile-menu.fullscreen-mobile-menu.open{
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
  }

  .fullscreen-menu-inner{
    width:min(430px,100%) !important;
    height:auto !important;
    max-height:none !important;
    overflow:hidden !important;
    display:grid !important;
    align-content:center !important;
    justify-items:center !important;
    gap:16px !important;
    padding:0 !important;
    text-align:center !important;
  }

  .fullscreen-menu-label{
    font-size:9.5px !important;
    line-height:1 !important;
    margin:0 0 2px !important;
    color:rgba(255,255,255,.46) !important;
    letter-spacing:.22em !important;
    text-transform:uppercase !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    width:100% !important;
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    column-gap:20px !important;
    row-gap:12px !important;
    overflow:hidden !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    min-height:auto !important;
    height:auto !important;
    padding:0 !important;
    margin:0 !important;
    border:0 !important;
    border-radius:0 !important;
    background:transparent !important;
    color:rgba(255,255,255,.88) !important;
    box-shadow:none !important;
    font-size:clamp(14px,4.15vw,19px) !important;
    line-height:1.12 !important;
    font-weight:760 !important;
    letter-spacing:-.025em !important;
    white-space:normal !important;
    text-align:center !important;
  }

  .fullscreen-mobile-menu nav a.active,
  .modern-mobile-menu.fullscreen-mobile-menu nav a.active,
  .mobile-menu.fullscreen-mobile-menu nav a.active{
    color:#8bbdff !important;
  }

  .fullscreen-menu-cta{
    margin-top:2px !important;
    min-height:32px !important;
    padding:0 15px !important;
    border-radius:999px !important;
    background:rgba(255,255,255,.10) !important;
    border:1px solid rgba(255,255,255,.16) !important;
    color:#fff !important;
    font-size:11.5px !important;
    line-height:1 !important;
    font-weight:900 !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
  }

  .mobile-menu-close{
    position:fixed !important;
    top:calc(env(safe-area-inset-top,0px) + 12px) !important;
    right:14px !important;
    z-index:900 !important;
    width:48px !important;
    height:48px !important;
    display:grid !important;
    place-items:center !important;
    pointer-events:auto !important;
    touch-action:manipulation !important;
    border:0 !important;
    border-radius:999px !important;
    background:rgba(255,255,255,.10) !important;
    color:#fff !important;
    font-size:34px !important;
    line-height:1 !important;
    font-weight:300 !important;
    box-shadow:0 12px 34px rgba(0,0,0,.22) !important;
    -webkit-tap-highlight-color:transparent !important;
  }

  .mobile-menu-close:active{
    transform:scale(.96) !important;
  }

  body.menu-open .mobile-header{
    z-index:650 !important;
    background:transparent !important;
    border-bottom-color:transparent !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
  }

  body.menu-open .mobile-logo img{
    filter:brightness(0) invert(1) drop-shadow(0 10px 24px rgba(0,0,0,.35)) !important;
  }

  body.menu-open .premium-menu-btn{
    opacity:0 !important;
    pointer-events:none !important;
  }
}

@media(max-width:390px){
  .fullscreen-mobile-menu,
  .modern-mobile-menu.fullscreen-mobile-menu,
  .mobile-menu.fullscreen-mobile-menu{
    padding-left:14px !important;
    padding-right:14px !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    column-gap:14px !important;
    row-gap:10px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(13px,4vw,17px) !important;
  }
}

@media(max-height:720px){
  .fullscreen-mobile-menu,
  .modern-mobile-menu.fullscreen-mobile-menu,
  .mobile-menu.fullscreen-mobile-menu{
    padding-top:calc(env(safe-area-inset-top,0px) + 64px) !important;
    padding-bottom:calc(env(safe-area-inset-bottom,0px) + 14px) !important;
  }

  .fullscreen-menu-inner{
    gap:10px !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    row-gap:7px !important;
    column-gap:14px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(12px,3.7vh,16px) !important;
    line-height:1.08 !important;
  }

  .fullscreen-menu-cta{
    min-height:28px !important;
    font-size:10.8px !important;
  }

  .mobile-menu-close{
    width:42px !important;
    height:42px !important;
    font-size:30px !important;
  }
}

@media(max-height:620px){
  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    row-gap:5px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(11px,3.3vh,14px) !important;
  }

  .fullscreen-menu-label{
    display:none !important;
  }
}


/* PROFESSIONAL MOBILE MENU: clean vertical navigation, no side-by-side */
@media(max-width:1100px){
  html.menu-lock,
  body.menu-lock{
    overflow:hidden !important;
    height:100% !important;
    overscroll-behavior:none !important;
  }

  .fullscreen-mobile-menu,
  .modern-mobile-menu.fullscreen-mobile-menu,
  .mobile-menu.fullscreen-mobile-menu{
    position:fixed !important;
    inset:0 !important;
    width:100vw !important;
    height:100vh !important;
    height:100dvh !important;
    min-height:100vh !important;
    min-height:100dvh !important;
    max-height:100dvh !important;
    z-index:600 !important;
    padding:
      calc(env(safe-area-inset-top,0px) + 78px)
      24px
      calc(env(safe-area-inset-bottom,0px) + 26px) !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    overflow:hidden !important;
    border:0 !important;
    border-radius:0 !important;
    background:
      radial-gradient(circle at 82% 10%,rgba(47,128,237,.22),transparent 31%),
      radial-gradient(circle at 12% 90%,rgba(120,216,196,.12),transparent 28%),
      linear-gradient(145deg,#050b13,#07111d 52%,#0b1b2c) !important;
    opacity:0 !important;
    visibility:hidden !important;
    pointer-events:none !important;
    transform:none !important;
    transition:opacity .22s ease, visibility .22s ease !important;
  }

  .fullscreen-mobile-menu.open,
  .modern-mobile-menu.fullscreen-mobile-menu.open,
  .mobile-menu.fullscreen-mobile-menu.open{
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
  }

  .fullscreen-menu-inner{
    width:min(360px,100%) !important;
    height:auto !important;
    max-height:none !important;
    overflow:hidden !important;
    display:grid !important;
    align-content:center !important;
    justify-items:stretch !important;
    gap:14px !important;
    padding:0 !important;
    text-align:left !important;
  }

  .fullscreen-menu-label{
    display:block !important;
    margin:0 0 3px !important;
    color:rgba(255,255,255,.44) !important;
    font-size:9.5px !important;
    line-height:1 !important;
    font-weight:900 !important;
    letter-spacing:.22em !important;
    text-transform:uppercase !important;
    text-align:left !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    width:100% !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    justify-content:center !important;
    gap:7px !important;
    overflow:hidden !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    display:block !important;
    width:100% !important;
    min-height:auto !important;
    height:auto !important;
    padding:0 0 0 14px !important;
    margin:0 !important;
    border:0 !important;
    border-radius:0 !important;
    background:transparent !important;
    box-shadow:none !important;
    color:rgba(255,255,255,.88) !important;
    font-size:clamp(15px,4.05vw,19px) !important;
    line-height:1.14 !important;
    font-weight:780 !important;
    letter-spacing:-.025em !important;
    white-space:nowrap !important;
    text-align:left !important;
    position:relative !important;
  }

  .fullscreen-mobile-menu nav a::before,
  .modern-mobile-menu.fullscreen-mobile-menu nav a::before,
  .mobile-menu.fullscreen-mobile-menu nav a::before{
    content:"" !important;
    position:absolute !important;
    left:0 !important;
    top:.48em !important;
    width:5px !important;
    height:5px !important;
    border-radius:50% !important;
    background:rgba(139,189,255,.42) !important;
  }

  .fullscreen-mobile-menu nav a.active,
  .modern-mobile-menu.fullscreen-mobile-menu nav a.active,
  .mobile-menu.fullscreen-mobile-menu nav a.active{
    color:#8bbdff !important;
  }

  .fullscreen-mobile-menu nav a.active::before,
  .modern-mobile-menu.fullscreen-mobile-menu nav a.active::before,
  .mobile-menu.fullscreen-mobile-menu nav a.active::before{
    background:#8bbdff !important;
  }

  .fullscreen-menu-cta{
    justify-self:start !important;
    margin-top:4px !important;
    min-height:auto !important;
    padding:0 !important;
    border:0 !important;
    background:transparent !important;
    color:#8bbdff !important;
    font-size:13px !important;
    line-height:1.1 !important;
    font-weight:900 !important;
    letter-spacing:-.01em !important;
    box-shadow:none !important;
  }

  .mobile-menu-close{
    position:fixed !important;
    top:calc(env(safe-area-inset-top,0px) + 12px) !important;
    right:14px !important;
    z-index:900 !important;
    width:48px !important;
    height:48px !important;
    display:grid !important;
    place-items:center !important;
    pointer-events:auto !important;
    border:0 !important;
    border-radius:999px !important;
    background:rgba(255,255,255,.10) !important;
    color:#fff !important;
    font-size:34px !important;
    line-height:1 !important;
    font-weight:300 !important;
    box-shadow:0 12px 34px rgba(0,0,0,.22) !important;
    -webkit-tap-highlight-color:transparent !important;
  }

  body.menu-open .mobile-header{
    z-index:650 !important;
    background:transparent !important;
    border-bottom-color:transparent !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
  }

  body.menu-open .mobile-logo img{
    filter:brightness(0) invert(1) drop-shadow(0 10px 24px rgba(0,0,0,.35)) !important;
  }

  body.menu-open .premium-menu-btn{
    opacity:0 !important;
    pointer-events:none !important;
  }
}

@media(max-width:390px){
  .fullscreen-menu-inner{
    width:min(330px,100%) !important;
    gap:12px !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:6px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(14px,3.9vw,17px) !important;
    line-height:1.12 !important;
  }
}

@media(max-height:720px){
  .fullscreen-mobile-menu,
  .modern-mobile-menu.fullscreen-mobile-menu,
  .mobile-menu.fullscreen-mobile-menu{
    padding-top:calc(env(safe-area-inset-top,0px) + 62px) !important;
    padding-bottom:calc(env(safe-area-inset-bottom,0px) + 16px) !important;
  }

  .fullscreen-menu-inner{
    gap:9px !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:4px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(12px,3.15vh,15px) !important;
    line-height:1.06 !important;
    padding-left:12px !important;
  }

  .fullscreen-menu-label{
    display:none !important;
  }

  .fullscreen-menu-cta{
    font-size:11.5px !important;
  }
}

@media(max-height:620px){
  .fullscreen-menu-inner{
    gap:6px !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:3px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(11px,2.85vh,13px) !important;
    line-height:1.04 !important;
  }

  .fullscreen-menu-cta{
    display:none !important;
  }
}


/* CLEAN PRO MOBILE MENU: readable vertical list, immediate close, no active leftover */
@media(max-width:1100px){
  html.menu-lock,
  body.menu-lock{
    overflow:hidden !important;
    height:100% !important;
    overscroll-behavior:none !important;
  }

  .fullscreen-mobile-menu,
  .modern-mobile-menu.fullscreen-mobile-menu,
  .mobile-menu.fullscreen-mobile-menu{
    position:fixed !important;
    inset:0 !important;
    width:100vw !important;
    height:100vh !important;
    height:100dvh !important;
    min-height:100vh !important;
    min-height:100dvh !important;
    max-height:100dvh !important;
    z-index:700 !important;
    padding:
      calc(env(safe-area-inset-top,0px) + 82px)
      26px
      calc(env(safe-area-inset-bottom,0px) + 28px) !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    overflow:hidden !important;
    border:0 !important;
    border-radius:0 !important;
    background:
      radial-gradient(circle at 82% 10%,rgba(47,128,237,.22),transparent 31%),
      radial-gradient(circle at 12% 90%,rgba(120,216,196,.12),transparent 28%),
      linear-gradient(145deg,#050b13,#07111d 52%,#0b1b2c) !important;
    opacity:0 !important;
    visibility:hidden !important;
    pointer-events:none !important;
    transform:none !important;
    transition:opacity .22s ease, visibility .22s ease !important;
  }

  .fullscreen-mobile-menu.open,
  .modern-mobile-menu.fullscreen-mobile-menu.open,
  .mobile-menu.fullscreen-mobile-menu.open{
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
  }

  .fullscreen-menu-inner{
    width:min(380px,100%) !important;
    max-height:none !important;
    overflow:hidden !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:flex-start !important;
    justify-content:center !important;
    gap:18px !important;
    padding:0 !important;
    text-align:left !important;
  }

  .fullscreen-menu-label{
    display:block !important;
    margin:0 !important;
    color:rgba(255,255,255,.46) !important;
    font-size:10px !important;
    line-height:1 !important;
    font-weight:900 !important;
    letter-spacing:.22em !important;
    text-transform:uppercase !important;
    text-align:left !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    width:100% !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    justify-content:center !important;
    gap:9px !important;
    overflow:hidden !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    display:block !important;
    width:100% !important;
    min-height:auto !important;
    height:auto !important;
    padding:0 !important;
    margin:0 !important;
    border:0 !important;
    border-radius:0 !important;
    background:transparent !important;
    box-shadow:none !important;
    color:rgba(255,255,255,.90) !important;
    font-size:clamp(18px,4.95vw,24px) !important;
    line-height:1.16 !important;
    font-weight:760 !important;
    letter-spacing:-.035em !important;
    white-space:nowrap !important;
    text-align:left !important;
    position:relative !important;
    transform:none !important;
  }

  .fullscreen-mobile-menu nav a::before,
  .modern-mobile-menu.fullscreen-mobile-menu nav a::before,
  .mobile-menu.fullscreen-mobile-menu nav a::before{
    display:none !important;
    content:none !important;
  }

  .fullscreen-mobile-menu nav a.active,
  .modern-mobile-menu.fullscreen-mobile-menu nav a.active,
  .mobile-menu.fullscreen-mobile-menu nav a.active,
  .fullscreen-mobile-menu nav a:hover,
  .modern-mobile-menu.fullscreen-mobile-menu nav a:hover,
  .mobile-menu.fullscreen-mobile-menu nav a:hover{
    color:rgba(255,255,255,.90) !important;
    background:transparent !important;
    border:0 !important;
    transform:none !important;
  }

  .fullscreen-menu-cta{
    justify-self:start !important;
    margin-top:2px !important;
    min-height:36px !important;
    padding:0 16px !important;
    border-radius:999px !important;
    background:rgba(255,255,255,.10) !important;
    border:1px solid rgba(255,255,255,.16) !important;
    color:#fff !important;
    font-size:13px !important;
    line-height:1 !important;
    font-weight:900 !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    box-shadow:none !important;
  }

  .mobile-menu-close{
    position:fixed !important;
    top:calc(env(safe-area-inset-top,0px) + 12px) !important;
    right:14px !important;
    z-index:950 !important;
    width:48px !important;
    height:48px !important;
    display:grid !important;
    place-items:center !important;
    pointer-events:auto !important;
    touch-action:manipulation !important;
    border:0 !important;
    border-radius:999px !important;
    background:rgba(255,255,255,.11) !important;
    color:#fff !important;
    font-size:34px !important;
    line-height:1 !important;
    font-weight:300 !important;
    box-shadow:0 12px 34px rgba(0,0,0,.22) !important;
    -webkit-tap-highlight-color:transparent !important;
  }

  body.menu-open .mobile-header{
    z-index:760 !important;
    background:transparent !important;
    border-bottom-color:transparent !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
  }

  body.menu-open .mobile-logo img{
    filter:brightness(0) invert(1) drop-shadow(0 10px 24px rgba(0,0,0,.35)) !important;
  }

  body.menu-open .premium-menu-btn{
    opacity:0 !important;
    pointer-events:none !important;
  }
}

@media(max-width:390px){
  .fullscreen-menu-inner{
    width:min(340px,100%) !important;
    gap:15px !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:8px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(17px,4.75vw,21px) !important;
    line-height:1.13 !important;
  }
}

@media(max-height:720px){
  .fullscreen-mobile-menu,
  .modern-mobile-menu.fullscreen-mobile-menu,
  .mobile-menu.fullscreen-mobile-menu{
    padding-top:calc(env(safe-area-inset-top,0px) + 62px) !important;
    padding-bottom:calc(env(safe-area-inset-bottom,0px) + 16px) !important;
  }

  .fullscreen-menu-inner{
    gap:12px !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:6px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(15px,3.7vh,18px) !important;
    line-height:1.08 !important;
  }

  .fullscreen-menu-cta{
    min-height:31px !important;
    font-size:12px !important;
  }
}

@media(max-height:620px){
  .fullscreen-menu-inner{
    gap:8px !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:4px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    font-size:clamp(13px,3.2vh,16px) !important;
    line-height:1.05 !important;
  }

  .fullscreen-menu-cta{
    min-height:28px !important;
    font-size:11px !important;
  }
}


/* TOUCH-SAFE MOBILE MENU: bigger tap zones, no accidental underlying clicks */
@media(max-width:1100px){
  html.menu-lock,
  body.menu-lock{
    overflow:hidden !important;
    height:100% !important;
    overscroll-behavior:none !important;
  }

  .fullscreen-mobile-menu,
  .modern-mobile-menu.fullscreen-mobile-menu,
  .mobile-menu.fullscreen-mobile-menu{
    position:fixed !important;
    inset:0 !important;
    width:100vw !important;
    height:100vh !important;
    height:100dvh !important;
    min-height:100vh !important;
    min-height:100dvh !important;
    max-height:100dvh !important;
    z-index:700 !important;
    padding:
      calc(env(safe-area-inset-top,0px) + 78px)
      24px
      calc(env(safe-area-inset-bottom,0px) + 22px) !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    overflow:hidden !important;
    border:0 !important;
    border-radius:0 !important;
    background:
      radial-gradient(circle at 82% 10%,rgba(47,128,237,.22),transparent 31%),
      radial-gradient(circle at 12% 90%,rgba(120,216,196,.12),transparent 28%),
      linear-gradient(145deg,#050b13,#07111d 52%,#0b1b2c) !important;
    opacity:0 !important;
    visibility:hidden !important;
    pointer-events:none !important;
    transform:none !important;
    transition:opacity .22s ease, visibility .22s ease !important;
  }

  .fullscreen-mobile-menu.open,
  .modern-mobile-menu.fullscreen-mobile-menu.open,
  .mobile-menu.fullscreen-mobile-menu.open{
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
  }

  .fullscreen-menu-inner{
    width:min(410px,100%) !important;
    max-height:none !important;
    overflow:hidden !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    justify-content:center !important;
    gap:14px !important;
    padding:0 !important;
    text-align:left !important;
  }

  .fullscreen-menu-label{
    display:block !important;
    margin:0 !important;
    color:rgba(255,255,255,.46) !important;
    font-size:10px !important;
    line-height:1 !important;
    font-weight:900 !important;
    letter-spacing:.22em !important;
    text-transform:uppercase !important;
    text-align:left !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    width:100% !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    justify-content:center !important;
    gap:4px !important;
    overflow:hidden !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    width:100% !important;
    min-height:44px !important;
    height:44px !important;
    padding:0 2px !important;
    margin:0 !important;
    border:0 !important;
    border-radius:0 !important;
    background:transparent !important;
    box-shadow:none !important;
    color:rgba(255,255,255,.92) !important;
    font-size:clamp(20px,5.3vw,26px) !important;
    line-height:1 !important;
    font-weight:760 !important;
    letter-spacing:-.04em !important;
    white-space:nowrap !important;
    text-align:left !important;
    position:relative !important;
    transform:none !important;
    -webkit-tap-highlight-color:rgba(139,189,255,.12) !important;
    touch-action:manipulation !important;
  }

  .fullscreen-mobile-menu nav a::before,
  .modern-mobile-menu.fullscreen-mobile-menu nav a::before,
  .mobile-menu.fullscreen-mobile-menu nav a::before{
    display:none !important;
    content:none !important;
  }

  .fullscreen-mobile-menu nav a.active,
  .modern-mobile-menu.fullscreen-mobile-menu nav a.active,
  .mobile-menu.fullscreen-mobile-menu nav a.active,
  .fullscreen-mobile-menu nav a:hover,
  .modern-mobile-menu.fullscreen-mobile-menu nav a:hover,
  .mobile-menu.fullscreen-mobile-menu nav a:hover{
    color:rgba(255,255,255,.92) !important;
    background:transparent !important;
    border:0 !important;
    transform:none !important;
  }

  .fullscreen-menu-cta{
    display:none !important;
  }

  .mobile-menu-close{
    position:fixed !important;
    top:calc(env(safe-area-inset-top,0px) + 12px) !important;
    right:14px !important;
    z-index:950 !important;
    width:52px !important;
    height:52px !important;
    display:grid !important;
    place-items:center !important;
    pointer-events:auto !important;
    touch-action:manipulation !important;
    border:0 !important;
    border-radius:999px !important;
    background:rgba(255,255,255,.11) !important;
    color:#fff !important;
    font-size:36px !important;
    line-height:1 !important;
    font-weight:300 !important;
    box-shadow:0 12px 34px rgba(0,0,0,.22) !important;
    -webkit-tap-highlight-color:transparent !important;
  }

  body.menu-open .mobile-header{
    z-index:760 !important;
    background:transparent !important;
    border-bottom-color:transparent !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
  }

  body.menu-open .mobile-logo img{
    filter:brightness(0) invert(1) drop-shadow(0 10px 24px rgba(0,0,0,.35)) !important;
  }

  body.menu-open .premium-menu-btn{
    opacity:0 !important;
    pointer-events:none !important;
  }

  section,
  .section,
  .hero,
  .journey,
  .contact-section,
  .pro-module-section{
    scroll-margin-top:78px !important;
  }
}

@media(max-height:760px){
  .fullscreen-menu-inner{
    gap:10px !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:2px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    min-height:39px !important;
    height:39px !important;
    font-size:clamp(17px,4.35vh,21px) !important;
  }

  .fullscreen-menu-label{
    display:none !important;
  }
}

@media(max-height:660px){
  .fullscreen-mobile-menu,
  .modern-mobile-menu.fullscreen-mobile-menu,
  .mobile-menu.fullscreen-mobile-menu{
    padding-top:calc(env(safe-area-inset-top,0px) + 62px) !important;
    padding-bottom:calc(env(safe-area-inset-bottom,0px) + 12px) !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    min-height:35px !important;
    height:35px !important;
    font-size:clamp(15px,3.65vh,18px) !important;
  }

  .mobile-menu-close{
    width:46px !important;
    height:46px !important;
    font-size:32px !important;
  }
}


/* EXACT MOBILE MENU FIX: X clickable + exact section navigation */
@media(max-width:1100px){
  html.menu-lock,
  body.menu-lock{
    overflow:hidden !important;
    height:100% !important;
    overscroll-behavior:none !important;
  }

  .fullscreen-mobile-menu,
  .modern-mobile-menu.fullscreen-mobile-menu,
  .mobile-menu.fullscreen-mobile-menu{
    position:fixed !important;
    inset:0 !important;
    width:100vw !important;
    height:100vh !important;
    height:100dvh !important;
    min-height:100vh !important;
    min-height:100dvh !important;
    max-height:100dvh !important;
    z-index:5000 !important;
    padding:
      calc(env(safe-area-inset-top,0px) + 74px)
      26px
      calc(env(safe-area-inset-bottom,0px) + 24px) !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    overflow:hidden !important;
    border:0 !important;
    border-radius:0 !important;
    background:
      radial-gradient(circle at 82% 10%,rgba(47,128,237,.22),transparent 31%),
      radial-gradient(circle at 12% 90%,rgba(120,216,196,.12),transparent 28%),
      linear-gradient(145deg,#050b13,#07111d 52%,#0b1b2c) !important;
    opacity:0 !important;
    visibility:hidden !important;
    pointer-events:none !important;
    transform:none !important;
    transition:opacity .22s ease, visibility .22s ease !important;
  }

  .fullscreen-mobile-menu.open,
  .modern-mobile-menu.fullscreen-mobile-menu.open,
  .mobile-menu.fullscreen-mobile-menu.open{
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
  }

  .fullscreen-menu-inner{
    width:min(420px,100%) !important;
    max-height:none !important;
    overflow:hidden !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    justify-content:center !important;
    gap:14px !important;
    padding:0 !important;
    text-align:left !important;
  }

  .fullscreen-menu-label{
    display:block !important;
    margin:0 !important;
    color:rgba(255,255,255,.46) !important;
    font-size:10px !important;
    line-height:1 !important;
    font-weight:900 !important;
    letter-spacing:.22em !important;
    text-transform:uppercase !important;
    text-align:left !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    width:100% !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    justify-content:center !important;
    gap:5px !important;
    overflow:hidden !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    width:100% !important;
    min-height:42px !important;
    height:42px !important;
    padding:0 !important;
    margin:0 !important;
    border:0 !important;
    border-radius:0 !important;
    background:transparent !important;
    box-shadow:none !important;
    color:rgba(255,255,255,.92) !important;
    font-size:clamp(20px,5.2vw,25px) !important;
    line-height:1 !important;
    font-weight:760 !important;
    letter-spacing:-.04em !important;
    white-space:nowrap !important;
    text-align:left !important;
    position:relative !important;
    transform:none !important;
    -webkit-tap-highlight-color:rgba(139,189,255,.10) !important;
    touch-action:manipulation !important;
  }

  .fullscreen-mobile-menu nav a::before,
  .modern-mobile-menu.fullscreen-mobile-menu nav a::before,
  .mobile-menu.fullscreen-mobile-menu nav a::before{
    display:none !important;
    content:none !important;
  }

  .fullscreen-mobile-menu nav a.active,
  .modern-mobile-menu.fullscreen-mobile-menu nav a.active,
  .mobile-menu.fullscreen-mobile-menu nav a.active,
  .fullscreen-mobile-menu nav a:hover,
  .modern-mobile-menu.fullscreen-mobile-menu nav a:hover,
  .mobile-menu.fullscreen-mobile-menu nav a:hover{
    color:rgba(255,255,255,.92) !important;
    background:transparent !important;
    border:0 !important;
    transform:none !important;
  }

  .fullscreen-menu-cta{
    display:none !important;
  }

  .mobile-menu-close{
    position:fixed !important;
    top:calc(env(safe-area-inset-top,0px) + 12px) !important;
    right:14px !important;
    z-index:7000 !important;
    width:54px !important;
    height:54px !important;
    display:grid !important;
    place-items:center !important;
    pointer-events:auto !important;
    touch-action:manipulation !important;
    border:0 !important;
    border-radius:999px !important;
    background:rgba(255,255,255,.13) !important;
    color:#fff !important;
    font-size:38px !important;
    line-height:1 !important;
    font-weight:300 !important;
    box-shadow:0 12px 34px rgba(0,0,0,.22) !important;
    -webkit-tap-highlight-color:transparent !important;
  }

  body.menu-open .mobile-header{
    z-index:100 !important;
    pointer-events:none !important;
    background:transparent !important;
    border-bottom-color:transparent !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
  }

  body.menu-open .premium-menu-btn{
    opacity:0 !important;
    pointer-events:none !important;
  }

  section,
  .section,
  .hero,
  .journey,
  .contact-section,
  .pro-module-section{
    scroll-margin-top:76px !important;
  }
}

@media(max-height:760px){
  .fullscreen-menu-inner{
    gap:10px !important;
  }

  .fullscreen-mobile-menu nav,
  .modern-mobile-menu.fullscreen-mobile-menu nav,
  .mobile-menu.fullscreen-mobile-menu nav{
    gap:2px !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    min-height:38px !important;
    height:38px !important;
    font-size:clamp(17px,4.25vh,21px) !important;
  }

  .fullscreen-menu-label{
    display:none !important;
  }
}

@media(max-height:660px){
  .fullscreen-mobile-menu,
  .modern-mobile-menu.fullscreen-mobile-menu,
  .mobile-menu.fullscreen-mobile-menu{
    padding-top:calc(env(safe-area-inset-top,0px) + 58px) !important;
    padding-bottom:calc(env(safe-area-inset-bottom,0px) + 10px) !important;
  }

  .fullscreen-mobile-menu nav a,
  .modern-mobile-menu.fullscreen-mobile-menu nav a,
  .mobile-menu.fullscreen-mobile-menu nav a{
    min-height:33px !important;
    height:33px !important;
    font-size:clamp(14px,3.35vh,17px) !important;
  }

  .mobile-menu-close{
    width:48px !important;
    height:48px !important;
    font-size:34px !important;
  }
}


/* SMTP admin status + mobile number line */
.smtp-status-box{
  margin:12px 0 18px;
  padding:14px 16px;
  border-radius:16px;
  background:#fff8e6;
  border:1px solid rgba(245,158,11,.28);
  display:grid;
  gap:4px;
}
.smtp-status-box.ok{
  background:#ecfdf3;
  border-color:rgba(57,169,107,.28);
}
.smtp-status-box strong{
  color:#07111d;
}
.smtp-status-box span{
  color:#334155;
  font-weight:800;
  word-break:break-word;
}
.smtp-status-box small{
  color:#64748b;
}
.smtp-actions{
  display:grid;
  gap:10px;
  margin-top:16px;
}
.contact-lines [hidden],
.email-modal-info [hidden]{
  display:none !important;
}


/* IONOS SMTP help box */
.smtp-ionos-hint{
  margin:12px 0 18px;
  padding:16px;
  border-radius:18px;
  background:#eef6ff;
  border:1px solid rgba(47,128,237,.18);
  display:grid;
  gap:6px;
}
.smtp-ionos-hint h3{
  margin:0 0 4px;
  color:#07111d;
}
.smtp-ionos-hint p{
  margin:0;
  color:#334155;
  font-size:.92rem;
  line-height:1.45;
}


/* Professional offer center in admin */
.offer-admin-details{
  background:linear-gradient(180deg,#ffffff,#f6f9fd) !important;
  border:1px solid rgba(24,95,216,.14) !important;
  box-shadow:0 18px 50px rgba(7,17,29,.08) !important;
}

.offer-admin-details summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:4px 2px 12px;
  font-size:1.05rem;
  color:#07111d;
}

.offer-admin-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px;
  border-radius:18px;
  background:#07111d;
  color:#fff;
  margin:8px 0 16px;
}

.offer-admin-header strong{
  display:block;
  font-size:1.05rem;
}

.offer-admin-header span{
  display:block;
  color:rgba(255,255,255,.72);
  font-size:.88rem;
  margin-top:3px;
}

.offer-admin-header em{
  display:block;
  color:#ffb4b4;
  font-style:normal;
  font-size:.86rem;
  margin-top:4px;
}

.offer-admin-grid textarea,
.offer-admin-grid input{
  background:#fff !important;
}

.offer-admin-preview-note{
  margin-top:14px;
  padding:14px 16px;
  border-radius:16px;
  background:#eef6ff;
  border:1px solid rgba(47,128,237,.15);
  display:grid;
  gap:4px;
}

.offer-admin-preview-note strong{
  color:#07111d;
}

.offer-admin-preview-note span{
  color:#425466;
  line-height:1.45;
}

.offer-admin-actions{
  gap:8px !important;
  flex-wrap:wrap;
}

.message-card.offer_created{
  border-left-color:#185fd8 !important;
}

.message-card .attachment-list a{
  background:#eef6ff;
  border:1px solid rgba(47,128,237,.12);
  color:#185fd8;
}

@media(max-width:760px){
  .offer-admin-header{
    display:grid;
  }

  .offer-admin-actions .button{
    width:100%;
  }
}


/* SMTP 535 help */
.smtp-535-help{
  margin:12px 0 18px;
  padding:16px;
  border-radius:18px;
  background:#fff7ed;
  border:1px solid rgba(249,115,22,.22);
  display:grid;
  gap:6px;
}
.smtp-535-help h3{
  margin:0 0 4px;
  color:#7c2d12;
}
.smtp-535-help p{
  margin:0;
  color:#431407;
  font-size:.92rem;
  line-height:1.45;
}
.smtp-admin-card small{
  color:#64748b;
  font-weight:750;
}


/* SMTP auth normalized display */
.smtp-auth-normalized{
  margin:12px 0 18px;
  padding:14px 16px;
  border-radius:18px;
  background:#eef6ff;
  border:1px solid rgba(47,128,237,.18);
  display:grid;
  gap:6px;
}
.smtp-auth-normalized strong{
  color:#07111d;
}
.smtp-auth-normalized code{
  display:inline-block;
  width:max-content;
  max-width:100%;
  overflow:auto;
  padding:8px 10px;
  border-radius:10px;
  background:#07111d;
  color:#fff;
}
.smtp-auth-normalized span{
  color:#425466;
  font-size:.92rem;
  line-height:1.45;
}


/* Offer positions editor */
.offer-position-editor{
  grid-column:1/-1;
  margin:18px 0;
  padding:16px;
  border-radius:22px;
  background:#f7faff;
  border:1px solid rgba(47,128,237,.15);
  display:grid;
  gap:12px;
}
.offer-position-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.offer-position-head strong{
  display:block;
  color:#07111d;
  font-size:1.05rem;
}
.offer-position-head span{
  display:block;
  color:#64748b;
  font-size:.88rem;
  margin-top:2px;
}
.offer-position-row{
  display:grid;
  grid-template-columns:1.5fr .65fr .75fr .9fr;
  gap:10px;
  padding:12px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(7,17,29,.08);
}
.offer-position-row .wide{
  grid-column:1/-1;
}
.offer-position-row label{
  gap:6px;
}
.offer-position-row input,
.offer-position-row textarea{
  background:#fbfdff !important;
}
@media(max-width:900px){
  .offer-position-row{
    grid-template-columns:1fr;
  }
}


/* Dynamic offer positions */
.offer-position-list{
  display:grid;
  gap:12px;
}
.offer-position-summary{
  width:max-content;
  max-width:100%;
  padding:9px 12px;
  border-radius:999px;
  background:#07111d;
  color:#fff;
  font-size:.86rem;
  font-weight:850;
}
.offer-position-remove{
  grid-column:1/-1;
  justify-self:start;
  border:1px solid rgba(239,68,68,.18);
  background:#fff5f5;
  color:#b91c1c;
  border-radius:999px;
  padding:9px 13px;
  font-weight:850;
  cursor:pointer;
}
.offer-position-remove:hover{
  background:#fee2e2;
}
.offer-position-head .button{
  white-space:nowrap;
}
@media(max-width:760px){
  .offer-position-head{
    display:grid;
    align-items:start;
  }
  .offer-position-head .button,
  .offer-position-remove{
    width:100%;
  }
}


/* All phone numbers + modern phone overlay */
.footer-phone-lines{
  margin-top:10px !important;
  display:grid;
  gap:4px;
  color:rgba(255,255,255,.72);
  font-size:.92rem;
}
.footer-phone-lines strong{
  color:#fff;
}
.footer-phone-lines [hidden]{
  display:none !important;
}

.phone-dialog{
  width:min(620px,calc(100vw - 28px));
  border:0;
  padding:0;
  border-radius:28px;
  background:transparent;
  color:#07111d;
  overflow:visible;
}
.phone-dialog::backdrop{
  background:rgba(3,8,15,.68);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}
.phone-dialog-card{
  position:relative;
  padding:30px;
  border-radius:28px;
  background:
    radial-gradient(circle at 85% 0%,rgba(47,128,237,.14),transparent 34%),
    linear-gradient(180deg,#ffffff,#f6f9fd);
  box-shadow:0 32px 100px rgba(7,17,29,.28);
  border:1px solid rgba(255,255,255,.8);
}
.phone-close{
  position:absolute !important;
  top:12px !important;
  right:12px !important;
  z-index:5 !important;
  background:#07111d !important;
  color:#fff !important;
  border-radius:999px !important;
  width:44px !important;
  height:44px !important;
}
.phone-dialog-head{
  display:grid;
  gap:10px;
  padding-right:42px;
}
.phone-dialog-head img{
  width:190px;
  max-width:65%;
  height:auto;
  display:block;
}
.phone-dialog-head h2{
  margin:0;
  max-width:460px;
  font-size:clamp(28px,5vw,46px);
  line-height:.98;
  letter-spacing:-.055em;
}
.phone-dialog-head p{
  margin:0;
  max-width:480px;
  color:#526174;
  line-height:1.55;
}
.phone-dialog-options{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-top:24px;
}
.phone-option{
  display:grid;
  gap:8px;
  padding:20px;
  border-radius:22px;
  text-decoration:none;
  background:#07111d;
  color:#fff;
  box-shadow:0 18px 45px rgba(7,17,29,.16);
}
.phone-option:nth-child(2){
  background:#185fd8;
}
.phone-option small{
  color:rgba(255,255,255,.68);
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.phone-option strong{
  font-size:1.35rem;
  letter-spacing:-.035em;
  color:#fff;
}
.phone-option span{
  width:max-content;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  color:#fff;
  font-size:.86rem;
  font-weight:900;
}
.phone-dialog-footer{
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid #e5edf5;
  display:flex;
  gap:10px 18px;
  flex-wrap:wrap;
  color:#64748b;
  font-size:.92rem;
}
.phone-dialog [hidden]{
  display:none !important;
}
@media(max-width:680px){
  .phone-dialog-card{
    padding:24px;
  }
  .phone-dialog-options{
    grid-template-columns:1fr;
  }
  .phone-option{
    padding:18px;
  }
}

/* Mobile-first Admin UX upgrade */
.admin-mobile-bar,
.admin-sidebar-mobile-head,
.admin-drawer-backdrop{
  display:none;
}

.admin-pro-sidebar nav a.is-active,
.admin-pro-sidebar nav a:focus-visible,
.admin-preview-link:focus-visible{
  background:#ffffff;
  color:#07111d;
  outline:0;
}

.admin-pro-card,
.admin-pro-card *{
  box-sizing:border-box;
}

.admin-pro-card input,
.admin-pro-card select,
.admin-pro-card textarea,
.admin-login-box input{
  font-size:16px;
}

.admin-pro-card input:focus,
.admin-pro-card select:focus,
.admin-pro-card textarea:focus,
.admin-login-box input:focus{
  outline:3px solid rgba(47,128,237,.20);
  border-color:rgba(47,128,237,.58);
}

.message-actions-inline,
.smtp-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
}

.message-card strong,
.dashboard-recent strong,
.admin-pro-card label,
.image-manager-card strong,
.upload-meta strong{
  overflow-wrap:anywhere;
}

.admin-pro-card input,
.admin-pro-card textarea,
.admin-pro-card select,
.message-body,
.message-meta,
.admin-note{
  overflow-wrap:anywhere;
}

@media(max-width:1100px){
  :root{
    --admin-mobile-top:72px;
  }

  html{
    scroll-padding-top:calc(var(--admin-mobile-top) + 12px);
  }

  body.admin-pro-body{
    background:#f3f7fb;
    padding-top:var(--admin-mobile-top);
  }

  body.admin-menu-open{
    overflow:hidden;
  }

  .admin-mobile-bar{
    position:fixed;
    inset:0 0 auto 0;
    z-index:1000;
    min-height:var(--admin-mobile-top);
    padding:10px max(12px, env(safe-area-inset-right)) 10px max(12px, env(safe-area-inset-left));
    display:grid;
    grid-template-columns:auto minmax(0,1fr) auto;
    align-items:center;
    gap:10px;
    background:rgba(255,255,255,.92);
    border-bottom:1px solid rgba(7,17,29,.09);
    box-shadow:0 12px 34px rgba(7,17,29,.12);
    backdrop-filter:blur(18px) saturate(1.18);
    -webkit-backdrop-filter:blur(18px) saturate(1.18);
  }

  .admin-mobile-menu-btn,
  .admin-sidebar-mobile-head button{
    min-height:48px;
    border:0;
    border-radius:16px;
    padding:0 14px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    background:#07111d;
    color:#fff;
    font-weight:900;
    cursor:pointer;
  }

  .admin-mobile-menu-btn span{
    font-size:22px;
    line-height:1;
  }

  .admin-mobile-logo{
    min-width:0;
    display:flex;
    align-items:center;
    justify-content:center;
  }

  .admin-mobile-logo img{
    max-width:min(174px,42vw);
    max-height:44px;
    object-fit:contain;
  }

  .admin-mobile-save{
    min-height:48px !important;
    padding:0 14px !important;
    border-radius:16px !important;
    white-space:nowrap;
  }

  .admin-drawer-backdrop{
    position:fixed;
    inset:0;
    z-index:998;
    display:block;
    background:rgba(4,10,18,.44);
    opacity:0;
    pointer-events:none;
    transition:opacity .22s ease;
  }

  body.admin-menu-open .admin-drawer-backdrop{
    opacity:1;
    pointer-events:auto;
  }

  .admin-pro-layout{
    display:block;
    min-height:calc(100vh - var(--admin-mobile-top));
  }

  .admin-pro-sidebar{
    position:fixed !important;
    z-index:999;
    top:0;
    left:0;
    bottom:0;
    width:min(88vw,360px);
    height:100dvh !important;
    padding:18px;
    padding-top:max(18px, env(safe-area-inset-top));
    transform:translateX(-105%);
    transition:transform .24s ease;
    border-radius:0 28px 28px 0;
    box-shadow:28px 0 70px rgba(0,0,0,.26);
    overscroll-behavior:contain;
  }

  body.admin-menu-open .admin-pro-sidebar{
    transform:translateX(0);
  }

  .admin-sidebar-mobile-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    margin-bottom:14px;
    padding-bottom:12px;
    border-bottom:1px solid rgba(255,255,255,.12);
  }

  .admin-sidebar-mobile-head strong{
    color:#fff;
    font-size:1.05rem;
  }

  .admin-sidebar-mobile-head button{
    width:46px;
    min-height:46px;
    padding:0;
    border:1px solid rgba(255,255,255,.18);
    background:rgba(255,255,255,.08);
    font-size:30px;
    line-height:1;
  }

  .admin-pro-sidebar img{
    width:190px;
    margin-bottom:10px;
  }

  .admin-pro-sidebar p{
    margin-bottom:12px;
    line-height:1.45;
  }

  .admin-pro-sidebar nav{
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
    margin:14px 0;
  }

  .admin-pro-sidebar nav a,
  .admin-preview-link{
    min-height:48px;
    border-radius:16px;
    padding:0 14px;
    margin:0 !important;
    font-size:.96rem;
  }

  .admin-pro-sidebar .button.full,
  .admin-preview-link{
    width:100%;
    justify-content:center;
  }

  .admin-pro-main{
    padding:14px;
    max-width:100vw;
    overflow:hidden;
  }

  .admin-pro-topbar{
    display:block;
    margin-bottom:14px;
    padding:16px;
    border-radius:22px;
    background:#fff;
    border:1px solid rgba(7,17,29,.08);
    box-shadow:0 14px 40px rgba(7,17,29,.08);
  }

  .admin-pro-topbar h1{
    font-size:clamp(2rem,9vw,3.2rem);
    line-height:.95;
    margin:0 0 8px;
  }

  .admin-pro-topbar p{
    margin:0 0 14px;
    line-height:1.45;
    color:#536174;
  }

  .admin-pro-topbar > .button{
    width:100%;
    min-height:50px;
  }

  .admin-pro-card{
    border-radius:22px;
    padding:16px;
    margin-bottom:14px;
    box-shadow:0 14px 42px rgba(7,17,29,.08);
    scroll-margin-top:calc(var(--admin-mobile-top) + 14px);
  }

  .admin-pro-card h2{
    font-size:clamp(1.55rem,7vw,2.25rem);
    line-height:1;
    margin-bottom:14px;
  }

  .admin-grid,
  .image-editor-grid,
  .admin-feature-grid,
  .service-admin-card,
  .dashboard-grid,
  .image-manager-grid,
  .message-filter{
    grid-template-columns:1fr !important;
  }

  .dashboard-grid{
    display:grid;
    gap:10px;
  }

  .dashboard-stat{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    padding:16px;
    text-decoration:none;
  }

  .dashboard-stat strong{
    font-size:2.1rem;
    flex:0 0 auto;
  }

  .dashboard-stat span{
    text-align:right;
  }

  .dashboard-recent div{
    display:grid;
    gap:4px;
  }

  .dashboard-recent span{
    line-height:1.4;
  }

  .admin-pro-card label{
    display:grid;
    gap:8px;
    font-size:.98rem;
    line-height:1.3;
  }

  .admin-pro-card input,
  .admin-pro-card select,
  .admin-pro-card textarea{
    min-height:52px;
    margin-top:0;
    border-radius:16px;
    padding:14px;
  }

  .admin-pro-card textarea{
    min-height:132px;
  }

  .checkline{
    grid-template-columns:auto 1fr !important;
    display:grid !important;
    align-items:start !important;
    gap:11px !important;
    padding:12px;
    border-radius:16px;
    background:#f7f9fc;
    border:1px solid rgba(7,17,29,.08);
  }

  .checkline input{
    width:22px !important;
    height:22px !important;
    min-height:22px !important;
    margin:1px 0 0 !important;
  }

  .button,
  .admin-pro-card button,
  .admin-pro-card .button,
  .message-filter .button{
    min-height:48px;
    border-radius:16px;
  }

  .message-filter{
    display:grid;
    gap:10px;
    margin-bottom:14px;
  }

  .message-card{
    border-radius:22px;
    padding:14px;
  }

  .message-head{
    display:grid !important;
    gap:12px;
  }

  .message-head > div:first-child strong{
    display:block;
    line-height:1.25;
  }

  .message-head > div:first-child span{
    display:block;
    margin-top:6px;
    line-height:1.45;
    color:#637184;
  }

  .message-actions-inline{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
    width:100%;
  }

  .message-actions-inline .button,
  .message-actions-inline button,
  .message-actions-inline a{
    width:100%;
    min-height:46px;
    padding-inline:10px;
    justify-content:center;
    text-align:center;
  }

  .message-body{
    padding:14px;
    border-radius:18px;
  }

  .attachment-list{
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
  }

  .admin-details{
    border-radius:18px;
    padding:12px;
  }

  .admin-details summary{
    min-height:44px;
    display:flex;
    align-items:center;
  }

  .offer-admin-details summary,
  .offer-admin-header,
  .offer-position-head{
    display:grid !important;
    gap:10px;
  }

  .offer-admin-header .button,
  .offer-position-head .button,
  .offer-position-remove{
    width:100%;
    justify-content:center;
  }

  .offer-position-editor{
    padding:12px;
    border-radius:20px;
  }

  .offer-position-summary{
    width:100%;
    text-align:center;
    border-radius:16px;
    line-height:1.35;
  }

  .offer-position-row{
    grid-template-columns:1fr !important;
    padding:12px;
  }

  .service-admin-card,
  .repeat-editor-card,
  .image-editor-card,
  .admin-feature-grid article{
    padding:14px;
    border-radius:20px;
  }

  .service-admin-preview,
  .image-preview{
    min-height:190px;
  }

  .image-manager-preview{
    height:190px;
  }

  .before-after-admin-preview{
    grid-template-columns:1fr 1fr !important;
  }

  .before-after-admin-preview img{
    height:150px;
  }

  .smtp-ionos-hint,
  .smtp-status-box,
  .smtp-535-help,
  .smtp-auth-normalized{
    border-radius:18px;
    padding:14px;
    overflow-wrap:anywhere;
  }

  .smtp-actions{
    display:grid;
    grid-template-columns:1fr;
    gap:10px;
  }

  .smtp-actions .button{
    width:100%;
  }

  .sticky-save{
    position:sticky;
    bottom:max(12px, env(safe-area-inset-bottom));
    z-index:120;
    min-height:54px;
    border-radius:18px !important;
  }
}

@media(max-width:520px){
  :root{
    --admin-mobile-top:66px;
  }

  .admin-mobile-bar{
    grid-template-columns:auto 1fr auto;
    padding-top:8px;
    padding-bottom:8px;
    gap:7px;
  }

  .admin-mobile-menu-btn{
    min-height:46px;
    width:46px;
    padding:0;
    font-size:0;
  }

  .admin-mobile-menu-btn span{
    font-size:23px;
  }

  .admin-mobile-save{
    min-height:46px !important;
    padding-inline:12px !important;
    font-size:.88rem !important;
  }

  .admin-mobile-logo img{
    max-width:128px;
    max-height:38px;
  }

  .admin-pro-main{
    padding:10px;
  }

  .admin-pro-card,
  .admin-pro-topbar{
    padding:14px;
    border-radius:20px;
  }

  .message-actions-inline{
    grid-template-columns:1fr;
  }

  .dashboard-stat{
    align-items:flex-start;
    display:grid;
  }

  .dashboard-stat span{
    text-align:left;
  }

  .before-after-admin-preview{
    grid-template-columns:1fr !important;
  }

  .before-after-admin-preview img{
    height:190px;
  }
}

@media(max-width:380px){
  .admin-mobile-save{
    font-size:0 !important;
    width:46px;
    padding:0 !important;
  }

  .admin-mobile-save::after{
    content:'✓';
    font-size:20px;
  }

  .admin-mobile-logo img{
    max-width:116px;
  }
}


/* Minimal modern Admin UI refresh */
body.admin-pro-body{
  --admin-bg:#f6f7f9;
  --admin-surface:#ffffff;
  --admin-surface-2:#f9fafb;
  --admin-ink:#111827;
  --admin-muted:#6b7280;
  --admin-soft:#eef2f7;
  --admin-line:#e5e7eb;
  --admin-line-strong:#d6dde8;
  --admin-blue:#2563eb;
  --admin-blue-soft:#eff6ff;
  --admin-green:#0f766e;
  --admin-red:#b42318;
  --admin-radius:18px;
  --admin-radius-sm:12px;
  --admin-shadow:0 1px 2px rgba(16,24,40,.04),0 14px 42px rgba(16,24,40,.055);
  margin:0;
  background:var(--admin-bg);
  color:var(--admin-ink);
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  font-size:15px;
  line-height:1.55;
  letter-spacing:-.012em;
}

body.admin-pro-body a{
  text-decoration:none;
}

body.admin-pro-body p{
  color:var(--admin-muted);
  font-size:.96rem;
  line-height:1.65;
}

body.admin-pro-body .button,
body.admin-pro-body button.button,
body.admin-pro-body label.button,
body.admin-pro-body a.button{
  min-height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border:1px solid var(--admin-line);
  border-radius:12px;
  padding:0 15px;
  background:#fff;
  color:var(--admin-ink);
  font-size:.92rem;
  font-weight:760;
  letter-spacing:-.01em;
  box-shadow:0 1px 1px rgba(16,24,40,.02);
  transition:background .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease,transform .18s ease;
}

body.admin-pro-body .button:hover,
body.admin-pro-body a.button:hover,
body.admin-pro-body button.button:hover,
body.admin-pro-body label.button:hover{
  border-color:#cbd5e1;
  background:#f8fafc;
  transform:translateY(-1px);
}

body.admin-pro-body .button.primary{
  border-color:#111827;
  background:#111827;
  color:#fff;
  box-shadow:0 10px 22px rgba(17,24,39,.12);
}

body.admin-pro-body .button.primary:hover{
  background:#0f172a;
  border-color:#0f172a;
  box-shadow:0 14px 28px rgba(17,24,39,.16);
}

body.admin-pro-body .button.soft{
  background:#f8fafc;
  color:#334155;
}

body.admin-pro-body .button.small{
  min-height:36px;
  border-radius:10px;
  padding:0 12px;
  font-size:.84rem;
}

body.admin-pro-body .button.full{
  width:100%;
}

body.admin-pro-body .button.danger,
body.admin-pro-body .danger.button,
body.admin-pro-body button.danger{
  border-color:#fee4e2 !important;
  background:#fff7f6 !important;
  color:var(--admin-red) !important;
}

.admin-login{
  background:radial-gradient(circle at top,#ffffff 0,#f6f7f9 42%,#eef2f7 100%) !important;
}

.admin-login-box{
  width:min(420px,calc(100vw - 32px)) !important;
  border:1px solid var(--admin-line) !important;
  border-radius:24px !important;
  padding:30px !important;
  box-shadow:var(--admin-shadow) !important;
}

.admin-login-box img{
  width:220px !important;
  margin:0 auto 26px !important;
}

.admin-login-box h1{
  font-size:2rem !important;
  line-height:1.1 !important;
  letter-spacing:-.045em !important;
  text-align:center;
}

.admin-login-box p{
  margin-bottom:22px;
  text-align:center;
}

.admin-pro-layout{
  grid-template-columns:272px minmax(0,1fr);
  min-height:100vh;
}

.admin-pro-sidebar{
  padding:22px 16px;
  background:rgba(255,255,255,.92);
  color:var(--admin-ink);
  border-right:1px solid var(--admin-line);
  box-shadow:none;
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
}

.admin-pro-sidebar img{
  width:188px;
  margin:0 8px 18px;
}

.admin-pro-sidebar p{
  margin:0 8px 18px;
  color:var(--admin-muted);
  font-size:.88rem;
  line-height:1.45;
}

.admin-pro-sidebar nav{
  gap:4px;
  margin:14px 0 18px;
}

.admin-pro-sidebar nav a,
.admin-preview-link{
  min-height:40px;
  margin:0 !important;
  border-radius:12px;
  padding:0 12px;
  background:transparent;
  color:#475569;
  font-size:.92rem;
  font-weight:720;
  letter-spacing:-.01em;
}

.admin-pro-sidebar nav a:hover,
.admin-preview-link:hover{
  background:#f1f5f9;
  color:var(--admin-ink);
}

.admin-pro-sidebar nav a.is-active,
.admin-pro-sidebar nav a:focus-visible,
.admin-preview-link:focus-visible{
  background:var(--admin-blue-soft);
  color:#1d4ed8;
  outline:0;
}

.admin-pro-sidebar .button.primary.full{
  margin-top:6px;
  background:#111827;
  color:#fff;
}

.admin-preview-link{
  border:1px solid transparent;
}

.admin-pro-main{
  width:min(100%,1180px);
  padding:28px;
}

.admin-pro-topbar{
  min-height:96px;
  align-items:center;
  margin-bottom:20px;
  padding:20px 22px;
  border:1px solid var(--admin-line);
  border-radius:var(--admin-radius);
  background:linear-gradient(180deg,#fff,#fbfcfd);
  box-shadow:0 1px 2px rgba(16,24,40,.035);
}

.admin-kicker{
  display:block;
  margin-bottom:6px;
  color:var(--admin-blue);
  font-size:.75rem;
  font-weight:820;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.admin-pro-topbar h1{
  margin:0 0 4px;
  color:var(--admin-ink);
  font-size:clamp(1.9rem,3.2vw,2.75rem);
  line-height:1.05;
  letter-spacing:-.055em;
}

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

.admin-save-status{
  border:1px solid #bbf7d0;
  border-radius:14px;
  background:#f0fdf4;
  color:#166534;
  box-shadow:none;
}

.admin-pro-card{
  margin-bottom:18px;
  padding:22px;
  border:1px solid var(--admin-line);
  border-radius:var(--admin-radius);
  background:var(--admin-surface);
  box-shadow:0 1px 2px rgba(16,24,40,.035);
}

.admin-pro-card:hover{
  border-color:#d8dee8;
}

.admin-pro-card h2{
  max-width:none;
  margin:0 0 18px;
  color:var(--admin-ink);
  font-size:1.35rem;
  line-height:1.2;
  letter-spacing:-.035em;
}

.admin-pro-card h3{
  margin:20px 0 12px;
  color:#1f2937;
  font-size:1rem;
  letter-spacing:-.02em;
}

.admin-grid{
  gap:14px;
}

.admin-pro-card label{
  gap:7px;
  color:#374151;
  font-size:.88rem;
  font-weight:720;
  letter-spacing:-.005em;
}

.admin-pro-card input,
.admin-pro-card select,
.admin-pro-card textarea,
.admin-login-box input{
  min-height:44px;
  margin-top:0;
  border:1px solid var(--admin-line-strong);
  border-radius:12px;
  padding:11px 12px;
  background:#fff;
  color:var(--admin-ink);
  font-size:16px;
  box-shadow:0 1px 1px rgba(16,24,40,.02);
  transition:border-color .18s ease,box-shadow .18s ease,background .18s ease;
}

.admin-pro-card input::placeholder,
.admin-pro-card textarea::placeholder{
  color:#9ca3af;
}

.admin-pro-card input:focus,
.admin-pro-card select:focus,
.admin-pro-card textarea:focus,
.admin-login-box input:focus{
  outline:0;
  border-color:#93c5fd;
  box-shadow:0 0 0 4px rgba(37,99,235,.11);
}

.admin-pro-card textarea{
  min-height:112px;
  line-height:1.55;
}

.admin-note,
.smtp-ionos-hint,
.smtp-status-box,
.smtp-535-help,
.smtp-auth-normalized{
  border:1px solid var(--admin-line) !important;
  border-radius:14px !important;
  background:#f8fafc !important;
  color:#475569 !important;
  box-shadow:none !important;
}

.admin-feature-grid article,
.repeat-editor-card,
.service-admin-card,
.image-editor-card,
.image-manager-card,
.message-card,
.admin-details,
.offer-position-editor,
.offer-position-row{
  border:1px solid var(--admin-line) !important;
  border-radius:16px !important;
  background:#fbfcfd !important;
  box-shadow:none !important;
}

.admin-feature-grid article,
.repeat-editor-card,
.image-editor-card{
  padding:16px;
}

.service-admin-card{
  grid-template-columns:220px minmax(0,1fr);
  gap:16px;
  padding:16px;
}

.service-admin-preview,
.image-preview,
.image-manager-preview{
  border:1px solid var(--admin-line);
  border-radius:14px;
  background:#eef2f7;
}

.message-filter{
  gap:10px;
}

.message-card{
  border-left:1px solid var(--admin-line) !important;
  padding:16px;
}

.message-card.new{
  border-color:#bfdbfe !important;
  background:#f8fbff !important;
}

.message-card.in_progress,
.message-card.offer_created{
  border-color:#c7d2fe !important;
}

.message-card.done{
  border-color:#bbf7d0 !important;
}

.message-head strong{
  color:var(--admin-ink);
  font-size:1rem;
  letter-spacing:-.02em;
}

.message-head span,
.message-meta,
.image-manager-card span,
.admin-feature-grid span,
.upload-meta span{
  color:var(--admin-muted);
  font-size:.86rem;
}

.message-body{
  border:1px solid var(--admin-line);
  border-radius:14px;
  background:#fff;
  color:#1f2937;
}

.dashboard-grid{
  gap:12px;
  margin-bottom:24px;
}

.dashboard-stat{
  padding:18px;
  border:1px solid var(--admin-line);
  border-radius:16px;
  background:#fff;
  color:inherit;
  box-shadow:0 1px 2px rgba(16,24,40,.03);
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;
}

.dashboard-stat:hover{
  border-color:#cbd5e1;
  box-shadow:var(--admin-shadow);
  transform:translateY(-2px);
}

.dashboard-stat strong{
  color:var(--admin-ink);
  font-size:2.35rem;
  line-height:1;
  letter-spacing:-.065em;
}

.dashboard-stat span{
  color:var(--admin-muted);
  font-size:.86rem;
  font-weight:700;
}

.dashboard-recent{
  gap:8px;
}

.dashboard-recent div{
  padding:12px 14px;
  border:1px solid var(--admin-line);
  border-radius:14px;
  background:#fbfcfd;
}

.checkline{
  align-items:flex-start;
  padding:10px 12px;
  border:1px solid var(--admin-line);
  border-radius:14px;
  background:#fbfcfd;
  color:#475569;
}

.checkline input{
  accent-color:var(--admin-blue);
}

.admin-details summary{
  color:var(--admin-ink);
  font-weight:780;
}

.offer-position-head strong,
.offer-admin-header strong,
.image-manager-card strong,
.upload-meta strong{
  color:var(--admin-ink);
  letter-spacing:-.015em;
}

.offer-position-summary{
  border:1px solid #bfdbfe;
  background:#eff6ff;
  color:#1d4ed8;
  font-weight:780;
}

.offer-position-remove{
  min-height:42px;
  border:1px solid #fee4e2;
  border-radius:12px;
  background:#fff7f6;
  color:var(--admin-red);
  font-weight:760;
}

.attachment-list a{
  border:1px solid var(--admin-line);
  background:#fff;
  color:#334155;
}

.sticky-save{
  bottom:18px;
  border-radius:14px !important;
  box-shadow:0 18px 36px rgba(17,24,39,.16) !important;
}

@media(max-width:1100px){
  body.admin-pro-body{
    --admin-mobile-top:64px;
    padding-top:var(--admin-mobile-top);
    background:var(--admin-bg);
  }

  .admin-mobile-bar{
    min-height:var(--admin-mobile-top);
    padding:8px max(12px, env(safe-area-inset-right)) 8px max(12px, env(safe-area-inset-left));
    gap:8px;
    border-bottom:1px solid var(--admin-line);
    background:rgba(255,255,255,.94);
    box-shadow:none;
  }

  .admin-mobile-menu-btn,
  .admin-sidebar-mobile-head button{
    min-height:42px;
    border:1px solid var(--admin-line);
    border-radius:12px;
    padding:0 12px;
    background:#fff;
    color:var(--admin-ink);
    font-size:.9rem;
    font-weight:760;
    box-shadow:none;
  }

  .admin-mobile-menu-btn span{
    font-size:20px;
  }

  .admin-mobile-logo img{
    max-width:min(158px,42vw);
    max-height:36px;
  }

  .admin-mobile-save{
    min-height:42px !important;
    border-radius:12px !important;
    padding-inline:13px !important;
  }

  .admin-drawer-backdrop{
    background:rgba(15,23,42,.28);
    backdrop-filter:blur(2px);
  }

  .admin-pro-sidebar{
    width:min(88vw,342px);
    padding:16px;
    border-radius:0 22px 22px 0;
    background:#fff;
    border-right:1px solid var(--admin-line);
    box-shadow:20px 0 44px rgba(15,23,42,.14);
  }

  .admin-sidebar-mobile-head{
    margin-bottom:12px;
    padding-bottom:12px;
    border-bottom:1px solid var(--admin-line);
  }

  .admin-sidebar-mobile-head strong{
    color:var(--admin-ink);
    font-size:1rem;
  }

  .admin-sidebar-mobile-head button{
    width:42px;
    min-height:42px;
    padding:0;
    background:#f8fafc;
    color:var(--admin-ink);
    font-size:24px;
    line-height:1;
  }

  .admin-pro-sidebar img{
    width:176px;
    margin:2px 8px 12px;
  }

  .admin-pro-sidebar p{
    margin-bottom:12px;
  }

  .admin-pro-sidebar nav{
    gap:4px;
    margin:12px 0 16px;
  }

  .admin-pro-sidebar nav a,
  .admin-preview-link{
    min-height:42px;
    border-radius:12px;
    color:#475569;
  }

  .admin-pro-main{
    width:100%;
    padding:14px;
    overflow:visible;
  }

  .admin-pro-topbar{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    min-height:auto;
    margin-bottom:14px;
    padding:16px;
    border-radius:16px;
    box-shadow:0 1px 2px rgba(16,24,40,.035);
  }

  .admin-pro-topbar h1{
    font-size:clamp(1.5rem,6vw,2rem);
    line-height:1.08;
    margin:0 0 4px;
  }

  .admin-pro-topbar p{
    margin:0;
    font-size:.9rem;
    line-height:1.45;
  }

  .admin-pro-topbar > .button{
    width:auto;
    min-width:94px;
    min-height:42px;
  }

  .admin-pro-card{
    margin-bottom:12px;
    padding:16px;
    border-radius:16px;
    box-shadow:0 1px 2px rgba(16,24,40,.035);
    scroll-margin-top:calc(var(--admin-mobile-top) + 12px);
  }

  .admin-pro-card h2{
    margin-bottom:14px;
    font-size:1.2rem;
    line-height:1.18;
  }

  .admin-pro-card h3{
    font-size:.98rem;
  }

  .admin-grid,
  .image-editor-grid,
  .admin-feature-grid,
  .service-admin-card,
  .dashboard-grid,
  .image-manager-grid,
  .message-filter{
    grid-template-columns:1fr !important;
  }

  .admin-pro-card input,
  .admin-pro-card select,
  .admin-pro-card textarea{
    min-height:46px;
    border-radius:12px;
    padding:12px;
  }

  .admin-pro-card textarea{
    min-height:120px;
  }

  .dashboard-grid{
    gap:8px;
  }

  .dashboard-stat{
    padding:14px;
    border-radius:14px;
  }

  .dashboard-stat strong{
    font-size:1.9rem;
  }

  .dashboard-stat span{
    text-align:right;
  }

  .message-card,
  .message-body,
  .admin-details,
  .offer-position-editor,
  .offer-position-row,
  .service-admin-card,
  .repeat-editor-card,
  .image-editor-card,
  .admin-feature-grid article{
    border-radius:14px !important;
  }

  .message-head{
    gap:10px;
  }

  .message-actions-inline{
    grid-template-columns:1fr 1fr;
    gap:8px;
  }

  .message-actions-inline .button,
  .message-actions-inline button,
  .message-actions-inline a{
    min-height:40px;
    border-radius:11px;
  }

  .offer-position-editor,
  .offer-position-row{
    padding:12px;
  }

  .service-admin-preview,
  .image-preview,
  .image-manager-preview{
    min-height:170px;
    height:auto;
  }

  .sticky-save{
    min-height:50px;
    bottom:max(12px, env(safe-area-inset-bottom));
  }
}

@media(max-width:520px){
  body.admin-pro-body{
    --admin-mobile-top:60px;
  }

  .admin-mobile-bar{
    padding-top:7px;
    padding-bottom:7px;
  }

  .admin-mobile-menu-btn{
    width:42px;
    min-height:42px;
    padding:0;
    font-size:0;
  }

  .admin-mobile-menu-btn span{
    font-size:20px;
  }

  .admin-mobile-save{
    min-height:42px !important;
    padding-inline:12px !important;
    font-size:.86rem !important;
  }

  .admin-mobile-logo img{
    max-width:122px;
    max-height:32px;
  }

  .admin-pro-main{
    padding:10px;
  }

  .admin-pro-topbar{
    display:grid;
    grid-template-columns:1fr;
    gap:12px;
    padding:14px;
  }

  .admin-pro-topbar > .button{
    width:100%;
  }

  .admin-pro-card{
    padding:14px;
  }

  .dashboard-stat{
    display:flex;
    align-items:center;
    justify-content:space-between;
  }

  .dashboard-stat span{
    text-align:right;
  }

  .message-actions-inline{
    grid-template-columns:1fr;
  }
}


/* Complete Admin polish: cleaner desktop + mobile workflow */
body.admin-pro-body{
  --admin-bg:#f7f8fb;
  --admin-surface:#ffffff;
  --admin-surface-2:#fbfcfe;
  --admin-ink:#0f172a;
  --admin-muted:#64748b;
  --admin-line:#e7ebf0;
  --admin-line-strong:#cfd8e3;
  --admin-blue:#1d4ed8;
  --admin-blue-soft:#eef5ff;
  --admin-green:#047857;
  --admin-red:#b42318;
  --admin-radius:20px;
  --admin-shadow:0 1px 2px rgba(15,23,42,.04),0 18px 52px rgba(15,23,42,.055);
}
.admin-pro-layout{grid-template-columns:264px minmax(0,1fr)}
.admin-pro-main{max-width:1540px;width:100%;margin:0 auto;padding:28px clamp(18px,2vw,34px)}
.admin-pro-topbar,.admin-pro-card{border:1px solid var(--admin-line);background:rgba(255,255,255,.94);box-shadow:var(--admin-shadow)}
.admin-pro-topbar{position:sticky;top:16px;z-index:35;padding:18px 20px;border-radius:22px;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.admin-pro-topbar h1{font-size:clamp(1.8rem,2.4vw,2.6rem);letter-spacing:-.055em}
.admin-kicker{font-size:.72rem;letter-spacing:.16em;color:var(--admin-blue);font-weight:850;text-transform:uppercase}
.admin-pro-card{border-radius:22px;padding:clamp(18px,2vw,28px);margin-bottom:18px}
.admin-pro-card h2{font-size:clamp(1.3rem,1.7vw,1.9rem);letter-spacing:-.04em;margin:0 0 16px}
.admin-pro-card h3{font-size:1rem;letter-spacing:-.02em;margin:18px 0 10px;color:var(--admin-ink)}
.admin-pro-card label{font-size:.88rem;font-weight:760;color:#334155;display:grid;gap:8px}
.admin-pro-card input,.admin-pro-card select,.admin-pro-card textarea,.admin-login-box input{border-radius:14px;border:1px solid var(--admin-line-strong);background:#fff;box-shadow:0 1px 0 rgba(15,23,42,.02) inset;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}
.admin-pro-card input:focus,.admin-pro-card select:focus,.admin-pro-card textarea:focus,.admin-login-box input:focus{border-color:#93c5fd;box-shadow:0 0 0 4px rgba(37,99,235,.12);outline:none}
.admin-pro-sidebar{background:rgba(255,255,255,.9);box-shadow:inset -1px 0 0 var(--admin-line);position:sticky;top:0}
.admin-pro-sidebar nav a,.admin-preview-link{background:transparent;color:#526071;font-weight:760;letter-spacing:-.01em;border:1px solid transparent}
.admin-pro-sidebar nav a:hover,.admin-pro-sidebar nav a.is-active,.admin-preview-link:hover{background:#f1f5f9;color:#0f172a;border-color:#e2e8f0}
.dashboard-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.dashboard-stat{padding:18px;border-radius:18px;background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid var(--admin-line);box-shadow:0 1px 2px rgba(15,23,42,.04)}
.dashboard-stat strong{font-size:2.25rem;letter-spacing:-.06em;color:#0f172a}
.dashboard-stat span{color:#64748b;font-weight:760}
.admin-dashboard-tools{display:flex;flex-wrap:wrap;gap:10px;margin:16px 0 4px}
.admin-dashboard-columns{display:grid;grid-template-columns:1.05fr .95fr 1.05fr;gap:14px;margin-top:8px}
.admin-health-list,.dashboard-recent{display:grid;gap:8px}
.admin-health-list div,.dashboard-recent div{display:flex;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:14px;background:#f8fafc;border:1px solid var(--admin-line)}
.admin-health-list strong,.dashboard-recent strong{color:#0f172a;font-weight:800}
.admin-health-list span,.dashboard-recent span{color:#64748b;text-align:right;overflow-wrap:anywhere}
.message-filter{display:grid;grid-template-columns:minmax(220px,1fr) 220px auto auto auto;gap:10px;align-items:end;margin-bottom:14px}
.message-card{background:#fff;border:1px solid var(--admin-line);box-shadow:0 1px 2px rgba(15,23,42,.035);border-radius:20px;padding:18px;margin-bottom:14px}
.message-card.new,.message-card.is-new{background:linear-gradient(180deg,#f8fbff,#fff);border-color:#bfdbfe;box-shadow:inset 4px 0 0 #2563eb,0 1px 2px rgba(15,23,42,.04)}
.message-card.offer_sent{border-color:#a7f3d0;box-shadow:inset 4px 0 0 #10b981,0 1px 2px rgba(15,23,42,.04)}
.message-card.accepted{border-color:#86efac;box-shadow:inset 4px 0 0 #16a34a,0 1px 2px rgba(15,23,42,.04)}
.message-card.declined{border-color:#fecaca;box-shadow:inset 4px 0 0 #ef4444,0 1px 2px rgba(15,23,42,.04)}
.message-head strong{font-size:1rem;line-height:1.35;color:#0f172a}
.message-head span{display:block;margin-top:4px;color:#64748b;font-size:.86rem}
.message-body{background:#f8fafc;border:1px solid var(--admin-line);border-radius:16px;color:#1f2937}
.message-meta{background:transparent!important;border:0!important;padding:0!important;color:#64748b}
.message-actions-inline{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:flex-end}
.admin-details{margin-top:12px;padding:14px;border-radius:18px;background:#fbfcfe;border:1px solid var(--admin-line)}
.admin-details summary{cursor:pointer;font-weight:850;color:#0f172a;list-style:none}
.admin-details summary::-webkit-details-marker{display:none}
.offer-admin-header,.offer-position-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin:14px 0}
.offer-position-editor{padding:14px;border-radius:18px;background:#f8fafc;border:1px solid var(--admin-line);margin:14px 0}
.offer-position-row{background:#fff;border-color:#e2e8f0;border-radius:16px}
.offer-position-summary{background:#0f172a;color:#fff}
.admin-note{background:#f8fafc;border-color:var(--admin-line);color:#64748b}
.image-manager-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.image-manager-card,.repeat-editor-card,.service-admin-card,.image-editor-card,.admin-feature-grid article{box-shadow:none;background:#fbfcfe;border-color:var(--admin-line)}
.sticky-save{box-shadow:0 14px 32px rgba(29,78,216,.18)!important}
@media(max-width:1180px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}.admin-dashboard-columns{grid-template-columns:1fr}.message-filter{grid-template-columns:1fr 1fr}.message-filter .button{width:100%}}
@media(max-width:1100px){.admin-pro-topbar{position:relative;top:auto}.admin-pro-main{padding:14px}.admin-mobile-bar{box-shadow:0 10px 28px rgba(15,23,42,.10)}.admin-pro-sidebar{box-shadow:24px 0 48px rgba(15,23,42,.14)}.offer-admin-header,.offer-position-head{display:grid}.message-head{display:grid}.message-actions-inline{justify-content:flex-start}.message-actions-inline .button,.message-actions-inline button,.message-actions-inline a{flex:1 1 auto}}
@media(max-width:640px){.dashboard-grid,.message-filter{grid-template-columns:1fr}.admin-health-list div,.dashboard-recent div{display:grid}.admin-health-list span,.dashboard-recent span{text-align:left}.admin-pro-card{padding:14px;border-radius:18px}.admin-grid{gap:12px}.offer-admin-actions .button{width:100%}.message-actions-inline{display:grid!important;grid-template-columns:1fr!important}.admin-pro-topbar{padding:14px;border-radius:18px}.admin-pro-topbar .button{width:100%}}


/* SEO landing pages */
.seo-page{max-width:1100px;margin:0 auto;padding:clamp(22px,4vw,54px);display:grid;gap:26px}
.seo-hero,.seo-content{background:#fff;border:1px solid rgba(13,22,35,.09);border-radius:28px;padding:clamp(24px,4vw,52px);box-shadow:0 22px 70px rgba(7,17,29,.08)}
.seo-hero img{width:min(280px,70vw);margin-bottom:28px}.seo-hero h1{font-size:clamp(2.2rem,6vw,4.6rem);letter-spacing:-.07em;line-height:.96;color:#07111d}.seo-hero p,.seo-content p{font-size:1.05rem;color:#526174;line-height:1.75}.seo-content{display:grid;gap:18px}.seo-content h2{font-size:clamp(1.5rem,3vw,2.4rem);letter-spacing:-.04em;color:#07111d}.seo-content ul{margin:0;padding-left:1.2rem;color:#334155;line-height:1.8}.seo-content .seo-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.seo-content .seo-card{background:#f8fafc;border:1px solid rgba(13,22,35,.08);border-radius:20px;padding:18px}.seo-content .seo-card strong{display:block;margin-bottom:6px;color:#07111d}@media(max-width:760px){.seo-page{padding:14px}.seo-hero,.seo-content{border-radius:20px;padding:22px}.seo-content .seo-card-grid{grid-template-columns:1fr}}


/* Moderne Standortkarte + lokale Statistiken */
.pro-location-area{
  background:linear-gradient(180deg,#eef5fb 0%,#f7fafc 100%) !important;
}
.location-card-modern{
  grid-template-columns:.82fr 1.18fr !important;
  background:linear-gradient(135deg,#07111d,#13263b) !important;
  overflow:hidden !important;
  position:relative !important;
}
.location-card-modern::before{
  content:"";
  position:absolute;
  inset:-30% auto auto -10%;
  width:520px;
  height:520px;
  border-radius:999px;
  background:radial-gradient(circle,rgba(47,130,255,.28),rgba(47,130,255,0) 62%);
  pointer-events:none;
}
.location-copy,
.location-map-panel{
  position:relative;
  z-index:1;
}
.location-copy .area-map{
  margin-top:24px;
}
.location-map-panel{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:18px;
  align-items:stretch;
  padding:12px;
  border-radius:30px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12), 0 28px 90px rgba(0,0,0,.24);
}
.map-visual{
  min-height:360px;
  border-radius:24px;
  overflow:hidden;
  position:relative;
  background:
    radial-gradient(circle at 20% 20%,rgba(255,255,255,.45),transparent 3px),
    radial-gradient(circle at 74% 62%,rgba(255,255,255,.35),transparent 4px),
    linear-gradient(135deg,#dbeafe,#f8fbff 52%,#cae5ff);
}
.map-grid{
  position:absolute;
  inset:0;
  opacity:.9;
  background:
    linear-gradient(90deg,rgba(20,74,112,.10) 1px,transparent 1px) 0 0/42px 42px,
    linear-gradient(0deg,rgba(20,74,112,.10) 1px,transparent 1px) 0 0/42px 42px;
}
.map-route-line{
  position:absolute;
  inset:54px 36px 78px 46px;
  border:8px solid rgba(9,83,151,.24);
  border-left-color:transparent;
  border-bottom-color:rgba(31,120,219,.34);
  border-radius:44% 54% 42% 52%;
  transform:rotate(-10deg);
}
.map-route-line::after{
  content:"";
  position:absolute;
  right:18%;
  bottom:-16px;
  width:54%;
  height:8px;
  border-radius:999px;
  background:linear-gradient(90deg,#1d75d8,#66b7ff);
  box-shadow:0 8px 18px rgba(29,117,216,.22);
}
.map-pin{
  position:absolute;
  width:54px;
  height:54px;
  border-radius:18px 18px 18px 4px;
  transform:rotate(-45deg);
  background:#0b2340;
  box-shadow:0 20px 34px rgba(7,17,29,.24);
  display:grid;
  place-items:center;
}
.map-pin span{
  width:18px;
  height:18px;
  border-radius:999px;
  background:#fff;
  display:block;
}
.map-pin.home{right:20%;top:42%;background:#0874e7;}
.map-pin.user{left:18%;bottom:20%;background:#0f172a;opacity:.88;}
.map-card-floating{
  position:absolute;
  left:18px;
  right:18px;
  bottom:18px;
  padding:16px;
  border-radius:20px;
  background:rgba(255,255,255,.92);
  color:#0f172a;
  box-shadow:0 18px 45px rgba(7,17,29,.14);
  backdrop-filter:blur(16px);
}
.map-card-floating strong,
.map-card-floating span{display:block;}
.map-card-floating span{margin-top:4px;color:#64748b;font-weight:750;font-size:.9rem;}
.location-panel-copy{
  padding:20px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:14px;
}
.location-panel-copy h3{
  color:#fff;
  margin:0;
  font-size:clamp(1.8rem,3vw,3rem);
  line-height:1;
  letter-spacing:-.055em;
}
.location-panel-copy p{
  color:rgba(255,255,255,.72) !important;
  margin:0;
}
.location-address{
  padding:14px 16px;
  border-radius:18px;
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.13);
}
.location-address span,
.location-address strong{display:block;}
.location-address span{font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;color:rgba(255,255,255,.52);font-weight:900;}
.location-address strong{margin-top:4px;color:#fff;line-height:1.35;}
.location-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:2px;}
.location-actions .btn{border-radius:999px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;}
.location-actions .btn.soft{border:0;background:rgba(255,255,255,.12);color:#fff;font-weight:900;cursor:pointer;}
.distance-result{font-size:.92rem;color:rgba(255,255,255,.62) !important;}

.stats-admin-body .admin-pro-main{max-width:1240px;}
.stats-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:flex-end;}
.stats-actions form{margin:0;}
.stats-hero-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:18px;}
.stat-tile{padding:24px;border-radius:28px;background:#fff;border:1px solid rgba(15,23,42,.08);box-shadow:0 18px 60px rgba(15,23,42,.07);display:grid;gap:8px;min-height:150px;}
.stat-tile.primary{background:linear-gradient(135deg,#07111d,#15375c);color:#fff;}
.stat-tile span{font-size:.78rem;text-transform:uppercase;letter-spacing:.16em;font-weight:900;color:#64748b;}
.stat-tile.primary span,.stat-tile.primary small{color:rgba(255,255,255,.68);}
.stat-tile strong{font-size:clamp(2.4rem,5vw,4.8rem);letter-spacing:-.075em;line-height:.9;color:#0f172a;}
.stat-tile.primary strong{color:#fff;}
.stat-tile small{color:#64748b;font-weight:750;line-height:1.45;}
.stats-grid-two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-bottom:18px;}
.stats-card h2{margin-bottom:18px;}
.stats-bars{display:grid;gap:14px;}
.stats-bar-row{display:grid;gap:8px;}
.stats-bar-row div{display:flex;justify-content:space-between;gap:14px;align-items:end;}
.stats-bar-row strong{font-size:.98rem;color:#0f172a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.stats-bar-row span{font-size:.86rem;color:#64748b;font-weight:800;white-space:nowrap;}
.stats-bar-row i{display:block;height:10px;border-radius:999px;background:linear-gradient(90deg,#0f172a,#2f82ff);width:var(--w);min-width:24px;box-shadow:0 8px 18px rgba(47,130,255,.14);}
.stats-bars.compact .stats-bar-row i{height:8px;}
.stats-feed{display:grid;gap:10px;}
.stats-feed article{display:grid;grid-template-columns:150px 180px 1fr;gap:14px;align-items:center;padding:13px 14px;border-radius:18px;background:#f8fafc;border:1px solid rgba(15,23,42,.06);}
.stats-feed span{color:#64748b;font-weight:800;font-size:.9rem;}
.stats-feed strong{color:#0f172a;}
.stats-feed small{color:#64748b;font-weight:750;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.stats-privacy-note{margin:20px 0 0 !important;}

@media(max-width:1100px){
  .location-card-modern{grid-template-columns:1fr !important;}
  .location-map-panel{grid-template-columns:1fr;}
  .map-visual{min-height:300px;}
  .stats-hero-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .stats-grid-two{grid-template-columns:1fr;}
}
@media(max-width:700px){
  .location-map-panel{padding:8px;border-radius:24px;}
  .location-panel-copy{padding:16px 10px 10px;}
  .location-actions{display:grid;grid-template-columns:1fr;}
  .map-visual{min-height:260px;border-radius:20px;}
  .stats-hero-grid{grid-template-columns:1fr;}
  .stat-tile{min-height:auto;padding:20px;}
  .stats-topbar{gap:16px;}
  .stats-actions{width:100%;justify-content:stretch;}
  .stats-actions .button,.stats-actions form,.stats-actions form button{width:100%;}
  .stats-feed article{grid-template-columns:1fr;gap:4px;}
}
