/* ===================================================
   MOONVIEW STUDIO — Japandi Edition
   Extreme restraint. Negative space. Thin lines.
   Desaturated warmth. Nothing without intention.
   =================================================== */

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --white:#F5F2EC;
  --greige:#E0D8CC;
  --clay:#9A7A5A;
  --clay2:#7A5A3A;
  --charcoal:#1E1C18;
  --mid:#8A8278;
  --fd:"Noto Serif",Georgia,serif;
  --fb:"Inter",system-ui,sans-serif;
}

html{scroll-behavior:smooth}
body{font-family:var(--fb);font-weight:300;background:var(--white);color:var(--charcoal);overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{display:block;width:100%;height:100%;object-fit:cover;filter:saturate(.78) brightness(.93)}
.wrap{max-width:1120px;margin:0 auto;padding:0 64px}

/* ---------- TYPOGRAPHY ---------- */
h1,h2,h3,h4{font-family:var(--fd);font-weight:300;line-height:1.2}

.section-label{
  font-family:var(--fb);font-size:9px;font-weight:300;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--clay);display:block;margin-bottom:48px;
}

.section-title{
  font-family:var(--fd);font-size:clamp(30px,3vw,46px);
  font-weight:300;font-style:italic;color:var(--charcoal);line-height:1.2;
}
.section-title strong{font-style:normal;font-weight:400;display:block}

.rule{width:40px;height:1px;background:var(--clay);opacity:.6}

/* ---------- BUTTONS ---------- */
.btn{
  font-family:var(--fb);font-size:10px;font-weight:300;
  letter-spacing:.24em;text-transform:uppercase;
  padding:13px 24px;border:1px solid;cursor:pointer;
  transition:all .4s;background:transparent;width:fit-content;
  display:inline-block;
}
.btn-k{border-color:var(--charcoal);color:var(--charcoal)}
.btn-k:hover{background:var(--charcoal);color:var(--white)}
.btn-c{border-color:rgba(154,122,90,.4);color:var(--clay)}
.btn-c:hover{border-color:var(--clay)}
.btn-w{border-color:rgba(245,242,236,.3);color:rgba(245,242,236,.6)}
.btn-w:hover{border-color:var(--clay);color:var(--clay)}

/* ---------- NAVIGATION ---------- */
nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  height:72px;display:flex;align-items:center;transition:all .5s;
}
nav.on{background:rgba(245,242,236,.97);border-bottom:1px solid rgba(30,28,24,.07)}

.nav-i{
  width:100%;max-width:1120px;margin:0 auto;padding:0 64px;
  display:flex;align-items:center;justify-content:space-between;
}

.nav-logo{font-family:var(--fd);font-size:16px;font-weight:300;letter-spacing:.08em;color:var(--white);transition:color .5s}
nav.on .nav-logo{color:var(--charcoal)}
.nav-logo em{font-style:italic;opacity:.7}

.nav-links{display:flex;gap:40px;list-style:none}
.nav-links a{
  font-size:10px;font-weight:300;letter-spacing:.22em;
  text-transform:uppercase;color:rgba(245,242,236,.45);transition:color .3s;
}
nav.on .nav-links a{color:var(--mid)}
.nav-links a:hover,.nav-links a.active{color:var(--clay)}

.nav-shop{
  font-size:10px;font-weight:300;letter-spacing:.18em;text-transform:uppercase;
  padding:9px 22px;border:1px solid rgba(245,242,236,.3);
  color:rgba(245,242,236,.6);transition:all .4s;
}
nav.on .nav-shop{border-color:rgba(30,28,24,.2);color:var(--mid)}
.nav-shop:hover{border-color:var(--clay);color:var(--clay)}

/* Mobile hamburger */
.nav-toggle{
  display:none;flex-direction:column;gap:6px;
  background:none;border:none;cursor:pointer;padding:8px;
}
.nav-toggle span{
  display:block;width:22px;height:1px;
  background:var(--white);transition:all .3s;
}
nav.on .nav-toggle span{background:var(--charcoal)}

