:root{
  --bg:#f7f5f2;
  --bg-elev:#ffffff;
  --surface:#ffffff;
  --text:#1b1f2a;
  --muted:#657085;
  --line:#e8e6e2;
  --brand:#6d4aff;
  --brand-700:#5a3bff;
  --brand-50:#f3f0ff;
  --accent:#6d4aff;
  --success:#22c55e;
  --warn:#f59e0b;
  --danger:#ef4444;
  --shadow: 0 10px 24px rgba(17, 24, 39, .06);
  --ring: 0 0 0 3px rgba(109,74,255,.35);
  --radius:16px;
}

@keyframes gc-bg-shift {
  0%   { background-position: 0% 50%, 100% 50%, 50% 50%; }
  50%  { background-position: 100% 50%, 0% 50%, 50% 60%; }
  100% { background-position: 0% 50%, 100% 50%, 50% 50%; }
}

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

[hidden]{ display:none !important; }

*{box-sizing:border-box}
html,body{ width: 100%; max-width: 100%; scroll-behavior: smooth; }
html {
  
  height:100vh;
}

body{
 
  background-size: 160% 160%, 160% 160%, cover;
  animation: gc-bg-shift 14s ease-in-out infinite;
  margin:0;
  height: 100%;
  color:var(--text);
  font:16px/1.55 Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial;
  letter-spacing:.2px;
}

@media (prefers-reduced-motion: reduce){
  body{ animation: none; }
}

main {
  padding: 20px;
}

img{max-width:100%;display:block}

a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

.container{max-width:1140px;margin:0 auto;padding:0 20px}

.topbar{
  display:flex;gap:12px;align-items:center;justify-content:center;
  padding:10px 14px;
  background:linear-gradient(90deg, rgba(109,74,255,.10), rgba(109,74,255,.18));
  border-bottom:1px solid var(--line);
  color:#1b1636;
  font-weight:700;
}
.topbar .topbar-cta{
  background:var(--brand);
  color:#fff;
  padding:.45rem .75rem;
  border-radius:10px;
  box-shadow:var(--shadow);
}
.topbar .topbar-cta:hover{text-decoration:none;filter:brightness(.96)}

