:root{
  --bg: #f5f7fb;
  --bg2:#ffffff;
  --card:#ffffff;
  --text:#0b1220;
  --muted:#475569;
  --border: rgba(15,23,42,.14);
  --accent:#7c5cff;
  --accent2:#35d1ff;
  --shadow: 0 16px 40px rgba(15,23,42,.12);
  --radius:16px;
  --radius2:20px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  color:var(--text);
  background: radial-gradient(1200px 520px at 20% -10%, rgba(124,92,255,.16), transparent 60%),
              radial-gradient(900px 520px at 80% 0%, rgba(53,209,255,.14), transparent 60%),
              linear-gradient(180deg, var(--bg), #ffffff 65%);
  line-height:1.55;
  font-size:16px;
  text-rendering: optimizeLegibility;
}

h1,h2,h3{letter-spacing:-.02em}
h1{font-size:clamp(36px, 4.2vw, 54px); line-height:1.03}
h2{font-size:clamp(26px, 2.4vw, 34px); line-height:1.12}
h3{font-size:clamp(18px, 1.25vw, 20px); letter-spacing:-.01em; line-height:1.18}
p{max-width: 72ch}

a{color:inherit; text-decoration:none}

.container{
  width:min(1100px, calc(100% - 40px));
  margin-inline:auto;
}

@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto !important}
  .hero__svg,.hero__float,.page-hero__svg,.page-hero__float{animation:none !important}
}

.skip{
  position:absolute;
  left:-999px;
  top:auto;
  width:1px;height:1px;
  overflow:hidden;
}
.skip:focus{left:16px;top:16px;width:auto;height:auto;background:#fff;color:#000;padding:10px 12px;border-radius:10px;z-index:50}

.header{
  position:sticky;
  top:0;
  z-index:20;
  backdrop-filter: blur(12px);
  background: rgba(255,255,255,.72);
  border-bottom:1px solid var(--border);
}
.header__inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:14px 0;
  gap:14px;
}

.brand{display:flex; align-items:center; gap:12px; min-width: 220px}
.brand:focus-visible{outline:2px solid rgba(124,92,255,.6); outline-offset:6px; border-radius:14px}
.brand__mark{
  width:40px;height:40px;
  border-radius:12px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  display:grid;
  place-items:center;
  font-weight:800;
  box-shadow: var(--shadow);
}
.brand__name{font-weight:800}
.brand__tagline{font-size:12px;color:var(--muted)}

.nav{display:flex; align-items:center; gap:18px; flex-wrap:wrap; justify-content:flex-end}
.nav a{color: rgba(15,23,42,.78); font-weight:700}
.nav a:hover{color:var(--text)}

.nav__menu{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  align-items:center;
  gap:18px;
}
.nav__menu li{margin:0; padding:0}
.nav__menu .current-menu-item > a,
.nav__menu .current_page_item > a{color:var(--text)}

.nav__cta{white-space:nowrap}
.nav__cta--rdv{
  position:relative;
  padding-inline:14px;
}
.nav__cta--rdv::before{
  content:"";
  width:16px;
  height:16px;
  margin-right:10px;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M7 2a1 1 0 0 1 1 1v1h8V3a1 1 0 1 1 2 0v1h1a3 3 0 0 1 3 3v12a3 3 0 0 1-3 3H5a3 3 0 0 1-3-3V7a3 3 0 0 1 3-3h1V3a1 1 0 0 1 1-1Zm12 6H5v11a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V8ZM6 6h12V7H6V6Zm5 4a1 1 0 0 1 1 1v1h1a1 1 0 1 1 0 2h-2a1 1 0 0 1-1-1v-2a1 1 0 0 1 1-1Z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M7 2a1 1 0 0 1 1 1v1h8V3a1 1 0 1 1 2 0v1h1a3 3 0 0 1 3 3v12a3 3 0 0 1-3 3H5a3 3 0 0 1-3-3V7a3 3 0 0 1 3-3h1V3a1 1 0 0 1 1-1Zm12 6H5v11a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V8ZM6 6h12V7H6V6Zm5 4a1 1 0 0 1 1 1v1h1a1 1 0 1 1 0 2h-2a1 1 0 0 1-1-1v-2a1 1 0 0 1 1-1Z'/%3E%3C/svg%3E") center / contain no-repeat;
  opacity:.95;
}

