  :root{
    --bg:#efe7ff;
    --card:#fff6fb;
    --muted:#6c5776;
    --accent:#c3a1ff;
    --accent-2:#fbcfe8;
    --text:#2b1f2f;
    --radius:18px;
    --max-width:1100px;
  }
  *{box-sizing:border-box}
  html,body{height:100%}
  body{
    margin:0;
    font-family:'Nunito',system-ui,Segoe UI,Roboto,-apple-system,"Helvetica Neue",Arial;
    background:linear-gradient(180deg,var(--bg) 0%, #f7eefb 100%);
    color:var(--text);
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
    line-height:1.45;
  }

  /* page container */
  .wrap{
    max-width:var(--max-width);
    margin:28px auto;
    padding:24px;
  }

  /* header */
  header.site-header{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    margin-bottom:18px;
  }
  .brand{
    display:flex;
    align-items:center;
    gap:12px;
    text-decoration:none;
    color:var(--text);
  }
  .brand .logo{
    width:56px;height:56px;border-radius:12px;background:linear-gradient(135deg,#ffcb8d,#ffb3d2);
    display:flex;align-items:center;justify-content:center;font-weight:800;color:#65324a;font-size:26px;
    box-shadow: 0 6px 18px rgba(0,0,0,0.08);
  }
  .brand h1{margin:0;font-size:20px;font-weight:800;letter-spacing:0.2px}

  /* nav */
  nav{
    display:flex;
    gap:12px;
    align-items:center;
  }
  .nav-item{position:relative}
  .nav-links{
    display:flex;
    gap:10px;
    align-items:center;
  }
  a.nav-btn{
    text-decoration:none;
    color:var(--muted);
    padding:8px 12px;
    border-radius:10px;
    font-weight:700;
    transition:all .18s;
  }
  a.nav-btn:hover, a.nav-btn:focus{background:rgba(0,0,0,0.03); color:var(--text); outline:none}
/* dropdown */
.dropdown {
  position: relative;
  display: inline-block;
}

.dropdown-checkbox {
  display: none; /* hide checkbox */
}

.dropdown-toggle {
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 10px;
  font-weight: 700;
  color: var(--muted);
  background: transparent;
  border: none;
  user-select: none;
}

/* menu hidden by default */
.menu {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  min-width: 200px;
  background: var(--card);
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(20,10,30,.08);
  padding: 10px;
  display: none;
  z-index: 40;
}

/* show menu when checkbox is checked */
.dropdown-checkbox:checked ~ .menu {
  display: block;
}

.menu a {
  display: block;
  padding: 8px 10px;
  text-decoration: none;
  color: var(--text);
  border-radius: 8px;
}

.menu a:hover {
  background: rgba(0,0,0,0.03);
}
  /* hero */
  .hero{
    background:linear-gradient(180deg, rgba(255,182,193,1), rgba(198,50,135,1));
    border-radius:var(--radius);
    overflow:hidden;
    display:grid;
    grid-template-columns: 1fr 380px;
    gap:18px;
    align-items:center;
    padding:0;
    box-shadow: 0 12px 40px rgba(50,20,60,0.06);
  }
  .hero .hero-image{
    min-height:220px;
    background-size:cover;
    background-position:center center;
    position:relative;
    padding:28px;
    display:flex;
    align-items:center;
  }
  .hero .hero-image .intro{
    color: #fff;
    text-shadow: 0 6px 18px rgba(0,0,0,0.25);
    max-width:580px;
  }
  .intro h2{margin:0;font-size:36px;line-height:1.02}
  .intro p{margin:8px 0 0;font-weight:700;opacity:.95}

  .hero .hero-avatar{
    padding:26px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(180deg, rgba(255,182,193,1), rgba(198,50,135,1));
  }
  .avatar{
    width:220px;height:220px;border-radius:16px; overflow:hidden;display:block;
    box-shadow:0 8px 30px rgba(0,0,0,0.08);
  }

  /* main card sections */
  .card{
    background:var(--card);
    border-radius:var(--radius);
    padding:22px;
    margin-top:18px;
    box-shadow: 0 10px 26px rgba(40,20,50,0.03);
  }
  .h2{
    margin:0 0 10px 0;
    font-size:22px;
    color:var(--muted);
    font-weight:800;
  }
  .about-grid{
    display:flex;gap:18px;align-items:center;
  }
  .about-grid .about-text{flex:1}
  .about-grid .about-pic{
    width:120px;height:120px;border-radius:999px;overflow:hidden;
    box-shadow:0 8px 20px rgba(0,0,0,0.06);
  }
  p.lead{margin:0;color:#3a2b3e}

/* FAQ Accordion */
.acc-item {
  border-radius: 12px;
  background: rgba(255,255,255,0.6);
  margin-top: 10px;
  overflow: hidden;
  padding: 0;
}

.acc-head {
  padding: 14px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  list-style: none; /* remove default triangle */
}

.acc-head::-webkit-details-marker {
  display: none; /* remove marker in Chrome/Safari */
}

.acc-head h3 {
  margin: 0;
  font-size: 15px;
  color: var(--muted);
}

.acc-body {
  padding: 0 18px 18px 18px;
  color: #463545;
}
.acc-head::after {
  content: "+";
  font-weight: bold;
  transition: transform 0.2s;
}

.acc-item[open] .acc-head::after {
  content: "–";
}

  /* gallery */
  .gallery-grid{
    display:grid;
    grid-template-columns: repeat(auto-fill,minmax(150px,1fr));
    gap:12px;
    margin-top:12px;

  /* new scroll settings */
  max-height: 600px;      /* adjust this to fit your design */
  overflow-y: scroll;       /* enables vertical scrollbar if content exceeds height */
  padding-right: 6px;     /* avoid content touching scrollbar */
  }
  .thumb{
    border-radius:12px;overflow:hidden;cursor:pointer;position:relative;
    background:#fff;padding:8px;display:block;
  }
  .thumb img{display:block;width:100%;height:140px;object-fit:cover;border-radius:8px}
  /* tabs */
  .tabs{display:flex;gap:8px}
  .tab-btn{padding:8px 12px;border-radius:12px;border:none;background:transparent;font-weight:800;cursor:pointer}
  .tab-btn.active{background:linear-gradient(90deg,var(--accent),#ffd6f1);color:#3c2142}


  /* lightbox modal */
  .lightbox{
    position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(10,6,12,0.6);
    z-index:80;padding:24px;
  }
  .lightbox .box{max-width:1100px;width:100%;background:var(--card);border-radius:16px;overflow:hidden}
  .lightbox img{display:block;width:100%;height:auto}
  .lightbox .meta{padding:12px 16px;display:flex;justify-content:space-between;align-items:center}

  /* contact form */
.contact {
  max-width: 500px;
  margin: 40px auto;
  padding: 20px;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  font-family: Arial, sans-serif;
}

.contact h2 {
  text-align: center;
  margin-bottom: 20px;
  font-size: 1.5rem;
  color: #333;
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.contact-form label {
  font-weight: bold;
  color: #444;
}

.contact-form input,
.contact-form textarea {
  padding: 10px;
  border: 1px solid #ccc;
  border-radius: 8px;
  font-size: 1rem;
  width: 100%;
}

.contact-form input:focus,
.contact-form textarea:focus {
  outline: none;
  border-color: #ff69b4; /* pink highlight */
  box-shadow: 0 0 5px rgba(255,105,180,0.4);
}

.contact-form button {
  background: #ff69b4;
  color: white;
  font-size: 1rem;
  padding: 12px;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.3s;
}

.contact-form button:hover {
  background: #e75492;
}

  /* footer */
  footer{margin-top:22px;text-align:center;color:var(--muted);font-size:14px;padding:12px}

  /* small screens */
  @media (max-width:900px){
    .hero{grid-template-columns:1fr; padding:0}
    .hero .hero-avatar{order:-1}
    .hero .hero-image{min-height:240px;padding:20px}
    .wrap{padding:16px}
    .brand h1{font-size:18px}
  }

  /* mobile nav button */
  .mobile-toggle{display:none}
  @media(max-width:700px){
    nav{display:flex;gap:6px}
    .nav-links{display:none}
    .mobile-toggle{display:inline-flex;padding:8px;border-radius:10px;cursor:pointer;background:rgba(0,0,0,0.05)}
  }