.site-header{
  display: flex; width: 100%; justify-content: space-around; padding: 10px 0px;
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(8px);
  border-bottom:1px solid var(--line);
}
.drawer{
  position:fixed;inset:0 0 0 auto;width:min(360px, 92%);
  background:var(--bg-elev);border-left:1px solid var(--line);
  transform:translateX(110%);transition:transform .25s ease;z-index:100;box-shadow:-10px 0 30px rgba(17,24,39,.12);
  border-top-left-radius:var(--radius);border-bottom-left-radius:var(--radius);
}
.drawer[aria-hidden="false"]{transform:translateX(0)}
.drawer-nav{display:grid;padding:22px;gap:8px}
.drawer-nav a{
  background:#faf9f7;
  border:1px solid transparent;
  border-radius:12px;
  padding:12px 14px;
  color:#15172a;
}
.drawer-nav a:hover{
  background: var(--brand-50);
  border-color:#e6e1ff;
  text-decoration:none;
}
.drawer-nav a.active{background:var(--brand-50);border-color:#dfd8ff}
.drawer .divider{height:1px;background:var(--line);margin:8px 0}
.scrim{position:fixed;inset:0;background:rgba(17,24,39,.35);z-index:90;backdrop-filter:blur(1px)}
.brand{display:flex;align-items:center;gap:10px;color:#1a1830;font-weight:900;letter-spacing:.3px}
.brand span{font-size:1.08rem}
.burger{all:unset;cursor:pointer;display:grid;gap:5px}
.burger span{width:26px;height:2px;background:#272a38;border-radius:2px;transition:transform .2s ease}

@keyframes gc-hero-pulse{
  from { filter:saturate(1) brightness(1); transform:scale(1); }
  to   { filter:saturate(1.08) brightness(1.02); transform:scale(1.03); }
}

.hero{
  position:relative;min-height:64vh;display:grid;align-items:center;
  overflow:hidden;
}

button {
  border: none;
}

.hero::before{
  content:"";
  position:absolute; inset:0;
  background-image:url("/assets/hero-bg.webp");
  background-size:cover;
  background-position:center 30%;
  filter:saturate(1.05) contrast(1.02);
  opacity:.30;
  mix-blend-mode:normal;
  pointer-events:none;
}

.hero__bg{
  position:absolute;inset:0;
  background:
    radial-gradient(900px 420px at 20% 0%, rgba(109,74,255,.20), transparent 60%),
    radial-gradient(700px 380px at 100% 100%, rgba(109,74,255,.16), transparent 60%);
  animation: gc-hero-pulse 12s ease-in-out infinite alternate;
  pointer-events:none;
}
@media (prefers-reduced-motion: reduce){
  .hero__bg{ animation:none; }
}

.hero__content{position:relative;z-index:1;padding:72px 0}
.hero h1{font-size:clamp(2.1rem, 5vw, 3.1rem);line-height:1.06;margin:0 0 10px;font-weight:900;color:#161628}
.hero p{max-width:62ch;color:var(--muted);margin:0 0 18px}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap;margin:14px 0 8px}
.hero__badges{display:flex;gap:10px;flex-wrap:wrap;padding:0;margin:20px 0 0;list-style:none}
.hero__badges li{
  background:#ffffff;border:1px solid var(--line);border-radius:999px;padding:8px 12px;
  box-shadow:var(--shadow);color:#2a2e3f
}

.section{padding:28px 0}
.section-head{display:grid;gap:6px;margin-bottom:14px}
.section-title{margin:0}
.section-sub{color:var(--muted);margin:0}

.logos{display:flex;flex-wrap:wrap;gap:10px}
.logo-pill{
  background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 12px;
  box-shadow:var(--shadow);color:#2a2e3f;font-weight:700
}

.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.stat strong{font-size:1.6rem;color:#1a1830;display:block}
.stat span{color:var(--muted)}

.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;counter-reset:st}
.steps li h4{margin:.2rem 0}
.steps li p{color:var(--muted);margin:0}

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

.coach-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
.coach{display:grid;grid-template-columns:72px 1fr;gap:12px;align-items:center}
.coach__media .avatar{
  width:64px;height:64px;border-radius:50%;display:grid;place-items:center;
  background:var(--brand-50);border:1px solid #e5e1ff;color:#3a2b84;font-weight:900
}
.coach__body .muted{color:var(--muted);margin:.1rem 0 .4rem}

.testimonial-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
.testimonial p{margin:.2rem 0 .4rem}

.article-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}

.newsletter{display:grid;grid-template-columns:1fr auto;gap:14px;align-items:center}
.newsletter__form{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.newsletter__form input{min-width:240px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.btn{
  border-radius: calc(var(--radius) + 2px);
  padding:.72rem 1rem;
  font-weight:800;
  background:linear-gradient(180deg, var(--brand), var(--brand-700));
  color:#fff;
  box-shadow: var(--shadow);
}
.btn:hover{ transform: translateY(-1px); filter:brightness(.98); text-decoration:none; }
.btn:focus{ outline:none; box-shadow: var(--ring), var(--shadow); }
.btn.ghost{ background:#fff; border:1px solid #e6e1ff; color:#3a2b84; }

.strip{padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;box-shadow:var(--shadow)}
.strip__row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:center}
.link{color:#3a2b84;text-decoration:underline dotted}

.grid.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin:30px auto}
.card{
  border-radius: var(--radius);
  border:1px solid var(--line);
  background: var(--surface);
  box-shadow: var(--shadow);
  padding: 20px;
}
.card:hover{ transform: translateY(-1px); transition: transform .15s ease; }
@media (prefers-reduced-motion: reduce){ .card:hover{ transform:none; } }
.card h3{margin:0 0 6px}
.card p{color:var(--muted)}

.pricing{padding:36px 0}
.pricing__head{display:grid;gap:10px;margin-bottom:14px}
.price-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}
.price-card{
  background:var(--bg-elev);border:1px solid var(--line);border-radius:18px;padding:18px;display:grid;gap:12px;position:relative;
  box-shadow:var(--shadow);
}
.price-card.popular{outline:2px solid #e5e1ff;box-shadow:0 0 0 4px #f3f0ff inset, var(--shadow)}
.price-card header h3{margin:0;color:#161628}
.price-card p{color:var(--muted);margin:.2rem 0 0}
.price-card .price{display:flex;align-items:baseline;gap:10px;font-weight:900}
.price-card .price s{color:#8b90a1}
.price-card .price span{font-size:2rem;color:#1a1830}
.price-card .features{margin:0;padding-left:18px}
.pricing__note{color:var(--muted);margin-top:10px}

.cta{padding:32px 0}
.cta__card{
  background:linear-gradient(135deg, #fff, #f6f4ff);
  padding:28px;border:1px solid var(--line);border-radius:18px;display:grid;gap:10px;text-align:center;
  box-shadow:var(--shadow)
}

.page{padding:32px 0}
.page h1{margin-top:8px}

.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}
.contact-card{background:var(--surface);padding:16px;border-radius:14px;border:1px solid var(--line);box-shadow:var(--shadow)}
.map-wrap{margin-top:10px;border-radius:14px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.map-wrap iframe{width:100%;height:260px;border:0}

form{display:grid;gap:12px}
label{display:grid;gap:6px}
input,select,textarea{
  background:#fff;color:var(--text);border:1px solid #e5e7eb;
  padding:.75rem .8rem;border-radius:12px;outline:none;box-shadow:0 1px 0 rgba(17,24,39,.03) inset;
}
input:focus,select:focus,textarea:focus{box-shadow:var(--ring)}
.checkbox{grid-auto-flow:column;grid-template-columns:auto 1fr;align-items:start;gap:10px}
.form-msg{margin:6px 0 0}

.site-footer{margin-top:40px;border-top:1px solid var(--line);background:#faf9f7}
.foot-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;padding:22px 20px}
.foot-grid h4{margin:0 0 6px}
.foot-grid ul{margin:0;padding-left:18px}
.foot-bottom{display:flex;justify-content:space-between;gap:10px;padding:12px 20px;border-top:1px solid var(--line);font-size:.95rem;color:var(--muted)}

.legal h1{margin-bottom:4px}
.legal h2{margin-top:16px}

.modal{position:fixed;inset:0;display:grid;place-items:center;background:rgba(17,24,39,.35);backdrop-filter:blur(2px);z-index:120;opacity:0;pointer-events:none;transition:opacity .2s ease}
.modal[aria-hidden="false"]{opacity:1;pointer-events:auto}
.modal__card{width:min(720px,92%);background:var(--surface);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);position:relative}
.modal__content{padding:18px}
.modal__actions{display:flex;gap:10px;justify-content:flex-end;padding:0 18px 18px}
.modal__close{all:unset;cursor:pointer;position:absolute;right:16px;top:12px;font-size:1.6rem;line-height:1;color:#3b3e52}

.cookie-banner{
  position:fixed;left:16px;right:16px;bottom:16px;background:#fff;border:1px solid var(--line);
  border-radius:16px;padding:14px;display:flex;justify-content:space-between;gap:12px;z-index:200;box-shadow:var(--shadow)
}
.cookie-banner p{margin:0;max-width:60ch}
.cookie-banner .actions{display:flex;gap:10px}

.hidden{display:none !important}

@media (max-width:600px){
  .foot-bottom{flex-direction:column;align-items:flex-start}
  .cookie-banner{flex-direction: column !important;}
}

.hero.hero--courses::before{
  content:"";
  position:absolute; inset:0;
  background-image:url("/assets/hero-courses.webp");
  background-size:cover;
  background-position:center 35%;
  opacity:.28;
  filter:saturate(1.05) contrast(1.02);
  pointer-events:none;
}

.compare{padding:0}
.compare .compare__row{
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr 1fr;
  gap:10px;
  padding:12px 14px;
  border-top:1px solid var(--line);
}
.compare .compare__row:first-child{ border-top:0 }
.compare .compare__cell{ color:var(--text) }
.compare .compare__cell strong{ color:#161628 }

details.card summary{
  cursor:pointer;
  list-style:none;
}
details.card summary::-webkit-details-marker{ display:none }
details.card[open]{ outline:2px solid #e5e1ff; box-shadow:0 0 0 4px #f6f4ff inset, var(--shadow); border-radius:18px }

.page-cards .price-card{ margin-bottom: 0 }