.nav-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  border-radius:14px;
  background: rgba(15,23,42,.04);
  border:1px solid var(--border);
  color: var(--text);
}
.nav-toggle__bar{display:block; width:18px; height:2px; background: rgba(15,23,42,.80); margin:3px 0; border-radius:2px}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 16px;
  border-radius:12px;
  background: linear-gradient(135deg, rgba(124,92,255,1), rgba(53,209,255,1));
  color:#06102a;
  font-weight:800;
  border:1px solid rgba(255,255,255,.10);
  box-shadow: 0 12px 28px rgba(0,0,0,.35);
  cursor:pointer;
}
.btn:hover{filter:brightness(1.03)}
.btn:active{transform: translateY(1px)}
.btn--ghost{
  background: rgba(15,23,42,.05);
  color:var(--text);
  border:1px solid var(--border);
  box-shadow:none;
}
.btn--sm{padding:10px 12px;border-radius:12px}
.btn--block{width:100%}

.hero{padding:56px 0 22px 0}
.hero__grid{display:grid; grid-template-columns: 1.2fr .8fr; gap:26px; align-items:stretch}

.hero{position:relative; overflow:hidden}
.hero::before{
  content:"";
  position:absolute;
  inset:-120px -140px auto -140px;
  height:380px;
  background:
    radial-gradient(260px 180px at 18% 40%, rgba(124,92,255,.20), transparent 62%),
    radial-gradient(240px 180px at 78% 18%, rgba(53,209,255,.18), transparent 62%),
    radial-gradient(260px 180px at 60% 70%, rgba(255,170,0,.12), transparent 62%);
  pointer-events:none;
}

.pill{
  display:inline-flex;
  padding:8px 10px;
  border-radius:999px;
  background: rgba(15,23,42,.05);
  border:1px solid var(--border);
  color: rgba(15,23,42,.72);
  font-weight:700;
  margin:0 0 12px 0;
}

.hero__content{max-width: 64ch}
h1{margin:0 0 14px 0; letter-spacing:-.02em; text-wrap: balance}
.lead{margin:0 0 18px 0; color: rgba(15,23,42,.72); font-size:18px; line-height:1.6; max-width: 62ch}
.hero__cta{display:flex; gap:12px; flex-wrap:wrap; margin-bottom:18px}

.hero__visual{position:relative; min-height: 360px}
.hero__visual-card{
  position:relative;
  z-index:2;
  background: rgba(255,255,255,.78);
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:18px;
  box-shadow: var(--shadow);
}
.hero__visual-card h2{margin:0 0 10px 0; font-size:18px}

.hero__svg{
  position:absolute;
  inset:auto -14px -22px auto;
  width:min(520px, 90%);
  height:auto;
  z-index:1;
  opacity:.95;
  transform: translateY(0);
  animation: floaty 6.5s ease-in-out infinite;
}

.hero__float{
  position:absolute;
  z-index:3;
  padding:10px 12px;
  border-radius:999px;
  background: rgba(255,255,255,.84);
  border:1px solid rgba(15,23,42,.12);
  box-shadow: 0 14px 30px rgba(15,23,42,.10);
  font-weight:900;
  color: rgba(15,23,42,.86);
  letter-spacing:-.01em;
  backdrop-filter: blur(10px);
  animation: floaty 5.2s ease-in-out infinite;
}
.hero__float--a{top:24px; right:38px; animation-delay:-.4s}
.hero__float--b{top:128px; right:18px; animation-delay:-1.1s}
.hero__float--c{bottom:78px; left:18px; animation-delay:-.8s}

@keyframes floaty{
  0%,100%{transform: translateY(0)}
  50%{transform: translateY(-8px)}
}
blockquote{
  margin:0;
  padding:12px 12px;
  border-radius: 14px;
  background: rgba(15,23,42,.04);
  border:1px solid var(--border);
  color:var(--text);
}