/* Mobile nav — hidden by default, shown only at 600px */
.mobile-nav{display:none}

/* ---------- HERO ---------- */
.hero{
  position:relative;height:100vh;min-height:700px;
  display:grid;grid-template-columns:3fr 2fr;overflow:hidden;background:var(--white);
}
.hero-photo{position:relative;overflow:hidden}
.hero-photo img{height:100%;filter:saturate(.78) brightness(.92)}

.hero-text{
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:80px 64px 100px 56px;background:var(--white);position:relative;
}
.hero-text::before{
  content:"";position:absolute;top:0;left:0;right:0;
  height:1px;background:var(--clay);opacity:.4;
}

.hero-kicker{
  font-size:9px;font-weight:300;letter-spacing:.36em;
  text-transform:uppercase;color:var(--mid);margin-bottom:48px;
}
.hero h1{
  font-family:var(--fd);font-size:clamp(40px,4vw,64px);
  font-weight:300;font-style:italic;line-height:1.2;
  color:var(--charcoal);margin-bottom:6px;letter-spacing:-.01em;
}
.hero h1 strong{font-style:normal;font-weight:400;display:block}
.hero-line{width:32px;height:1px;background:var(--clay);margin:32px 0}
.hero-sub{font-size:13px;font-weight:300;color:var(--mid);line-height:2;max-width:280px;margin-bottom:48px}
.hero-acts{display:flex;flex-direction:column;gap:10px}

/* ---------- SCROLLING STRIP ---------- */
.intro-strip{border-top:1px solid rgba(30,28,24,.08);border-bottom:1px solid rgba(30,28,24,.08);padding:20px 0;overflow:hidden}
.intro-strip-t{display:flex;width:max-content;animation:tick 40s linear infinite}
.strip-i{font-family:var(--fd);font-style:italic;font-size:14px;color:rgba(30,28,24,.25);padding:0 32px;white-space:nowrap}
.sep{color:var(--clay);opacity:.3}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- ABOUT SECTION ---------- */
.about{padding:160px 0}
.about-inner{display:grid;grid-template-columns:1fr 1fr;gap:120px;align-items:center}
.about-photo{height:680px;overflow:hidden}
.about-photo img{filter:saturate(.75) brightness(.95)}

.about-text .section-title{margin-bottom:8px}
.about-rule{width:40px;height:1px;background:var(--clay);margin:36px 0;opacity:.6}
.about-text p{font-size:13px;font-weight:300;color:var(--mid);line-height:2.1;margin-bottom:16px}
.about-text p:last-of-type{margin-bottom:48px}

.about-stats{display:flex;gap:48px;margin-bottom:48px}
.astat-n{font-family:var(--fd);font-size:40px;font-weight:300;color:var(--charcoal);line-height:1;letter-spacing:-.02em}
.astat-l{font-size:9px;font-weight:300;letter-spacing:.22em;text-transform:uppercase;color:var(--mid);margin-top:6px}

/* ---------- VALUES ---------- */
.values{padding:120px 0;background:var(--greige)}
.values-head{margin-bottom:80px}
.values-head .section-title{line-height:1.2}

.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(30,28,24,.06)}
.vc{background:var(--greige);padding:48px 32px}
.vc-n{font-family:var(--fd);font-style:italic;font-size:28px;color:var(--clay);opacity:.3;margin-bottom:32px;line-height:1}
.vc h3{font-family:var(--fd);font-size:16px;font-weight:300;color:var(--charcoal);margin-bottom:16px;line-height:1.3}
.vc p{font-size:12px;font-weight:300;color:var(--mid);line-height:2}

/* 3-column variant for about page */
.values-grid-3{grid-template-columns:repeat(3,1fr)}

