/* ============================================
   Zurena Sisaje / Aurora Glow design system
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Unbounded:wght@400;500;600;700&family=Inter:wght@400;500;600&display=swap');

:root{
  --color-bg:#FAF8F6;
  --color-surface:#FFFFFF;
  --color-surface-tint:#F3EFFA;
  --color-surface-dark:#1E1533;
  --color-text:#241F35;
  --color-text-muted:#635C78;
  --color-border:#E4DEEF;
  --color-primary:#4C3575;
  --color-primary-dark:#33224F;
  --color-secondary:#1E8F8F;
  --color-accent:#E85D9C;

  --aurora-1:#7C5CFF;
  --aurora-2:#2EC4C4;
  --aurora-3:#FF6FA8;
  --aurora-4:#5B8DEF;

  --shadow-sm:0 1px 2px rgba(36,31,53,0.06),0 1px 1px rgba(36,31,53,0.05);
  --shadow-md:0 6px 16px rgba(36,31,53,0.09),0 2px 6px rgba(36,31,53,0.06);
  --shadow-lg:0 20px 44px rgba(36,31,53,0.14),0 6px 14px rgba(36,31,53,0.08);

  --radius-sm:8px;
  --radius-md:16px;
  --radius-lg:26px;
  --radius-full:999px;

  --space-1:0.5rem;
  --space-2:1rem;
  --space-3:1.75rem;
  --space-4:2.75rem;
  --space-5:4.5rem;
  --space-6:7rem;

  --font-heading:'Unbounded', sans-serif;
  --font-body:'Inter', sans-serif;

  --transition-base:0.3s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--color-text);
  background:var(--color-bg);
  line-height:1.65;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  overflow-x:hidden;
}
main{flex:1 0 auto;}
img{max-width:100%;height:auto;display:block;border-radius:var(--radius-md);}
a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-base);}
a:hover{color:var(--color-accent);}
h1,h2,h3,h4{font-family:var(--font-heading);color:var(--color-text);line-height:1.2;margin:0 0 var(--space-2);}
p{margin:0 0 1rem;color:var(--color-text-muted);}
ul,ol{margin:0;padding:0;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
input,textarea{font-family:inherit;font-size:1rem;}

.content-wrapper{
  max-width:1180px;
  margin-inline:auto;
  padding-inline:clamp(1.25rem,4vw,2.5rem);
}

.skip-link{
  position:absolute;
  left:-9999px;
  top:0;
  background:var(--color-primary);
  color:#fff;
  padding:0.75rem 1.25rem;
  border-radius:var(--radius-sm);
  z-index:1000;
}
.skip-link:focus{left:1rem;top:1rem;}

.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;
}


.aurora-backdrop{
  position:fixed;
  inset:0;
  z-index:-2;
  overflow:hidden;
  background:var(--color-bg);
}
.aurora-blob{
  position:absolute;
  border-radius:50%;
  filter:blur(90px);
  opacity:0.28;
  mix-blend-mode:multiply;
}
.site-blob-1{width:520px;height:520px;background:var(--aurora-1);top:-160px;left:-120px;animation:auroraDrift1 34s ease-in-out infinite;}
.site-blob-2{width:460px;height:460px;background:var(--aurora-2);bottom:-140px;right:-100px;animation:auroraDrift2 40s ease-in-out infinite;}
.site-blob-3{width:380px;height:380px;background:var(--aurora-3);top:40%;left:60%;animation:auroraDrift3 46s ease-in-out infinite;}

@keyframes auroraDrift1{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(6%,8%) scale(1.08);}}
@keyframes auroraDrift2{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(-8%,-6%) scale(1.1);}}
@keyframes auroraDrift3{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(-5%,10%) scale(0.95);}}


.cookie-bar{
  position:relative;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  background:var(--color-surface-dark);
  color:#EFEAFA;
  padding:0.75rem clamp(1.25rem,4vw,2.5rem);
  font-size:0.9rem;
  transition:max-height var(--transition-base), padding var(--transition-base), opacity var(--transition-base);
  overflow:hidden;
}
.cookie-bar p{color:#D9D2EE;margin:0;flex:1 1 320px;}
.cookie-bar a{color:#fff;text-decoration:underline;}
.cookie-actions{display:flex;gap:0.6rem;flex-wrap:wrap;}
.cookie-bar button{
  padding:0.5rem 1rem;
  border-radius:var(--radius-full);
  font-size:0.85rem;
  font-weight:600;
  transition:transform var(--transition-base), background var(--transition-base);
  min-height:38px;
}
.cookie-reject{background:rgba(255,255,255,0.12);color:#fff;}
.cookie-reject:hover{background:rgba(255,255,255,0.22);}
.cookie-bar.is-dismissed{max-height:0;padding-top:0;padding-bottom:0;opacity:0;}


.site-header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:100;
  background:rgba(250,248,246,0.85);
  backdrop-filter:blur(14px);
  box-shadow:var(--shadow-sm);
  transform:translateY(0%);
  transition:transform var(--transition-base);
}
.site-header.is-visible{transform:translateY(0);}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding-block:0.9rem;
}
.logo-mark{height:40px;width:auto;}

.drawer-toggle{
  display:flex;
  flex-direction:column;
  gap:5px;
  padding:12px;
  min-width:44px;min-height:44px;
  align-items:center;
  justify-content:center;
  border-radius:var(--radius-sm);
  transition:background var(--transition-base);
}
.drawer-toggle:hover{background:var(--color-surface-tint);}
.drawer-toggle-bar{width:22px;height:2px;background:var(--color-text);border-radius:2px;transition:transform var(--transition-base);}

.drawer-backdrop{
  position:fixed;inset:0;background:rgba(30,21,51,0.45);
  opacity:0;pointer-events:none;z-index:150;
  transition:opacity var(--transition-base);
}
body.drawer-open .drawer-backdrop{opacity:1;pointer-events:auto;}

.nav-drawer{
  position:fixed;
  top:0;left:0;
  height:100%;
  width:min(320px,84vw);
  background:var(--color-surface);
  box-shadow:var(--shadow-lg);
  z-index:200;
  transform:translateX(-105%);
  transition:transform var(--transition-base);
  display:flex;
  flex-direction:column;
  padding:1.5rem;
}
.nav-drawer.is-open{transform:translateX(0);}
.drawer-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;}
.drawer-close{min-width:44px;min-height:44px;border-radius:var(--radius-sm);font-size:1.1rem;transition:background var(--transition-base);}
.drawer-close:hover{background:var(--color-surface-tint);}
.nav-drawer ul{list-style:none;display:flex;flex-direction:column;gap:0.25rem;}
.nav-drawer a{
  display:block;
  padding:0.85rem 0.75rem;
  border-radius:var(--radius-sm);
  font-weight:600;
  color:var(--color-text);
  transition:background var(--transition-base), color var(--transition-base), padding-left var(--transition-base);
}
.nav-drawer a:hover,.nav-drawer a[aria-current="page"]{background:var(--color-surface-tint);color:var(--color-primary);padding-left:1.1rem;}
.drawer-contact{margin-top:auto;padding-top:1.5rem;border-top:1px solid var(--color-border);}
.drawer-contact p{display:flex;align-items:center;gap:0.5rem;font-size:0.9rem;margin-bottom:0.6rem;}


.tab-bar{
  display:none;
  position:fixed;
  bottom:0;left:0;right:0;
  background:rgba(255,255,255,0.96);
  backdrop-filter:blur(10px);
  border-top:1px solid var(--color-border);
  box-shadow:0 -4px 16px rgba(36,31,53,0.08);
  z-index:120;
  padding:0.4rem 0.3rem calc(0.4rem + env(safe-area-inset-bottom));
}
.tab-bar-link{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:0.2rem;
  padding:0.4rem 0.2rem;
  min-height:48px;
  font-size:0.65rem;
  font-weight:600;
  color:var(--color-text-muted);
  border-radius:var(--radius-sm);
  transition:color var(--transition-base), background var(--transition-base);
}
.tab-bar-link i{font-size:1.05rem;}
.tab-bar-link.is-active{color:var(--color-primary);background:var(--color-surface-tint);}


.hero-section{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  overflow:hidden;
  padding-block:var(--space-5);
}
.hero-aurora{position:absolute;inset:0;overflow:hidden;z-index:0;}
.hero-aurora .aurora-blob{opacity:0.42;mix-blend-mode:normal;}
.blob-1{width:480px;height:480px;background:var(--aurora-1);top:-120px;left:-80px;animation:auroraDrift1 22s ease-in-out infinite;}
.blob-2{width:420px;height:420px;background:var(--aurora-2);bottom:-100px;left:20%;animation:auroraDrift2 26s ease-in-out infinite;}
.blob-3{width:380px;height:380px;background:var(--aurora-3);top:10%;right:-60px;animation:auroraDrift3 30s ease-in-out infinite;}
.blob-4{width:300px;height:300px;background:var(--aurora-4);bottom:10%;right:15%;animation:auroraDrift1 24s ease-in-out infinite reverse;}

.hero-inner{
  position:relative;z-index:1;
  display:grid;
  grid-template-columns:1.15fr 0.85fr;
  gap:var(--space-4);
  align-items:center;
  opacity:0;
  transform:translateY(24px);
  animation:heroEntrance 1s cubic-bezier(.16,1,.3,1) 0.15s forwards;
}
@keyframes heroEntrance{to{opacity:1;transform:translateY(0);}}

.hero-eyebrow{
  font-family:var(--font-heading);
  font-size:0.85rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:1rem;
  display:inline-block;
}
.highlight-text{
  color:var(--color-primary);
  background:linear-gradient(120deg, rgba(124,92,255,0.15), rgba(232,93,156,0.15));
  padding:0.35rem 0.85rem;
  border-radius:var(--radius-full);
}
.hero-heading{
  font-size:clamp(2.4rem,5.5vw,4.1rem);
  font-weight:700;
  margin-bottom:1.25rem;
  letter-spacing:-0.01em;
}
.hero-heading .char{
  display:inline-block;
  opacity:0;
  transform:translateY(28px);
  animation:charReveal 0.7s cubic-bezier(.16,1,.3,1) forwards;
  animation-delay:calc(var(--char-index) * 0.028s);
}
@keyframes charReveal{to{opacity:1;transform:translateY(0);}}

.hero-lead{font-size:1.1rem;max-width:46ch;color:var(--color-text-muted);}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin:1.5rem 0;}
.hero-meta{display:flex;flex-direction:column;gap:0.5rem;font-size:0.9rem;color:var(--color-text-muted);}
.hero-meta p{display:flex;align-items:center;gap:0.5rem;margin:0;}
.hero-figure{position:relative;}
.hero-figure img{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);}
.hero-figure figcaption{font-size:0.85rem;color:var(--color-text-muted);margin-top:0.75rem;text-align:center;}

.hero-sentinel{height:1px;width:100%;}


.primary-action{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0.5rem;
  background:linear-gradient(120deg, var(--color-primary), var(--color-accent));
  color:#fff;
  padding:0.85rem 1.75rem;
  border-radius:var(--radius-full);
  font-weight:600;
  font-size:0.95rem;
  min-height:48px;
  box-shadow:var(--shadow-md);
  transition:transform var(--transition-base), box-shadow var(--transition-base), filter var(--transition-base);
}
.primary-action:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);color:#fff;filter:brightness(1.05);}
.secondary-action{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0.85rem 1.75rem;
  border-radius:var(--radius-full);
  border:1.5px solid var(--color-primary);
  color:var(--color-primary);
  font-weight:600;
  font-size:0.95rem;
  min-height:48px;
  transition:background var(--transition-base), color var(--transition-base), transform var(--transition-base);
}
.secondary-action:hover{background:var(--color-primary);color:#fff;transform:translateY(-2px);}


.page-hero{
  padding-block:calc(var(--space-6) + 2rem) var(--space-4);
  background:linear-gradient(160deg, rgba(124,92,255,0.08), rgba(46,196,196,0.06));
}
.page-heading{font-size:clamp(2rem,4.5vw,3.2rem);font-weight:700;max-width:20ch;}
.legal-hero{padding-block:calc(var(--space-6) + 1.5rem) var(--space-3);}
.thanks-hero{padding-block:calc(var(--space-6) + 2rem) var(--space-3);}


.content-block{padding-block:var(--space-5);}
.content-block-tint{background:var(--color-surface-tint);}
.section-eyebrow{
  font-family:var(--font-heading);
  font-size:0.8rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--color-secondary);
  margin-bottom:0.5rem;
}
.section-heading{font-size:clamp(1.6rem,3.2vw,2.4rem);max-width:26ch;margin-bottom:1rem;}
.section-lead{font-size:1.05rem;max-width:62ch;}

.scroll-reveal{opacity:0;transform:translateY(28px);transition:opacity 0.8s cubic-bezier(.16,1,.3,1), transform 0.8s cubic-bezier(.16,1,.3,1);}
.scroll-reveal.is-visible{opacity:1;transform:translateY(0);}


.magazine-columns{
  column-count:1;
  column-gap:3rem;
}
@media(min-width:800px){
  .magazine-columns{column-count:2;}
}
.magazine-columns p{margin-bottom:1.25rem;break-inside:avoid;}

.visual-break{
  break-inside:avoid;
  column-span:all;
  margin:2rem 0;
}
.pull-quote{
  background:var(--color-surface);
  border-left:4px solid var(--color-accent);
  padding:1.75rem 2rem;
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-md);
}
.pull-quote p{font-family:var(--font-heading);font-size:1.15rem;color:var(--color-text);line-height:1.5;}
.quote-mark{color:var(--color-accent);font-size:1.6rem;margin-right:0.15rem;}
.pull-quote cite{font-style:normal;font-size:0.85rem;color:var(--color-text-muted);}


.curriculum-layout{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:var(--space-4);
  align-items:start;
}
.content-figure img{box-shadow:var(--shadow-md);}
.content-figure figcaption{font-size:0.85rem;color:var(--color-text-muted);margin-top:0.6rem;}


.features-list{display:flex;flex-direction:column;gap:1.25rem;}
.feature-item{
  background:var(--color-surface);
  border-radius:var(--radius-md);
  padding:1.25rem 1.5rem;
  box-shadow:var(--shadow-sm);
  border:1px solid var(--color-border);
  transition:box-shadow var(--transition-base), transform var(--transition-base);
}
.feature-item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.feature-item dt h3{font-size:1.1rem;margin-bottom:0.35rem;}
.feature-item dd{margin:0;}
.feature-item dd p{margin:0;}


.meter-block{
  margin-top:2rem;
  background:var(--color-surface);
  border-radius:var(--radius-md);
  padding:1.5rem;
  box-shadow:var(--shadow-sm);
  border:1px solid var(--color-border);
}
.meter-block p{margin-bottom:0.5rem;font-weight:600;color:var(--color-text);}
meter{width:100%;height:14px;margin-bottom:0.6rem;}
.meter-note{font-weight:400;color:var(--color-text-muted);font-size:0.9rem;}


.format-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--space-4);
  align-items:center;
}


.lesson-grid{
  list-style:none;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
  margin-top:2rem;
}
.lesson-card{
  background:var(--color-surface);
  border-radius:var(--radius-md);
  padding:1.5rem;
  box-shadow:var(--shadow-sm);
  border:1px solid var(--color-border);
  transition:transform var(--transition-base), box-shadow var(--transition-base);
}
.lesson-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.lesson-card-featured{
  grid-column:span 2;
  background:linear-gradient(135deg, rgba(124,92,255,0.08), rgba(255,111,168,0.08));
  border:1px solid rgba(124,92,255,0.25);
}
.lesson-card hgroup h3{font-size:1.05rem;margin-bottom:0.2rem;}
.lesson-card hgroup p{font-size:0.85rem;color:var(--color-secondary);font-weight:600;margin-bottom:0.75rem;}


.details-block{
  margin-top:2rem;
  background:var(--color-surface);
  border:1px solid var(--color-border);
  border-radius:var(--radius-md);
  padding:1.1rem 1.4rem;
  box-shadow:var(--shadow-sm);
}
.details-block summary{
  font-family:var(--font-heading);
  font-weight:600;
  cursor:pointer;
  list-style:none;
  position:relative;
  padding-right:1.5rem;
}
.details-block summary::-webkit-details-marker{display:none;}
.details-block summary::after{
  content:'+';
  position:absolute;right:0;top:0;
  font-size:1.2rem;color:var(--color-accent);
  transition:transform var(--transition-base);
}
.details-block[open] summary::after{transform:rotate(45deg);}
.details-block p{margin-top:0.85rem;}


.region-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:1.25rem;
  margin-top:2rem;
}
.region-card{
  background:var(--color-surface);
  border-radius:var(--radius-md);
  padding:1.5rem;
  border:1px solid var(--color-border);
  box-shadow:var(--shadow-sm);
  transition:box-shadow var(--transition-base), transform var(--transition-base);
  position:relative;
  overflow:hidden;
}
.region-card::before{
  content:'';
  position:absolute;top:0;left:0;width:4px;height:100%;
  background:linear-gradient(var(--aurora-1), var(--aurora-2));
}
.region-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.region-card hgroup h3{font-size:1.05rem;margin-bottom:0.15rem;}
.region-card hgroup p{font-size:0.8rem;color:var(--color-secondary);font-weight:600;margin-bottom:0.6rem;}


.faq-list{display:flex;flex-direction:column;gap:1rem;margin-top:2rem;}
.faq-item{
  background:var(--color-surface);
  border-radius:var(--radius-md);
  border:1px solid var(--color-border);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.accordion-trigger{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:1.15rem 1.4rem;
  font-family:var(--font-heading);
  font-size:1rem;
  font-weight:500;
  text-align:left;
  color:var(--color-text);
  transition:color var(--transition-base);
}
.accordion-trigger:hover{color:var(--color-primary);}
.accordion-trigger i{transition:transform var(--transition-base);color:var(--color-accent);}
.accordion-trigger[aria-expanded="true"] i{transform:rotate(180deg);}
.accordion-panel{
  max-height:0;
  overflow:hidden;
  padding:0 1.4rem;
  transition:max-height var(--transition-base), padding var(--transition-base);
}
.accordion-panel p{margin:0 0 1.15rem;}


.cta-strip{
  padding-block:var(--space-4);
  background:var(--color-surface-dark);
  color:#fff;
}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;}
.cta-heading{color:#fff;font-size:clamp(1.4rem,2.6vw,2rem);margin-bottom:0.4rem;}
.cta-strip p{color:#CFC6E8;margin:0;}


.timeline{display:flex;flex-direction:column;gap:1.5rem;margin-top:2rem;position:relative;}
.timeline-item{
  display:grid;
  grid-template-columns:100px 1fr;
  gap:1.5rem;
  padding-bottom:1.5rem;
  border-bottom:1px solid var(--color-border);
}
.timeline-item:last-child{border-bottom:none;}
.timeline-item time{
  font-family:var(--font-heading);
  font-weight:700;
  color:var(--color-primary);
  font-size:1.1rem;
}


.contact-layout{
  display:grid;
  grid-template-columns:0.9fr 1.6fr;
  gap:var(--space-4);
  align-items:start;
}
.contact-info-list{list-style:none;display:flex;flex-direction:column;gap:0.85rem;margin:1.5rem 0;}
.contact-info-list li{display:flex;align-items:center;gap:0.75rem;color:var(--color-text-muted);}
.contact-info-list i{color:var(--color-accent);width:20px;}
.contact-note{font-size:0.9rem;}

.form-compact{
  background:var(--color-surface);
  border-radius:var(--radius-lg);
  padding:1.75rem;
  box-shadow:var(--shadow-md);
  border:1px solid var(--color-border);
}
.form-row{display:flex;gap:1.25rem;flex-wrap:wrap;margin-bottom:1.25rem;}
.form-row:last-child{margin-bottom:0;}
.form-field-group{
  flex:2;
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
  border:1px solid var(--color-border);
  border-radius:var(--radius-md);
  padding:1rem;
  margin:0;
  min-width:240px;
}
.form-field-group-message{flex:1;min-width:200px;}
.form-field-group legend{font-family:var(--font-heading);font-size:0.8rem;font-weight:600;padding:0 0.4rem;color:var(--color-secondary);}
.form-field{display:flex;flex-direction:column;gap:0.35rem;flex:1;min-width:140px;}
.form-field label{font-size:0.85rem;font-weight:600;color:var(--color-text);}
.form-field input,.form-field textarea{
  padding:0.7rem 0.85rem;
  border:1px solid var(--color-border);
  border-radius:var(--radius-sm);
  background:var(--color-bg);
  transition:border-color var(--transition-base), box-shadow var(--transition-base);
  resize:vertical;
}
.form-field input:focus,.form-field textarea:focus{
  outline:none;
  border-color:var(--color-primary);
  box-shadow:0 0 0 3px rgba(76,53,117,0.15);
}
.form-row-actions{align-items:center;justify-content:space-between;}
.privacy-group{border:none;padding:0;margin:0;flex:1;min-width:220px;}
.checkbox-label{display:flex;align-items:flex-start;gap:0.6rem;font-size:0.85rem;color:var(--color-text-muted);}
.checkbox-label input{margin-top:0.2rem;min-width:20px;min-height:20px;}

.map-frame{
  margin-top:1.5rem;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-md);
  border:1px solid var(--color-border);
}
.map-frame iframe{width:100%;height:360px;border:0;display:block;}

.news-list{list-style:none;display:flex;flex-direction:column;gap:1.5rem;margin-top:2rem;}
.news-item{
  background:var(--color-surface);
  border-radius:var(--radius-md);
  padding:1.5rem;
  border:1px solid var(--color-border);
  box-shadow:var(--shadow-sm);
}
.news-item time{
  font-size:0.8rem;
  font-weight:600;
  color:var(--color-secondary);
  text-transform:uppercase;
  letter-spacing:0.04em;
}
.news-item hgroup h3{font-size:1.05rem;margin:0.5rem 0 0.1rem;}
.news-item hgroup p{font-size:0.85rem;color:var(--color-accent);margin-bottom:0.6rem;}


.legal-content{display:flex;flex-direction:column;gap:1rem;max-width:820px;margin-inline:auto;}
.legal-accordion{
  background:var(--color-surface);
  border:1px solid var(--color-border);
  border-radius:var(--radius-md);
  padding:1.25rem 1.5rem;
  box-shadow:var(--shadow-sm);
}
.legal-accordion summary{
  font-family:var(--font-heading);
  font-weight:600;
  cursor:pointer;
  list-style:none;
  position:relative;
  padding-right:1.75rem;
  font-size:1.05rem;
}
.legal-accordion summary::-webkit-details-marker{display:none;}
.legal-accordion summary::after{
  content:'\002B';
  position:absolute;right:0;top:0;
  color:var(--color-accent);font-size:1.3rem;
  transition:transform var(--transition-base);
}
.legal-accordion[open] summary::after{transform:rotate(45deg);}
.legal-accordion p{margin-top:0.85rem;}


.site-footer{
  background:var(--color-surface-dark);
  color:#D9D2EE;
  padding-top:var(--space-4);
  margin-top:var(--space-5);
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1.2fr;
  gap:var(--space-4);
  padding-bottom:var(--space-3);
}
.footer-brand p{color:#B9AFD6;font-size:0.9rem;margin-top:1rem;}
.footer-links hgroup h3,.footer-contact hgroup h3{color:#fff;font-size:1rem;margin-bottom:1rem;}
.footer-links ul{list-style:none;display:flex;flex-direction:column;gap:0.6rem;}
.footer-links a{color:#B9AFD6;font-size:0.9rem;}
.footer-links a:hover{color:#fff;}
.footer-contact address{font-style:normal;font-size:0.9rem;color:#B9AFD6;}
.footer-contact p{margin-bottom:0.5rem;}
.footer-contact a{color:#B9AFD6;}
.footer-contact a:hover{color:#fff;}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding-block:1.25rem;font-size:0.8rem;color:#9C90BC;}


@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;}
  .hero-figure{order:-1;max-width:340px;margin-inline:auto;}
  .curriculum-layout,.format-layout,.contact-layout{grid-template-columns:1fr;}
  .lesson-grid{grid-template-columns:repeat(2,1fr);}
  .lesson-card-featured{grid-column:span 2;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}

@media(max-width:640px){
  .lesson-grid{grid-template-columns:1fr;}
  .lesson-card-featured{grid-column:span 1;}
  .footer-grid{grid-template-columns:1fr;}
  .cta-inner{flex-direction:column;align-items:flex-start;}
  .timeline-item{grid-template-columns:1fr;gap:0.4rem;}
  .form-row-actions{flex-direction:column;align-items:stretch;gap:1rem;}
  .form-row-actions button{width:100%;}

  .drawer-toggle{display:none;}
  .tab-bar{display:flex;}
  body{padding-bottom:70px;}
  .site-header{position:sticky;transform:translateY(0);}
}

@media(min-width:641px){
  .tab-bar{display:none;}
}