.chips{display:flex; flex-wrap:wrap; gap:8px; margin-top:14px}
.chip{
  padding:8px 10px;
  border-radius: 999px;
  background: rgba(15,23,42,.04);
  border:1px solid var(--border);
  color: rgba(15,23,42,.74);
  font-weight:700;
  font-size:12px;
}

.trust{display:grid; grid-template-columns: repeat(3, 1fr); gap:10px; margin-top:18px}
.trust__item{
  padding:10px 10px;
  border-radius: 14px;
  background: rgba(255,255,255,.80);
  border:1px solid var(--border);
}
.trust__k{display:block; font-size:12px; color: rgba(15,23,42,.60); font-weight:800}
.trust__v{display:block; font-size:14px; font-weight:800}

.section{padding:52px 0}
.section--alt{background: linear-gradient(180deg, rgba(15,23,42,.03), transparent 60%)}
.section__head{margin-bottom:18px}
.section__head h2{margin:0 0 8px 0; letter-spacing:-.01em; text-wrap: balance}
.section__head p{margin:0; color: rgba(15,23,42,.70)}

.page-hero{padding:44px 0 10px 0}
.page-hero h1{margin:0; font-size:38px}

.page-hero{position:relative; overflow:hidden}
.page-hero::before{
  content:"";
  position:absolute;
  inset:-120px -140px auto -140px;
  height:300px;
  background:
    radial-gradient(240px 180px at 12% 55%, rgba(124,92,255,.18), transparent 62%),
    radial-gradient(220px 160px at 78% 18%, rgba(53,209,255,.16), transparent 62%),
    radial-gradient(240px 170px at 58% 70%, rgba(255,170,0,.10), transparent 62%);
  pointer-events:none;
}

.page-hero__grid{display:grid; grid-template-columns: 1.1fr .9fr; gap:22px; align-items:center}
.page-hero__visual{position:relative; min-height: 220px}
.page-hero__svg{
  position:absolute;
  inset:auto -8px -28px auto;
  width:min(460px, 95%);
  height:auto;
  opacity:.95;
  animation: floaty 7.2s ease-in-out infinite;
}
.page-hero__float{
  position:absolute;
  z-index:2;
  padding:10px 12px;
  border-radius:999px;
  background: rgba(255,255,255,.84);
  border:1px solid rgba(15,23,42,.12);
  box-shadow: 0 14px 30px rgba(15,23,42,.10);
  font-weight:900;
  color: rgba(15,23,42,.86);
  backdrop-filter: blur(10px);
  animation: floaty 5.6s ease-in-out infinite;
}
.page-hero__float--a{top:10px; right:44px; animation-delay:-.6s}
.page-hero__float--b{top:92px; right:18px; animation-delay:-1.2s}
.page-hero__float--c{bottom:46px; left:10px; animation-delay:-.9s}

.content{
  background: rgba(255,255,255,.78);
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:18px;
  box-shadow: var(--shadow);
}
.content{transition: transform 180ms ease, box-shadow 180ms ease}
.content:hover{transform: translateY(-2px); box-shadow: 0 18px 44px rgba(15,23,42,.14)}
.content > :first-child{margin-top:0}
.content > :last-child{margin-bottom:0}

.content{font-size:17px; line-height:1.75}
.content p{margin:0 0 14px 0}
.content p:last-child{margin-bottom:0}

.content a{color: rgba(63,76,255,.95); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px}
.content a:hover{color: rgba(20,140,255,.95)}
.content a:focus-visible{outline:2px solid rgba(124,92,255,.45); outline-offset:3px; border-radius:6px}

.content .wp-block-heading{margin:18px 0 10px 0}
.content .wp-block-heading:first-child{margin-top:0}
.content p{color: rgba(15,23,42,.74)}
.content strong{color:var(--text)}

.content h2,.content h3{margin-top:26px}
.content h2:first-child,.content h3:first-child{margin-top:0}
.content h2{padding-top:6px}