/* ---------- SHOP / PRODUCT GRID ---------- */
.shop{padding:160px 0}
.shop-head{
  margin-bottom:80px;display:flex;align-items:flex-end;
  justify-content:space-between;border-bottom:1px solid rgba(30,28,24,.07);padding-bottom:32px;
}

.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}

.pc{cursor:pointer}
.pc-img{height:400px;overflow:hidden;margin-bottom:24px}
.pc-img img{transition:transform .9s;filter:saturate(.78)}
.pc:hover .pc-img img{transform:scale(1.03);filter:saturate(.88)}
.pc-cat{font-size:9px;font-weight:300;letter-spacing:.26em;text-transform:uppercase;color:var(--clay);margin-bottom:10px;opacity:.7}
.pc-name{font-family:var(--fd);font-size:18px;font-weight:300;color:var(--charcoal);margin-bottom:8px;line-height:1.3}
.pc-desc{font-size:12px;font-weight:300;color:var(--mid);line-height:2;margin-bottom:16px}
.pc-row{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid rgba(30,28,24,.07)}
.pc-price{font-family:var(--fd);font-size:18px;font-weight:300;color:var(--charcoal)}
.pc-add{
  font-family:var(--fb);font-size:9px;font-weight:300;letter-spacing:.22em;
  text-transform:uppercase;padding:8px 16px;border:1px solid rgba(30,28,24,.15);
  color:var(--mid);cursor:pointer;transition:all .35s;background:transparent;
}
.pc-add:hover{border-color:var(--charcoal);color:var(--charcoal)}

/* Shop page filters */
.shop-filters{
  display:flex;justify-content:center;gap:16px;margin-bottom:80px;flex-wrap:wrap;
}
.filter-btn{
  font-family:var(--fb);font-size:10px;font-weight:300;
  letter-spacing:.22em;text-transform:uppercase;
  padding:10px 20px;border:1px solid rgba(30,28,24,.12);
  background:transparent;color:var(--mid);cursor:pointer;transition:all .3s;
}
.filter-btn:hover,.filter-btn.active{border-color:var(--clay);color:var(--clay)}

/* ---------- PAGE HEADER (inner pages) ---------- */
.page-header{
  padding:140px 0 80px;background:var(--greige);position:relative;
}
.page-header::after{
  content:"";position:absolute;bottom:0;left:0;right:0;
  height:1px;background:var(--clay);opacity:.2;
}
.page-header .section-label{margin-bottom:24px}
.page-header .section-title{margin-bottom:16px}
.page-header p{font-size:13px;font-weight:300;color:var(--mid);line-height:2;max-width:420px}

/* ---------- CLASS CARDS ---------- */
.class-list{padding:120px 0}

.class-card{
  display:grid;grid-template-columns:320px 1fr;gap:64px;
  padding:64px 0;border-bottom:1px solid rgba(30,28,24,.07);
  align-items:center;
}
.class-card:first-child{padding-top:0}
.class-card:last-child{border-bottom:none}

.class-card-img{height:320px;overflow:hidden}
.class-card-img img{filter:saturate(.75) brightness(.95)}

.class-card-body .section-label{margin-bottom:16px}
.class-card-body h3{
  font-family:var(--fd);font-size:24px;font-weight:300;
  font-style:italic;color:var(--charcoal);margin-bottom:8px;
}
.class-card-body h3 strong{font-style:normal;font-weight:400;display:block}

.class-meta{
  display:flex;gap:32px;margin:20px 0;flex-wrap:wrap;
}
.class-meta span{
  font-size:10px;font-weight:300;letter-spacing:.16em;
  text-transform:uppercase;color:var(--mid);
}
.class-meta strong{color:var(--charcoal);font-weight:400}

.class-card-body p{font-size:13px;font-weight:300;color:var(--mid);line-height:2.1;margin-bottom:24px}

.class-price{
  font-family:var(--fd);font-size:18px;font-weight:300;
  color:var(--charcoal);margin-bottom:24px;display:block;
}
.class-price small{font-family:var(--fb);font-size:11px;color:var(--mid);letter-spacing:.08em}

