:root{
    --sky:      #4FA3C7;
    --sky-tint: #E7F4F8;
    --grass:    #6FA85C;
    --grass-tint:#EEF6E9;
    --sunshine: #F2B705;
    --sunshine-tint:#FDF3D9;
    --coral:    #E8674A;
    --coral-tint:#FBE9E3;
    --ink:      #2E2A26;
    --paper:    #FFFDF8;
    --cream:    #FBF6EC;
    --cork:     #C9995F;
    --cork-tint:#EFDCC0;
    --radius:   22px;
  }

  *{ box-sizing:border-box; }
  [hidden]{ display:none !important; }
  button{
    appearance:none;
    -webkit-appearance:none;
    font-family:inherit;
    color:inherit;
  }
  html{ scroll-behavior:smooth; }
  body{
    margin:0;
    font-family:'Nunito', sans-serif;
    color:var(--ink);
    background:var(--paper);
    line-height:1.6;
    font-size:clamp(15px, 1.4vw + 11px, 17px);
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
    overflow-wrap:break-word;
    word-break:break-word;
  }
  h1,h2,h3,.brand{
    font-family:'Baloo 2', sans-serif;
    margin:0;
    line-height:1.15;
  }
  a{ color:inherit; }
  img,svg{ display:block; max-width:100%; }
  .wrap{
    max-width:1120px;
    margin:0 auto;
    padding:0 28px;
  }

  /* ---------- Accessibility helpers ---------- */
  .skip-link{
    position:fixed;
    top:-60px; left:12px;
    z-index:10002;
    background:var(--ink);
    color:var(--paper);
    font-weight:800;
    padding:12px 20px;
    border-radius:0 0 10px 10px;
    text-decoration:none;
    transition:top .2s ease;
  }
  .skip-link:focus{ top:0; }

  a:focus-visible,
  button:focus-visible,
  .btn:focus-visible,
  .social-icon:focus-visible,
  input:focus-visible,
  textarea:focus-visible{
    outline:3px solid var(--coral);
    outline-offset:3px;
    border-radius:6px;
  }

  section[id]{ scroll-margin-top:100px; }
  @media (max-width:1300px){
    section[id]{ scroll-margin-top:84px; }
  }
  .btn{
    display:inline-flex;
    align-items:center;
    gap:10px;
    font-family:'Nunito', sans-serif;
    font-weight:800;
    font-size:1rem;
    padding:14px 26px;
    border-radius:999px;
    border:3px solid var(--ink);
    text-decoration:none;
    cursor:pointer;
    transition:transform .15s ease, box-shadow .15s ease;
    box-shadow:4px 4px 0 var(--ink);
    background:var(--sunshine);
    color:var(--ink);
  }
  .btn:hover{ transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
  .btn:active{ transform:translate(1px,1px); box-shadow:2px 2px 0 var(--ink); }
  .btn.secondary{ background:var(--paper); }
  .btn.small{ padding:10px 18px; font-size:.9rem; }

  .eyebrow{
    display:inline-block;
    font-weight:800;
    letter-spacing:.06em;
    text-transform:uppercase;
    font-size:.78rem;
    padding:6px 14px;
    border-radius:999px;
    background:var(--ink);
    color:var(--paper);
  }

  /* ---------- Header ---------- */
  header{
    position:sticky;
    top:0;
    z-index:50;
    background:var(--paper);
    border-bottom:3px solid var(--ink);
    transition:box-shadow .2s ease;
  }
  header.scrolled{ box-shadow:0 6px 16px rgba(43,38,26,.12); }
  .nav-inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:14px 28px;
    max-width:1280px;
    margin:0 auto;
    gap:12px;
  }
  .brand{
    font-size:1.35rem;
    font-weight:800;
    display:flex;
    align-items:center;
    gap:10px;
    text-decoration:none;
    color:var(--ink);
    flex:none;
  }
  .brand-text{ white-space:nowrap; }
  .brand .dot{
    width:14px; height:14px; border-radius:50%;
    background:var(--coral);
    border:2px solid var(--ink);
    display:inline-block;
    flex:none;
  }
  nav ul{
    list-style:none;
    display:flex;
    gap:28px;
    margin:0;
    padding:0;
  }
  nav a{
    text-decoration:none;
    font-weight:700;
    font-size:.98rem;
    position:relative;
    white-space:nowrap;
  }
  nav a::after{
    content:'';
    position:absolute; left:0; bottom:-6px;
    width:0; height:3px; background:var(--coral);
    transition:width .2s ease;
  }
  nav a:hover::after, nav a.active::after{ width:100%; }
  nav a.active{ color:var(--coral); }
  .nav-right{ display:flex; align-items:center; gap:14px; }
  .social-icon{
    width:40px; height:40px;
    display:flex; align-items:center; justify-content:center;
    border:2px solid var(--ink);
    border-radius:50%;
    color:var(--ink);
    flex:none;
    transition:background .15s ease, color .15s ease, transform .15s ease;
  }
  .social-icon:hover{ background:var(--coral); color:var(--paper); transform:translateY(-2px); }
  .call-icon{
    display:none;
    width:44px; height:44px;
    align-items:center; justify-content:center;
    border:2px solid var(--ink);
    border-radius:50%;
    color:var(--ink);
    flex:none;
    background:var(--sunshine);
    transition:transform .15s ease, box-shadow .15s ease;
    box-shadow:3px 3px 0 var(--ink);
  }
  .call-icon:hover{ transform:translate(-1px,-1px); box-shadow:4px 4px 0 var(--ink); }
  .call-icon:active{ transform:translate(1px,1px); box-shadow:1px 1px 0 var(--ink); }
  .menu-toggle{
    display:none;
    position:relative;
    background:none; border:2px solid var(--ink); border-radius:10px;
    width:44px; height:44px; cursor:pointer;
    flex:none;
  }
  .menu-toggle .bar{
    display:block;
    position:absolute;
    left:50%; top:50%;
    width:20px; height:2.5px;
    background:var(--ink);
    border-radius:2px;
    transition:transform .25s ease, opacity .2s ease;
  }
  .menu-toggle .bar:nth-child(1){ transform:translate(-50%,-7px); }
  .menu-toggle .bar:nth-child(2){ transform:translate(-50%,-50%); }
  .menu-toggle .bar:nth-child(3){ transform:translate(-50%,6px); }
  .menu-toggle.open .bar:nth-child(1){ transform:translate(-50%,-50%) rotate(45deg); }
  .menu-toggle.open .bar:nth-child(2){ opacity:0; }
  .menu-toggle.open .bar:nth-child(3){ transform:translate(-50%,-50%) rotate(-45deg); }

  @media (max-width:520px){
    .brand{ font-size:1.1rem; gap:8px; }
    .brand-sub{ display:none; }
    .nav-right .social-icon{ display:none; }
    .nav-inner{ gap:8px; }
  }

  @media (max-width:1300px){
    .nav-inner{ padding:12px 20px; }
    nav{
      position:absolute; top:100%; left:0; right:0;
      background:var(--paper); border-bottom:3px solid var(--ink);
      max-height:0;
      overflow:hidden;
      opacity:0;
      transition:max-height .3s ease, opacity .25s ease;
    }
    nav.open{ max-height:420px; opacity:1; }
    nav ul{ flex-direction:column; gap:0; padding:10px 20px 20px; }
    nav ul li{ border-top:1px solid #e7e2d6; }
    nav ul li a{ display:block; padding:15px 4px; }
    .call-icon{ display:flex; margin-left:auto; }
    .menu-toggle{ display:block; }
    .nav-right .btn{ display:none; }
  }

  /* ---------- Scallop dividers (torn-paper effect) ---------- */
  .scallop{
    position:relative;
    height:26px;
    margin-top:-1px;
  }
  .scallop-sunshine{ background-image: radial-gradient(circle at 13px 0, transparent 13px, var(--sunshine-tint) 13.5px); background-size:26px 26px; background-repeat:repeat-x; background-color:var(--paper); }
  .scallop-grass{ background-image: radial-gradient(circle at 13px 0, transparent 13px, var(--grass-tint) 13.5px); background-size:26px 26px; background-repeat:repeat-x; background-color:var(--sunshine-tint); }
  .scallop-coral{ background-image: radial-gradient(circle at 13px 0, transparent 13px, var(--coral-tint) 13.5px); background-size:26px 26px; background-repeat:repeat-x; background-color:var(--grass-tint); }
  .scallop-paper{ background-image: radial-gradient(circle at 13px 0, transparent 13px, var(--paper) 13.5px); background-size:26px 26px; background-repeat:repeat-x; background-color:var(--coral-tint); }
  .scallop-cork{ background-image: radial-gradient(circle at 13px 0, transparent 13px, var(--cork-tint) 13.5px); background-size:26px 26px; background-repeat:repeat-x; background-color:var(--paper); }
  .scallop-ink{ background-image: radial-gradient(circle at 13px 0, transparent 13px, var(--ink) 13.5px); background-size:26px 26px; background-repeat:repeat-x; background-color:var(--cork-tint); }

  section{ position:relative; }

  /* ---------- Hero ---------- */
  .hero{
    background:var(--paper);
    padding:72px 0 46px;
  }
  .hero .wrap{
    display:grid;
    grid-template-columns:1.05fr .95fr;
    gap:48px;
    align-items:center;
  }
  .hero h1{
    font-size:clamp(2.2rem, 4vw, 3.4rem);
    margin:16px 0 18px;
  }
  .hero h1 .accent{ color:var(--coral); }
  .hero p.lead{
    font-size:1.15rem;
    max-width:46ch;
    margin-bottom:28px;
  }
  .hero .cta-row{ display:flex; gap:16px; flex-wrap:wrap; margin-bottom:22px; }
  .hero .trust{
    display:flex; gap:22px; flex-wrap:wrap;
    font-weight:700; font-size:.92rem; color:#5b564c;
  }
  .hero .trust span{ display:flex; align-items:center; gap:8px; }

  .hero-art{ position:relative; }
  .hero-art svg{ width:100%; height:auto; }

  .photo-album{
    position:relative;
    width:100%;
    max-width:420px;
    margin:0 auto;
  }
  .photo-album-frame{
    position:relative;
    width:100%;
    aspect-ratio:420/380;
    background:var(--paper);
    border:4px solid var(--ink);
    border-radius:var(--radius);
    box-shadow:8px 8px 0 var(--ink);
    overflow:hidden;
  }
  .photo-album-frame img{
    position:absolute; inset:0;
    width:100%; height:100%;
    object-fit:cover;
    transform:translateX(100%);
    transition:transform .85s cubic-bezier(.65,.05,.36,1);
  }
  .photo-album-frame img.pos-current{ transform:translateX(0); z-index:2; }
  .photo-album-frame img.pos-next{ transform:translateX(100%); z-index:1; }
  .photo-album-frame img.pos-prev{ transform:translateX(-100%); z-index:1; }
  .photo-album .tape.big{
    position:absolute;
    top:-16px; left:50%;
    width:84px; height:30px;
    transform:translateX(-50%) rotate(-3deg);
    opacity:.9;
    z-index:2;
    border:1px solid rgba(0,0,0,.08);
  }

  /* ---------- About ---------- */
  .about{ background:var(--sunshine-tint); padding:64px 0 56px; }
  .about-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:48px; align-items:stretch; }
  .about-grid > *{ min-width:0; }
  .about h2{ font-size:clamp(1.7rem, 3.2vw + 1rem, 2.2rem); margin:14px 0 16px; }
  .badge-row{ display:flex; gap:14px; margin-top:26px; flex-wrap:wrap; }
  .badge{
    background:var(--paper);
    border:3px solid var(--ink);
    border-radius:16px;
    padding:14px 18px;
    font-weight:800;
    box-shadow:4px 4px 0 var(--ink);
    display:flex; align-items:center; gap:10px;
    font-size:.92rem;
  }

  /* ---------- Interactive stacking rings (drag to move) ---------- */
  .hanoi-wrap{
    display:flex;
    min-height:340px;
  }
  .hanoi-board{
    display:flex; justify-content:space-around; align-items:flex-end;
    flex:1;
    background:
      radial-gradient(circle at 15% 12%, var(--sunshine-tint) 0%, transparent 42%),
      radial-gradient(circle at 85% 18%, var(--coral-tint) 0%, transparent 42%),
      var(--sky-tint);
    border:3px solid var(--ink);
    border-radius:var(--radius);
    box-shadow:6px 6px 0 var(--ink);
    padding:30px 14px 0;
    gap:10px;
  }
  .hanoi-peg{
    position:relative;
    flex:1;
    height:100%;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:flex-end;
  }
  .hanoi-peg.drop-target .hanoi-base{ background:var(--coral); }
  .hanoi-rod{
    position:absolute;
    bottom:16px; left:50%;
    transform:translateX(-50%);
    width:12px;
    height:calc(100% - 40px);
    background:var(--ink);
    border-radius:6px 6px 0 0;
    z-index:1;
    pointer-events:none;
  }
  .hanoi-base{
    width:100%; max-width:190px; height:16px;
    background:var(--ink);
    border-radius:6px;
    position:relative;
    z-index:2;
    pointer-events:none;
    transition:background .15s ease;
  }
  .hanoi-stack{
    position:relative;
    z-index:3;
    display:flex;
    flex-direction:column-reverse;
    align-items:center;
    gap:7px;
    margin-bottom:0;
  }
  .hanoi-disk{
    height:30px;
    border-radius:999px;
    border:3px solid var(--ink);
    box-shadow:2px 2px 0 rgba(0,0,0,.15);
    touch-action:none;
  }
  .hanoi-disk[data-size="1"]{ width:58px; background:var(--coral); }
  .hanoi-disk[data-size="2"]{ width:86px; background:var(--sky); }
  .hanoi-disk[data-size="3"]{ width:114px; background:var(--grass); }
  .hanoi-disk[data-size="4"]{ width:142px; background:var(--sunshine); }
  .hanoi-disk.draggable{ cursor:grab; }
  .hanoi-disk.dragging{
    position:fixed;
    z-index:1000;
    cursor:grabbing;
    box-shadow:4px 6px 0 rgba(0,0,0,.25);
    pointer-events:none;
  }

  @media (max-width:900px){
    .hanoi-wrap{ min-height:300px; }
  }
  @media (max-width:520px){
    .hanoi-wrap{ min-height:250px; }
    .hanoi-disk{ height:24px; }
    .hanoi-disk[data-size="1"]{ width:44px; }
    .hanoi-disk[data-size="2"]{ width:64px; }
    .hanoi-disk[data-size="3"]{ width:84px; }
    .hanoi-disk[data-size="4"]{ width:104px; }
  }

  /* ---------- Programs ---------- */
  .programs{ background:var(--grass-tint); padding:66px 0 60px; }
  .section-head{ max-width:640px; margin-bottom:40px; }
  .section-head h2{ font-size:clamp(1.7rem, 3.2vw + 1rem, 2.2rem); margin:14px 0 12px; }
  .card-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
  .card{
    background:var(--paper);
    border:3px solid var(--ink);
    border-radius:var(--radius);
    padding:28px 24px;
    box-shadow:6px 6px 0 var(--ink);
    transition:transform .18s ease, box-shadow .18s ease, opacity .6s ease;
  }
  .card:hover{ transform:translate(-3px,-3px); box-shadow:9px 9px 0 var(--ink); }
  .card .icon{
    width:56px; height:56px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    margin-bottom:16px; border:3px solid var(--ink);
  }
  .card h3{ font-size:1.2rem; margin-bottom:8px; }
  .card p{ margin:0; color:#4a463d; font-size:.97rem; }

  /* ---------- Day rhythm / timeline ---------- */
  .rhythm{ background:var(--coral-tint); padding:66px 0 60px; }
  .timeline{ display:grid; grid-template-columns:repeat(6,1fr); gap:16px; }
  .tl-item{
    background:var(--paper);
    border:3px solid var(--ink);
    border-radius:16px;
    padding:18px 14px;
    text-align:center;
    font-weight:700;
    font-size:.88rem;
  }
  .tl-item .time{
    display:block; font-family:'Baloo 2',sans-serif; font-size:1rem;
    color:var(--coral); margin-bottom:6px;
  }
  .rhythm-note{ margin-top:22px; font-size:.9rem; color:#5b564c; text-align:center; }

  /* ---------- Why us ---------- */
  .why{ background:var(--paper); padding:66px 0 60px; }
  .why-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
  .why-item{ text-align:center; padding:14px; }
  .why-item .icon{
    width:64px; height:64px; margin:0 auto 14px;
    border-radius:50%; border:3px solid var(--ink);
    display:flex; align-items:center; justify-content:center;
  }
  .why-item h3{ font-size:1.05rem; margin-bottom:6px; }
  .why-item p{ font-size:.9rem; color:#4a463d; margin:0; }

  /* ---------- Contact ---------- */
  .contact{ background:var(--ink); color:var(--paper); padding:66px 0 60px; }
  .contact .eyebrow{ background:var(--sunshine); color:var(--ink); }
  .contact h2{ font-size:clamp(1.7rem, 3.2vw + 1rem, 2.2rem); margin:14px 0 20px; color:var(--paper); }
  .contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:start; }
  .contact-grid > *{ min-width:0; }
  .info-list{ list-style:none; padding:0; margin:0 0 26px; }
  .info-list li{
    display:flex; gap:14px; align-items:flex-start;
    margin-bottom:18px; font-weight:700;
  }
  .info-list .icon{
    width:38px; height:38px; flex:none;
    border-radius:50%; background:var(--paper); color:var(--ink);
    display:flex; align-items:center; justify-content:center;
    border:2px solid var(--paper);
  }
  .info-list a{ text-decoration:underline; }
  .map-frame{
    border:4px solid var(--sunshine);
    border-radius:var(--radius);
    overflow:hidden;
    height:340px;
  }
  .map-frame iframe{ width:100%; height:100%; border:0; }

  .full-sm{ }
  @media (max-width:520px){
    .full-sm{ width:100%; justify-content:center; }
    .map-frame{ height:260px; }
  }

  /* ---------- Gallery / Corkboard ---------- */
  .gallery{
    background-color:var(--cork-tint);
    background-image:
      radial-gradient(circle, rgba(0,0,0,.06) 1px, transparent 1.4px);
    background-size:14px 14px;
    padding:66px 0 70px;
  }
  .corkboard{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:34px 26px;
    padding:10px 0 6px;
  }
  .polaroid{
    background:var(--paper);
    border:1px solid #e4d8c2;
    border-radius:4px;
    padding:12px 12px 22px;
    box-shadow:0 10px 18px rgba(43,38,26,.22);
    transform:rotate(var(--rot,0deg));
    transition:transform .25s ease, box-shadow .25s ease, opacity .7s ease;
    position:relative;
  }
  .polaroid:hover{
    transform:rotate(0deg) scale(1.04);
    box-shadow:0 16px 26px rgba(43,38,26,.28);
    z-index:2;
  }
  .polaroid .tape{
    position:absolute;
    top:-14px; left:50%;
    width:64px; height:26px;
    transform:translateX(-50%) rotate(-4deg);
    opacity:.85;
    border:1px solid rgba(0,0,0,.08);
  }
  .photo-frame{
    display:block;
    position:relative;
    width:100%;
    aspect-ratio:1/1;
    overflow:hidden;
    background:var(--sky-tint);
  }
  .photo-frame img{
    position:absolute; inset:0;
    width:100%; height:100%;
    object-fit:cover;
    opacity:0;
    transition:opacity 1s ease;
  }
  .photo-frame img.visible{ opacity:1; }
  .gallery-note{
    text-align:center;
    font-weight:700;
    background:var(--paper);
    border:3px dashed var(--ink);
    border-radius:16px;
    padding:22px;
    margin-top:10px;
  }
  .gallery-note code{
    background:var(--sunshine-tint);
    padding:2px 6px;
    border-radius:6px;
  }

  @media (max-width:860px){
    .corkboard{ grid-template-columns:repeat(2, 1fr); }
  }
  @media (max-width:520px){
    .corkboard{ grid-template-columns:1fr 1fr; gap:22px 14px; }
    .polaroid{ padding:8px 8px 16px; }
    .polaroid .tape{ width:46px; height:20px; top:-10px; }
  }

  /* ---------- Footer ---------- */
  footer{
    background:var(--ink);
    color:#c9c4b8;
    padding:24px 0 30px;
    border-top:3px solid var(--sunshine);
  }
  .footer-inner{
    display:flex; justify-content:space-between; align-items:center;
    flex-wrap:wrap; gap:14px; font-size:.85rem;
  }
  .footer-inner a{ color:var(--sunshine); text-decoration:none; font-weight:700; }
  .footer-links{ display:flex; gap:18px; }

  @media (max-width:900px){
    .hero .wrap{ grid-template-columns:1fr; }
    .hero-art{ order:-1; max-width:360px; margin:0 auto; }
    .about-grid{ grid-template-columns:1fr; }
    .card-grid{ grid-template-columns:1fr 1fr; }
    .timeline{ grid-template-columns:repeat(3,1fr); }
    .why-grid{ grid-template-columns:1fr 1fr; }
    .contact-grid{ grid-template-columns:1fr; }
  }
  @media (max-width:520px){
    .card-grid{ grid-template-columns:1fr; }
    .timeline{ grid-template-columns:repeat(2,1fr); }
    .why-grid{ grid-template-columns:1fr; }
    .hero .cta-row .btn{ width:100%; justify-content:center; }
    .hero-art{ max-width:230px; }
  }

  /* ---------- Tighter rhythm on small screens ---------- */
  @media (max-width:600px){
    .hero{ padding:40px 0 34px; }
    .about, .programs, .rhythm, .why, .gallery, .contact{ padding:46px 0 44px; }
    .section-head{ margin-bottom:28px; }
    .wrap{ padding:0 20px; }
    .card-grid{ gap:18px; }
    .why-grid{ gap:16px; }
    .badge-row{ gap:10px; }
    .badge{ padding:11px 15px; font-size:.86rem; }
    footer{ padding:20px 0 26px; }
    .footer-inner{ flex-direction:column; align-items:flex-start; gap:10px; }
  }

  /* ---------- Scroll reveal ---------- */
  .reveal{
    opacity:0;
    transform:translateY(22px);
    transition:opacity .6s ease, transform .6s ease;
  }
  .reveal.in-view{
    opacity:1;
    transform:none;
  }
  .reveal-fade{ opacity:0; }
  .reveal-fade.in-view{ opacity:1; }

  @media (prefers-reduced-motion: reduce){
    *{ transition:none !important; scroll-behavior:auto !important; }
    .reveal, .reveal-fade{ opacity:1 !important; transform:none !important; }
  }

  /* ---------- Custom playful cursor ---------- */
  html.cursor-fun, html.cursor-fun *{ cursor:none !important; }

  .cursor-shape{
    position:fixed;
    top:0; left:0;
    width:34px; height:34px;
    margin-left:-17px;
    margin-top:-17px;
    object-fit:contain;
    transform:scale(1);
    transition:transform .16s cubic-bezier(.34,1.56,.64,1), opacity .15s ease;
    pointer-events:none;
    z-index:10000;
    opacity:0;
    filter:drop-shadow(1px 2px 2px rgba(0,0,0,.28));
  }
  .cursor-shape.swap{ opacity:.4; transform:scale(.4) rotate(-12deg); }
  .cursor-shape.clickable{ transform:scale(1.25); }

  @media (hover:none), (pointer:coarse){
    .cursor-shape{ display:none; }
  }