.content h2{
  display:inline-block;
  background: linear-gradient(180deg, transparent 62%, rgba(124,92,255,.18) 0);
  padding:0 6px;
  margin-left:-6px;
  border-radius:10px;
}

.content h3{
  display:inline-block;
  background: linear-gradient(180deg, transparent 66%, rgba(53,209,255,.16) 0);
  padding:0 6px;
  margin-left:-6px;
  border-radius:10px;
}

.content ul{padding-left:18px}
.content li{margin:8px 0; color: rgba(15,23,42,.74)}
.content li::marker{color: rgba(53,209,255,.9)}

/* Gutenberg: listes en checklist (plus "pro") */
.content ul{
  padding-left:0;
  list-style:none;
  margin:12px 0 18px 0;
}
.content ul li{
  position:relative;
  padding-left:28px;
  margin:10px 0;
}
.content ul li::before{
  content:"";
  position:absolute;
  left:0;
  top:0.45em;
  width:18px;
  height:18px;
  border-radius:6px;
  background: linear-gradient(135deg, rgba(124,92,255,.95), rgba(53,209,255,.85));
  box-shadow: 0 10px 18px rgba(15,23,42,.10);
}
.content ul li::after{
  content:"";
  position:absolute;
  left:6px;
  top:0.78em;
  width:8px;
  height:4px;
  border-left:2px solid rgba(255,255,255,.95);
  border-bottom:2px solid rgba(255,255,255,.95);
  transform: rotate(-45deg);
}

/* Gutenberg: groupes/colonnes comme sections premium */
.content .wp-block-group,
.content .wp-block-media-text{
  margin:18px 0;
  padding:18px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.70);
}

.content .wp-block-columns{
  gap:14px;
  margin:18px 0;
}
.content .wp-block-column{
  padding:16px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.72);
  box-shadow: 0 16px 40px rgba(15,23,42,.08);
}
.content .wp-block-column > :first-child{margin-top:0}
.content .wp-block-column > :last-child{margin-bottom:0}

/* Gutenberg: séparateur */
.content .wp-block-separator{
  border:0;
  height:1px;
  background: linear-gradient(90deg, transparent, rgba(15,23,42,.14), transparent);
  margin:20px 0;
}

.content blockquote,
.content .wp-block-quote{
  margin:14px 0;
  padding:12px 12px;
  border-radius: 14px;
  background: rgba(15,23,42,.04);
  border:1px solid var(--border);
  color:var(--text);
}
.content blockquote p,
.content .wp-block-quote p{color:var(--text); margin:0}

.content .wp-block-buttons{margin-top:12px}
.content .wp-block-button__link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 16px;
  border-radius:12px;
  background: linear-gradient(135deg, rgba(124,92,255,1), rgba(53,209,255,1));
  color:#06102a;
  font-weight:800;
  border:1px solid rgba(255,255,255,.10);
  box-shadow: 0 12px 28px rgba(0,0,0,.35);
  text-decoration:none;
}
.content .wp-block-button__link:hover{filter:brightness(1.03)}

.cards{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px; align-items:stretch}
.card{
  background: rgba(255,255,255,.78);
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:18px;
  box-shadow: var(--shadow);
  display:flex;
  flex-direction:column;
  gap:12px;
}
.card{transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease}
.card:hover{transform: translateY(-4px); border-color: rgba(124,92,255,.22); box-shadow: 0 22px 56px rgba(15,23,42,.16)}
.card--accent{
  background: linear-gradient(180deg, rgba(124,92,255,.12), rgba(255,255,255,.78));
}
.card__top{display:flex; flex-direction:column; gap:6px}
.card__badge{margin:0; color:var(--muted); font-weight:800; font-size:12px; letter-spacing:.08em; text-transform:uppercase}
.card h3{margin:0; font-size:18px}
.card__price{margin:0; font-weight:900}
.card__desc{margin:0; color: rgba(15,23,42,.74)}

.list{margin:0; padding-left:18px; color:var(--text)}
.list li{margin:8px 0}