/* ---------- PRIVATE LESSONS ---------- */
.private-section{padding:120px 0;background:var(--greige)}
.private-inner{display:grid;grid-template-columns:1fr 1fr;gap:120px;align-items:center}
.private-photo{height:500px;overflow:hidden}
.private-photo img{filter:saturate(.75) brightness(.95)}

.private-list{list-style:none;margin:48px 0}
.private-list li{
  padding:24px 0;border-bottom:1px solid rgba(30,28,24,.08);
}
.private-list li:first-child{border-top:1px solid rgba(30,28,24,.08)}
.private-list li strong{
  font-family:var(--fd);font-size:15px;font-weight:300;
  color:var(--charcoal);display:block;margin-bottom:4px;
}
.private-list li span{font-size:12px;font-weight:300;color:var(--mid)}

/* ---------- STORY / ABOUT PAGE ---------- */
.story{padding:160px 0}
.story-inner{display:grid;grid-template-columns:1.2fr 1fr;gap:120px;align-items:start}

.story-text .section-title{margin-bottom:24px}
.story-text p{font-size:13px;font-weight:300;color:var(--mid);line-height:2.1;margin-bottom:20px}
.story-text p:last-of-type{margin-bottom:48px}

.story-images{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.story-images img{filter:saturate(.75) brightness(.95)}
.story-images img:first-child{grid-column:1/-1;height:320px}
.story-images img:nth-child(2),.story-images img:nth-child(3){height:240px}

/* Split layout */
.split{padding:120px 0}
.split-inner{display:grid;grid-template-columns:1fr 1fr;gap:120px;align-items:center}
.split-photo{height:560px;overflow:hidden}
.split-photo img{filter:saturate(.75) brightness(.95)}
.split-text .section-title{margin-bottom:16px}
.split-text p{font-size:13px;font-weight:300;color:var(--mid);line-height:2.1;margin-bottom:20px}
.split-text p:last-of-type{margin-bottom:48px}

/* ---------- EVENTS PAGE ---------- */
.event-feature{padding:120px 0}
.event-hero-img{height:400px;overflow:hidden;margin-bottom:64px}
.event-hero-img img{filter:saturate(.72) brightness(.95)}

.event-content{max-width:760px;margin:0 auto}
.event-content .section-title{margin-bottom:16px}
.event-content h3{
  font-family:var(--fd);font-size:20px;font-weight:300;
  font-style:italic;color:var(--charcoal);margin:48px 0 16px;
}
.event-content p{font-size:13px;font-weight:300;color:var(--mid);line-height:2.1;margin-bottom:12px}

.event-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(30,28,24,.06);margin:48px 0}
.event-info-card{
  background:var(--white);padding:40px 32px;text-align:center;
}
.event-info-card .icon{font-size:9px;font-weight:300;letter-spacing:.28em;text-transform:uppercase;color:var(--clay);margin-bottom:12px}
.event-info-card strong{
  font-family:var(--fd);font-size:16px;font-weight:300;
  color:var(--charcoal);display:block;margin-bottom:4px;
}
.event-info-card span{font-size:11px;font-weight:300;color:var(--mid)}

.event-save-img{max-width:560px;margin:0 auto;overflow:hidden}
.event-save-img img{filter:saturate(.72) brightness(.95)}

/* Two-column event cards */
.event-cards{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.event-card-img{height:340px;overflow:hidden;margin-bottom:24px}
.event-card-img img{filter:saturate(.75) brightness(.95)}
.event-card h3{
  font-family:var(--fd);font-size:18px;font-weight:300;
  color:var(--charcoal);margin-bottom:12px;
}
.event-card p{font-size:12px;font-weight:300;color:var(--mid);line-height:2}

/* ---------- CONTACT PAGE ---------- */
.contact{padding:120px 0}
.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:120px}

