:root{
  --bg:#f7f1da;
  --surface:#fffdf4;
  --surface-2:#efe7c9;
  --ink:#22301f;
  --muted:#5c6353;
  --line:#e6dcbf;
  --terra:#255b3b;
  --terra-d:#1b4a2e;
  --olive:#c2913f;
  --gold:#e0b16d;
  --cream-deep:#ece1c1;
  --radius:18px;
  --shadow:0 1px 2px oklch(0.4 0.05 60/.05), 0 18px 40px -22px oklch(0.4 0.08 50/.35);
  --maxw:1180px;
  --serif:'Spectral',Georgia,serif;
  --sans:'Be Vietnam Pro',system-ui,sans-serif;
  --mono:'Space Mono',monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;font-size:17px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--serif);font-weight:700;line-height:1.14;letter-spacing:-.015em}
img{max-width:100%;display:block}
section{position:relative}
.eyebrow{font-family:var(--mono);font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--terra-d);font-weight:700}

/* placeholder image */
.ph{position:relative;background:
   repeating-linear-gradient(135deg,var(--cream-deep) 0 14px,transparent 14px 28px),
   var(--surface-2);
  border:1px solid var(--line);border-radius:14px;display:grid;place-items:center;overflow:hidden}
.ph span{font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase;background:var(--surface);padding:5px 10px;border-radius:99px;border:1px solid var(--line)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-weight:700;font-size:16px;
  padding:14px 24px;border-radius:99px;border:1px solid transparent;cursor:pointer;transition:.18s;white-space:nowrap}