.steps{list-style:none; margin:0; padding:0; display:grid; gap:10px}
.step{display:grid; grid-template-columns: 42px 1fr; gap:12px; align-items:start; padding:14px; border-radius: var(--radius); border:1px solid var(--border); background: rgba(255,255,255,.78)}
.step__n{width:42px;height:42px;border-radius:14px;background: rgba(15,23,42,.04);border:1px solid var(--border);display:grid;place-items:center;font-weight:900}
.step__c h3{margin:0 0 6px 0; font-size:16px}
.step__c p{margin:0; color: rgba(15,23,42,.72)}

.accordion details{
  background: rgba(255,255,255,.78);
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:14px;
  box-shadow: var(--shadow);
}
.accordion details + details{margin-top:10px}
.accordion summary{cursor:pointer; font-weight:900}

.answer{margin:12px 0 0 0; color: rgba(15,23,42,.74)}

.features{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px}
.feature{
  background: rgba(255,255,255,.78);
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:18px;
  box-shadow: var(--shadow);
}
.feature{transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease}
.feature:hover{transform: translateY(-4px); border-color: rgba(53,209,255,.26); box-shadow: 0 22px 56px rgba(15,23,42,.16)}
.feature h3{margin:0 0 8px 0; font-size:18px}
.feature p{margin:0; color: rgba(15,23,42,.74)}

.cta-band{
  margin-top:14px;
  padding:18px;
  border-radius: var(--radius2);
  border: 1px solid var(--border);
  background: linear-gradient(135deg, rgba(124,92,255,.10), rgba(53,209,255,.10));
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
.cta-band h3{margin:0 0 6px 0}
.cta-band p{margin:0; color: rgba(15,23,42,.74)}

.check{margin:12px 0 0 0; padding-left:18px; color:var(--text)}
.check li{margin:8px 0; color: rgba(15,23,42,.74)}
.check li::marker{color: rgba(53,209,255,.9)}

.contact{display:grid; grid-template-columns: 1.15fr .85fr; gap:14px; align-items:start}

.form{
  background: rgba(255,255,255,.78);
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:18px;
  box-shadow: var(--shadow);
}
.form label{display:grid; gap:8px; font-weight:800; color:var(--text)}
.form__row{display:grid; grid-template-columns: 1fr 1fr; gap:12px}
input, textarea{
  width:100%;
  padding:12px 12px;
  border-radius: 12px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.92);
  color: var(--text);
  font: inherit;
}
input::placeholder, textarea::placeholder{color: rgba(15,23,42,.45)}
input:focus, textarea:focus{outline:2px solid rgba(124,92,255,.5); border-color: transparent}

.form__actions{display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-top:12px}
.form__hint{margin:0; color:var(--muted); font-size:13px}

.panel{
  background: rgba(255,255,255,.78);
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:18px;
  box-shadow: var(--shadow);
}
.panel h3{margin:0 0 10px 0}
.mini{margin:0; padding-left:18px; color: rgba(15,23,42,.74)}
.mini li{margin:8px 0}
.panel__cta{margin-top:14px}
.muted{color:var(--muted); margin:0 0 10px 0}

.contact-mini{margin-top:14px; padding-top:14px; border-top:1px solid var(--border)}
.contact-mini__link{font-weight:900; text-decoration:none}
.contact-mini__link:hover{text-decoration:underline}

.footer{padding:26px 0; border-top:1px solid var(--border); background: rgba(255,255,255,.70)}
.footer__inner{display:block}
.footer__grid{display:grid; grid-template-columns: 1fr auto auto; align-items:center; gap:14px}
.footer__copy{margin:0; color:var(--muted)}
.footer__links{display:flex; gap:14px; flex-wrap:wrap; justify-content:center}
.footer__top{display:flex; justify-content:flex-end}
.link{color:var(--muted); font-weight:700}
.link:hover{color:var(--text)}