.contact-form label{
  font-size:9px;font-weight:300;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mid);display:block;margin-bottom:8px;
}
.contact-form input,
.contact-form textarea,
.contact-form select{
  width:100%;padding:14px 16px;
  border:1px solid rgba(154,122,90,.25);
  background:transparent;font-family:var(--fb);font-size:13px;
  font-weight:300;color:var(--charcoal);margin-bottom:32px;
  transition:border-color .3s;outline:none;
  -webkit-appearance:none;appearance:none;
}
.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus{border-color:var(--charcoal)}
.contact-form input::placeholder,
.contact-form textarea::placeholder{color:rgba(30,28,24,.25)}
.contact-form textarea{resize:vertical;min-height:140px}
.contact-form select{cursor:pointer;color:var(--mid)}

.contact-info{list-style:none}
.contact-info li{
  padding:28px 0;border-bottom:1px solid rgba(30,28,24,.07);
}
.contact-info li:first-child{border-top:1px solid rgba(30,28,24,.07)}
.contact-info-label{
  font-size:9px;font-weight:300;letter-spacing:.26em;
  text-transform:uppercase;color:var(--clay);display:block;margin-bottom:8px;
}
.contact-info li p{font-size:13px;font-weight:300;color:var(--charcoal);line-height:1.8;margin-bottom:2px}
.contact-info li small{font-size:11px;font-weight:300;color:var(--mid)}

.contact-links{
  margin-top:48px;padding:40px;border:1px solid rgba(30,28,24,.07);
}
.contact-links h3{
  font-family:var(--fd);font-size:16px;font-weight:300;
  color:var(--charcoal);margin-bottom:20px;
}
.contact-links a{
  display:block;font-size:12px;font-weight:300;
  color:var(--clay);padding:6px 0;transition:color .3s;
}
.contact-links a:hover{color:var(--charcoal)}

/* ---------- NEWSLETTER ---------- */
.newsletter{padding:100px 0;background:var(--greige);text-align:center}
.newsletter .section-title{margin-bottom:16px}
.newsletter p{font-size:13px;font-weight:300;color:var(--mid);max-width:360px;margin:0 auto 40px;line-height:2}

.newsletter-form{display:flex;max-width:400px;margin:0 auto;gap:0}
.newsletter-form input{
  flex:1;padding:13px 16px;border:1px solid rgba(30,28,24,.12);
  border-right:none;background:transparent;font-family:var(--fb);
  font-size:12px;font-weight:300;color:var(--charcoal);outline:none;
}
.newsletter-form input::placeholder{color:rgba(30,28,24,.25)}
.newsletter-form input:focus{border-color:var(--clay)}
.newsletter-form button{
  font-family:var(--fb);font-size:9px;font-weight:300;
  letter-spacing:.22em;text-transform:uppercase;
  padding:13px 20px;border:1px solid rgba(30,28,24,.12);
  background:transparent;color:var(--mid);cursor:pointer;
  transition:all .3s;white-space:nowrap;
}
.newsletter-form button:hover{border-color:var(--charcoal);color:var(--charcoal)}
.newsletter .form-note{font-size:10px;font-weight:300;color:var(--mid);opacity:.5;margin-top:16px}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--charcoal);padding:80px 0 32px}
.footer-inner{
  max-width:1120px;margin:0 auto;padding:0 64px;
  display:grid;grid-template-columns:2fr 3fr;gap:80px;
  margin-bottom:48px;padding-bottom:40px;
  border-bottom:1px solid rgba(245,242,236,.05);
}
.footer-logo{font-family:var(--fd);font-size:18px;font-weight:300;color:var(--white);margin-bottom:14px}
.footer-logo em{font-style:italic;color:var(--clay)}
.footer-brand p{font-size:12px;font-weight:300;color:rgba(245,242,236,.28);line-height:2}
.footer-links{display:flex;gap:56px}
.footer-links div,.footer-links address{flex:1}
.footer-links h4{
  font-size:9px;font-weight:300;letter-spacing:.24em;
  text-transform:uppercase;color:rgba(245,242,236,.2);margin-bottom:16px;
}
.footer-links ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-links li a,.footer-links address a{font-size:12px;font-weight:300;color:rgba(245,242,236,.32);transition:color .3s}
.footer-links li a:hover,.footer-links address a:hover{color:var(--clay)}
.footer-links address{font-style:normal;font-size:12px;font-weight:300;color:rgba(245,242,236,.28);line-height:2}
.footer-bot{max-width:1120px;margin:0 auto;padding:0 64px;font-size:11px;font-weight:300;color:rgba(245,242,236,.15)}