.btn-primary{background:var(--terra);color:#fff;box-shadow:0 10px 22px -10px var(--terra)}
.btn-primary:hover{background:var(--terra-d);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:var(--surface);border-color:var(--ink)}

/* header */
header{position:sticky;top:0;z-index:50;background:rgba(247,241,218,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.brand-logo{height:50px;width:auto;display:block}
.nav{display:flex;align-items:center;gap:30px;height:72px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:800;font-size:22px;letter-spacing:-.02em;white-space:nowrap}
.brand .roof{width:30px;height:30px;flex:none}
.nav-links{display:flex;gap:26px;margin-left:14px}
.nav-links a{font-size:15px;font-weight:500;color:var(--muted);transition:.15s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:12px}
.nav-phone{font-weight:600;font-size:15px}
@media(max-width:880px){.nav-links{display:none}.nav-phone{display:none}}

/* hero */
.hero{padding:70px 0 80px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:48px;align-items:center}
.hero h1{font-size:clamp(38px,5vw,62px);line-height:1.12;margin:18px 0 26px}
.hero h1 em{font-style:italic;color:var(--terra)}
.hero p.lead{font-size:19px;color:var(--muted);max-width:30em;margin-bottom:30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-note{font-size:14px;color:var(--muted);margin-top:16px;display:flex;align-items:center;gap:8px}
.hero-visual{position:relative;width:min(100%,500px);justify-self:end}
.hero-photo,.hero-photo-img{aspect-ratio:1;border-radius:24px}
.hero-photo-img{width:100%;height:auto;border:1px solid var(--line);object-fit:cover;object-position:center;box-shadow:var(--shadow)}
.hero-badge{position:absolute;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:13px 16px;box-shadow:var(--shadow);display:flex;align-items:center;gap:11px}
.hero-badge .n{font-family:var(--serif);font-size:26px;font-weight:800;color:var(--terra);line-height:1}
.hero-badge small{font-size:12.5px;color:var(--muted);line-height:1.25;display:block}
.hb-1{top:24px;left:-26px}
.hb-2{bottom:30px;right:-22px}
@media(max-width:820px){.hero-grid{grid-template-columns:1fr;gap:38px}.hero-visual{justify-self:center;width:min(100%,460px)}.hb-1{left:8px}.hb-2{right:8px}}

/* trust strip */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--surface)}
.trust .wrap{display:flex;align-items:center;gap:42px;padding-top:30px;padding-bottom:30px;flex-wrap:wrap;justify-content:center}
.trust-label{font-family:var(--mono);font-size:15px;letter-spacing:.14em;text-transform:uppercase;color:var(--terra-d);font-weight:700;white-space:nowrap}
.trust-divider{width:1px;height:44px;background:var(--line);flex:none}
.trust-logos{display:flex;align-items:center;gap:38px;flex-wrap:wrap;justify-content:center}
.partner-logo{display:flex;align-items:center;gap:9px;opacity:.9;transition:.15s}
.partner-logo:hover{opacity:1}
.trust-logo{width:auto;display:block;opacity:.95}
.trust-logo-bc{height:70px}
.trust-logo-idp{height:52px}
.partner-logo .pl-icon{width:36px;height:36px;border-radius:8px;flex:none;display:grid;place-items:center;font-weight:800;font-size:13px;letter-spacing:.02em;color:#fff}
.partner-logo .pl-name{font-family:var(--sans);font-weight:700;font-size:15px;line-height:1.2;color:var(--ink)}
.partner-logo .pl-name small{display:block;font-size:11px;font-weight:500;color:var(--muted);letter-spacing:.04em}
@media(max-width:600px){.trust .wrap{gap:22px;padding-top:24px;padding-bottom:24px}.trust-label{font-size:13px;width:100%;text-align:center}.trust-divider{display:none}.trust-logos{gap:26px}.trust-logo-bc{height:55px}.trust-logo-idp{height:42px}}

/* stats */
.stats{padding:74px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px}
.stat .num{font-family:var(--serif);font-size:48px;font-weight:800;color:var(--ink);line-height:1;letter-spacing:-.02em}
.stat .num b{color:var(--terra);font-weight:800}
.stat .lab{margin-top:10px;color:var(--muted);font-size:15px}
@media(max-width:820px){.stats-grid{grid-template-columns:repeat(2,1fr)}}

/* section heading */
.sec-head{max-width:620px;margin-bottom:44px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(30px,3.6vw,46px);margin:14px 0 14px}
.sec-head p{color:var(--muted);font-size:18px}

/* method */
.method{padding:30px 0 84px}
.method-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.feat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:32px;display:flex;gap:20px;transition:.18s}
.feat:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.feat .ico{width:52px;height:52px;border-radius:14px;flex:none;display:grid;place-items:center;background:var(--cream-deep);font-family:var(--serif);font-weight:800;font-size:22px;color:var(--terra-d)}
.feat h3{font-size:21px;margin-bottom:8px;font-family:var(--sans);font-weight:700;letter-spacing:-.01em}
.feat p{color:var(--muted);font-size:15.5px}
.feat.span2{grid-column:1/-1;background:linear-gradient(110deg,var(--terra),var(--terra-d));color:#fff;border-color:transparent;align-items:center}
.feat.span2 .ico{background:#ffffff2a;color:#fff}
.feat.span2 h3{color:#fff}.feat.span2 p{color:#ffffffdc}
@media(max-width:760px){.method-grid{grid-template-columns:1fr}}

/* courses */
.courses{padding:84px 0;background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.course-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.course{border:1px solid var(--line);border-radius:var(--radius);padding:28px;background:var(--bg);display:flex;flex-direction:column;transition:.18s}
.course:hover{border-color:var(--terra);transform:translateY(-3px)}
.course .tag{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--terra-d);font-weight:700}
.course h3{font-size:23px;margin:12px 0 6px;font-family:var(--sans);font-weight:700;letter-spacing:-.01em}
.course .desc{color:var(--muted);font-size:15px;margin-bottom:18px}
.course ul{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:22px}
.course li{font-size:14.5px;display:flex;gap:9px;align-items:flex-start}
.course li::before{content:"";width:7px;height:7px;border-radius:99px;background:var(--olive);margin-top:8px;flex:none}
.course .lvls{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:18px}
.course .lvls b{font-family:var(--mono);font-weight:700;font-size:12.5px;padding:5px 9px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}
.course .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between}
.course .price{font-family:var(--serif);font-weight:700;font-size:15px;color:var(--muted)}
.course.feature{background:linear-gradient(160deg,var(--cream-deep),var(--surface));border-color:var(--terra)}
@media(max-width:820px){.course-grid{grid-template-columns:1fr}}

/* bands */
.bands{padding:84px 0}
.band-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.band{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;text-align:center}
.avatar{width:62px;height:62px;border-radius:99px;margin:0 auto 14px;display:grid;place-items:center;font-family:var(--serif);font-weight:800;font-size:22px;color:#fff;background:var(--terra)}
.band .name{font-weight:700;font-size:16px}
.band .course-name{font-size:13px;color:var(--muted);margin-bottom:14px}
.band .overall{font-family:var(--serif);font-size:42px;font-weight:800;color:var(--terra);line-height:1}
.band .overall small{font-size:14px;color:var(--muted);font-weight:500;font-family:var(--sans);display:block;letter-spacing:.05em}
.band .skills{display:flex;justify-content:center;gap:7px;margin-top:14px;border-top:1px solid var(--line);padding-top:14px}
.band .skills div{font-size:12px;color:var(--muted)}
.band .skills b{display:block;font-family:var(--mono);font-size:14px;color:var(--ink);font-weight:700}
@media(max-width:880px){.band-grid{grid-template-columns:repeat(2,1fr)}}

/* facilities */
.facil{padding:84px 0;background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.facil-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-auto-rows:200px;gap:16px}
.facil-grid .ph:nth-child(1){grid-row:span 2}
.facil-grid .ph:nth-child(4){grid-column:span 2}
@media(max-width:760px){.facil-grid{grid-template-columns:1fr 1fr}.facil-grid .ph:nth-child(1){grid-row:auto}.facil-grid .ph:nth-child(4){grid-column:span 2}}

/* faq */
.faq{padding:84px 0}
.faq-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:48px;align-items:start}
details{border-bottom:1px solid var(--line);padding:6px 0}
details summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:18px;padding:18px 0;font-weight:600;font-size:18px}
details summary::-webkit-details-marker{display:none}
details summary .pm{width:26px;height:26px;flex:none;border:1px solid var(--line);border-radius:99px;display:grid;place-items:center;font-size:18px;color:var(--terra);transition:.2s}
details[open] summary .pm{transform:rotate(45deg);background:var(--terra);color:#fff;border-color:var(--terra)}
details p{color:var(--muted);font-size:15.5px;padding:0 0 18px;max-width:46em}
@media(max-width:760px){.faq-grid{grid-template-columns:1fr;gap:20px}}

/* form / cta */
.signup{padding:90px 0}
.signup-card{background:linear-gradient(155deg,#2c4030,#1a2417);border-radius:30px;padding:56px;display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;color:#fff;box-shadow:var(--shadow)}
.signup-card h2{color:#fff;font-size:clamp(30px,3.4vw,42px)}
.signup-card .eyebrow{color:var(--gold)}
.signup-card p.s{color:#ffffffc4;margin:14px 0 24px;font-size:17px}
.signup ul.bul{list-style:none;display:flex;flex-direction:column;gap:12px}
.signup ul.bul li{display:flex;gap:11px;align-items:center;font-size:15.5px;color:#ffffffe0}
.signup ul.bul li .ck{width:22px;height:22px;border-radius:99px;background:var(--terra);display:grid;place-items:center;flex:none;font-size:13px}
form{background:var(--surface);border-radius:20px;padding:30px;color:var(--ink)}
form h3{font-family:var(--sans);font-weight:700;font-size:20px;margin-bottom:4px;letter-spacing:-.01em}
form .sub{color:var(--muted);font-size:14px;margin-bottom:20px}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--muted)}
.field input,.field select{width:100%;padding:13px 14px;border:1px solid var(--line);border-radius:11px;font-family:var(--sans);font-size:15px;background:var(--bg);color:var(--ink);transition:.15s}
.field input:focus,.field select:focus{outline:none;border-color:var(--terra);box-shadow:0 0 0 3px var(--terra)/.12}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
form .btn-primary{width:100%;justify-content:center;margin-top:8px}
.form-done{display:none;text-align:center;padding:30px 10px}
.form-done.show{display:block}
.form-done .big{font-family:var(--serif);font-size:26px;font-weight:800;color:var(--olive);margin-bottom:8px}
@media(max-width:820px){.signup-card{grid-template-columns:1fr;padding:34px}}

/* footer */
footer{background:var(--ink);color:oklch(0.82 0.01 60);padding:62px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;padding-bottom:40px;border-bottom:1px solid oklch(0.4 0.02 55)}
.foot-brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:800;font-size:22px;color:#fff;margin-bottom:14px;white-space:nowrap}
.foot-col h4{font-family:var(--sans);font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:#fff;margin-bottom:14px}
.foot-col a{display:block;font-size:14.5px;margin-bottom:10px;color:oklch(0.82 0.01 60);transition:.15s}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;font-size:13.5px;color:oklch(0.66 0.01 60);flex-wrap:wrap;gap:10px}
.tag-pill{display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--terra);border:1px solid oklch(0.4 0.02 55);padding:4px 10px;border-radius:99px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr}}

/* ── Custom cursor ── */
*{cursor:none!important}
#cur-dot,#cur-ring{position:fixed;border-radius:50%;pointer-events:none;z-index:9999;top:0;left:0}
#cur-dot{width:9px;height:9px;background:var(--terra);transform:translate(-50%,-50%);transition:width .18s,height .18s,background .18s,opacity .2s}
#cur-ring{width:40px;height:40px;border:1.5px solid var(--olive);transform:translate(-50%,-50%);opacity:.55;transition:width .3s cubic-bezier(.25,.46,.45,.94),height .3s cubic-bezier(.25,.46,.45,.94),border-color .25s,opacity .25s}
body.cur-hover #cur-dot{width:14px;height:14px;background:var(--olive)}
body.cur-hover #cur-ring{width:58px;height:58px;border-color:var(--terra);opacity:.22}
body.cur-off #cur-dot,body.cur-off #cur-ring{opacity:0!important}
@media(hover:none){*{cursor:auto!important}#cur-dot,#cur-ring{display:none!important}}

/* ── Hero badge float ── */
.hero-badge{animation:float-badge 3.8s ease-in-out infinite}
.hb-2{animation-delay:-1.9s}
@keyframes float-badge{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* ── Marquee ── */
.bands-overflow{overflow:hidden;position:relative;padding:6px 0}
.bands-overflow::before,.bands-overflow::after{content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.bands-overflow::before{left:0;background:linear-gradient(to right,var(--bg),transparent)}
.bands-overflow::after{right:0;background:linear-gradient(to left,var(--bg),transparent)}
.bands-track{display:flex;gap:18px;width:max-content;animation:marquee-go 34s linear infinite;padding:14px 0}
.bands-track:hover{animation-play-state:paused;cursor:default!important}
@keyframes marquee-go{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.band{min-width:210px;flex:none}
/* messenger result screenshots */
.shots-track{display:flex;gap:18px;width:max-content;animation:marquee-go 70s linear infinite;padding:14px 0}
.shots-track:hover{animation-play-state:paused}
.shot{min-width:280px;width:280px;aspect-ratio:1200/1697;flex:none;border-radius:20px;position:relative;
  background:var(--surface);border:1px solid var(--line);overflow:hidden;box-shadow:0 10px 30px rgba(27,74,46,.07);transition:.18s}
.shot:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.shot img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:560px){.shot{width:220px;min-width:220px}}

/* ── Scroll fade-up ── */
.fade-up{opacity:0;transform:translateY(26px);transition:opacity .65s ease,transform .65s ease}
.fade-up.in{opacity:1;transform:translateY(0)}

/* ── Marker highlight ── */
.mark-inner{
  display:inline;
  -webkit-box-decoration-break:clone;
  box-decoration-break:clone;
  background-image:
    linear-gradient(rgba(224,181,90,.46),rgba(224,181,90,.46)),
    linear-gradient(rgba(198,155,68,.34),rgba(198,155,68,.34));
  background-repeat:no-repeat;
  background-position:left 15%, right 52%;
  background-size:0% 65%, 0% 48%;
  padding:.06em .05em;
}
.mark-inner.terra{
  background-image:
    linear-gradient(rgba(37,91,59,.2),rgba(37,91,59,.2)),
    linear-gradient(rgba(27,74,46,.16),rgba(27,74,46,.16));
}

/* ── Animated Title (GSAP brush + chars) ── */
.animated-title{position:relative;display:inline-block;padding:0 48px;}
.title-brush{position:absolute;left:50%;top:50%;width:min(100%,567px);height:auto;transform:translate(-50%,-45%);z-index:0;pointer-events:none;overflow:visible;}
.line{display:block;}
.word{display:inline-block;white-space:nowrap;}
.char{display:inline-block;will-change:transform,opacity;}
.title-star{position:absolute;z-index:3;font-size:26px;pointer-events:none;font-style:normal;line-height:1;}
.star-1{top:-22px;left:10px;}
.star-2{right:14px;bottom:-16px;}
@media(max-width:768px){
  .animated-title{padding:0 20px;}
  .title-star{font-size:18px;}
  .star-1{top:-16px;left:0;}
  .star-2{right:0;bottom:-12px;}
}

/* ── Location (NILP-04) ── */
.location{padding:84px 0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.loc-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:28px;align-items:stretch}
.loc-info{display:flex;flex-direction:column;gap:10px;justify-content:center}
.loc-name{font-weight:700;font-size:20px}
.loc-addr,.loc-hours{color:var(--muted)}
.loc-info .btn{align-self:flex-start;margin-top:8px}
.loc-map{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);min-height:340px}
.loc-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
@media(max-width:760px){
  .loc-grid{grid-template-columns:1fr}
  .loc-info .btn{align-self:stretch;text-align:center}
}