@media (max-width: 980px){
  .hero__grid{grid-template-columns: 1fr}
  .cards{grid-template-columns: 1fr}
  .contact{grid-template-columns: 1fr}
  .features{grid-template-columns: 1fr}
  .cta-band{flex-direction:column; align-items:flex-start}
  .hero__visual{min-height: 320px}
  .hero__svg{inset:auto -12px -26px auto; width:min(560px, 96%)}
  .page-hero__grid{grid-template-columns: 1fr}
  .page-hero__visual{min-height: 200px}
  .page-hero__svg{inset:auto -12px -34px auto; width:min(520px, 98%)}
}

@media (max-width: 560px){
  .nav-toggle{display:inline-flex}
  .nav{
    position: fixed;
    inset: 64px 12px auto 12px;
    padding: 14px;
    background: rgba(255,255,255,.94);
    border: 1px solid var(--border);
    border-radius: var(--radius2);
    display: grid;
    gap: 10px;
    justify-content: stretch;
    align-content: start;
    transform: translateY(-10px);
    opacity: 0;
    pointer-events: none;
    transition: opacity 160ms ease, transform 160ms ease;
  }
  .nav[data-open="true"]{
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }

  .nav__menu{display:grid; gap:10px}
  .nav__menu a{width:100%}
  .nav__cta{width:100%}
  .form__row{grid-template-columns: 1fr}
  h1{font-size:34px}
  .trust{grid-template-columns: 1fr}
  .footer__grid{grid-template-columns: 1fr; align-items:start}
  .footer__links{justify-content:flex-start}
  .footer__top{justify-content:flex-start}
}

/* WPForms (contact) */
.wpforms-container{margin-top:12px}
.wpforms-container .wpforms-field-label,
.wpforms-container .wpforms-field-sublabel,
.wpforms-container .wpforms-field-description,
.wpforms-container .wpforms-required-label{
  color: var(--text) !important;
}
.wpforms-container .wpforms-field-description{opacity:.85}
.wpforms-container .wpforms-required-label{color: rgba(255,120,160,.95) !important}
.wpforms-container input[type="text"],
.wpforms-container input[type="email"],
.wpforms-container textarea{
  width:100% !important;
  padding:12px 12px !important;
  border-radius: 12px !important;
  border:1px solid var(--border) !important;
  background: rgba(255,255,255,.92) !important;
  color: var(--text) !important;
  outline: none !important;
}
.wpforms-container input[type="text"]::placeholder,
.wpforms-container input[type="email"]::placeholder,
.wpforms-container textarea::placeholder{
  color: rgba(15,23,42,.45) !important;
}
.wpforms-container input[type="text"]:focus,
.wpforms-container input[type="email"]:focus,
.wpforms-container textarea:focus{
  border-color: transparent !important;
  box-shadow: 0 0 0 2px rgba(124,92,255,.45) !important;
}
.wpforms-container .wpforms-submit{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  padding:12px 16px !important;
  border-radius:12px !important;
  background: linear-gradient(135deg, rgba(124,92,255,1), rgba(53,209,255,1)) !important;
  color:#06102a !important;
  font-weight:800 !important;
  border:1px solid rgba(255,255,255,.10) !important;
  box-shadow: 0 12px 28px rgba(0,0,0,.35) !important;
}

.cal-modal{
  position:fixed;
  inset:0;
  z-index:60;
  display:grid;
  place-items:center;
}
.cal-modal__backdrop{
  position:absolute;
  inset:0;
  background: rgba(15,23,42,.58);
  backdrop-filter: blur(10px);
}
.cal-modal__dialog{
  position:relative;
  width:min(980px, calc(100% - 22px));
  height:min(86vh, 760px);
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.92);
  box-shadow: 0 28px 90px rgba(0,0,0,.35);
  overflow:hidden;
}
.cal-modal__frame{
  width:100%;
  height:100%;
  border:0;
}
.cal-modal__close{
  position:absolute;
  top:10px;
  right:10px;
  width:40px;
  height:40px;
  border-radius: 12px;
  border:1px solid rgba(15,23,42,.14);
  background: rgba(255,255,255,.85);
  color: rgba(15,23,42,.85);
  font-size:22px;
  font-weight:900;
  cursor:pointer;
  display:grid;
  place-items:center;
}
.cal-modal__close:hover{filter:brightness(1.03)}