/* ---------- UTILITY ---------- */
.text-center{text-align:center}
.mt-section{margin-top:80px}

/* ---------- REVEAL (subtle) ---------- */
.reveal{opacity:0;transition:opacity .8s ease}
.reveal.revealed{opacity:1}

/* ---------- RESPONSIVE ---------- */
@media(max-width:960px){
  .hero{grid-template-columns:1fr;height:auto}
  .hero-photo{height:60vw}
  .hero-text{padding:60px 40px 80px}
  .about-inner{grid-template-columns:1fr;gap:64px}
  .about-photo{height:360px}
  .values-grid,.values-grid-3{grid-template-columns:1fr 1fr}
  .prod-grid{grid-template-columns:1fr 1fr}
  .footer-inner{grid-template-columns:1fr}
  .split-inner{grid-template-columns:1fr;gap:64px}
  .split-photo{height:360px}
  .story-inner{grid-template-columns:1fr;gap:64px}
  .private-inner{grid-template-columns:1fr;gap:64px}
  .private-photo{height:360px}
  .contact-inner{grid-template-columns:1fr;gap:64px}
  .class-card{grid-template-columns:1fr;gap:32px}
  .class-card-img{height:280px}
  .event-info-grid{grid-template-columns:1fr 1fr}
  .event-cards{grid-template-columns:1fr}
}

@media(max-width:600px){
  .values-grid,.values-grid-3,.prod-grid{grid-template-columns:1fr}
  .nav-links,.nav-shop{display:none}
  .nav-toggle{display:flex}
  .footer-links{flex-wrap:wrap;gap:28px}
  .wrap{padding:0 28px}
  .nav-i{padding:0 28px}
  .footer-inner{padding:0 28px}
  .footer-bot{padding:0 28px}
  .hero-text{padding:48px 28px 64px}
  .about{padding:80px 0}
  .shop{padding:80px 0}
  .values{padding:80px 0}
  .class-list{padding:80px 0}
  .story{padding:80px 0}
  .split{padding:80px 0}
  .event-feature{padding:80px 0}
  .contact{padding:80px 0}
  .newsletter{padding:64px 0}
  .page-header{padding:110px 0 48px}
  .about-inner,.split-inner,.private-inner,.contact-inner,.story-inner{gap:48px}
  .event-info-grid{grid-template-columns:1fr}
  .newsletter-form{flex-direction:column;gap:8px}
  .newsletter-form input{border-right:1px solid rgba(30,28,24,.12)}

  /* Mobile menu */
  .mobile-nav{
    display:flex;
    position:fixed;top:72px;left:0;right:0;bottom:0;
    background:var(--white);z-index:499;
    flex-direction:column;
    padding:48px 28px;gap:0;
    transform:translateY(-120%);transition:transform .4s ease;
  }
  .mobile-nav.open{transform:translateY(0)}
  .mobile-nav a{
    font-size:11px;font-weight:300;letter-spacing:.22em;
    text-transform:uppercase;color:var(--mid);
    padding:20px 0;border-bottom:1px solid rgba(30,28,24,.06);
    transition:color .3s;
  }
  .mobile-nav a:hover,.mobile-nav a.active{color:var(--clay)}
}
