/* ============================
   MAGNUS GYM — Landing Styles
   ============================ */

:root{
  --bg:        #0a0a0a;
  --bg-soft:   #111111;
  --bg-card:   #161616;
  --line:      #262626;
  --line-2:    #2e2e2e;
  --text:      #ffffff;
  --text-dim:  #cfcfcf;
  --text-muted:#9a9a9a;
  --red:       #e60d2e;
  --red-2:     #b80a25;
  --red-glow:  rgba(230,13,46,.35);

  --container: 1240px;
  --gutter:    24px;

  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 14px;

  --font-display: "Oswald", "Bebas Neue", "Kanit", system-ui, sans-serif;
  --font-body:    "Inter", "Kanit", system-ui, sans-serif;
  --font-thai:    "Kanit", "Inter", system-ui, sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none;margin:0;padding:0}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

/* Thai text rendering hook */
:lang(th){font-family:var(--font-thai);}
[data-lang="th"] body, [data-lang="th"] :is(p,span,em,strong,a,h1,h2,h3,h4,li,button){
  font-family:var(--font-thai);
}

.container{
  max-width:var(--container);
  margin:0 auto;
  padding-inline:var(--gutter);
}

/* ============= GLOBAL TYPE ============= */
.section-title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(34px,4.2vw,56px);
  letter-spacing:.04em;
  line-height:1.02;
  margin:6px 0 8px;
  text-transform:uppercase;
}
.section-subtitle{font-size:clamp(18px,2vw,24px);font-weight:500;margin:0 0 18px}
.section-body{color:var(--text-dim);max-width:54ch;margin:0 0 22px}
.eyebrow{
  display:inline-block;
  color:var(--red);
  font-family:var(--font-display);
  font-weight:600;
  letter-spacing:.28em;
  font-size:14px;
  text-transform:uppercase;
}
.accent{color:var(--red)}
.center{text-align:center;display:flex;justify-content:center}
.section-head.center{flex-direction:column;align-items:center;margin-bottom:34px;gap:4px}

/* ============= BUTTONS ============= */
.btn{
  --btn-fg:#fff;
  --btn-bg:var(--red);
  --btn-bd:transparent;
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;
  font-family:var(--font-display);
  font-weight:600;
  letter-spacing:.18em;
  font-size:14px;
  text-transform:uppercase;
  color:var(--btn-fg);
  background:var(--btn-bg);
  border:1.5px solid var(--btn-bd);
  border-radius:4px;
  transition:transform .15s ease, background .2s ease, box-shadow .2s ease;
  cursor:pointer;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{box-shadow:0 6px 24px -10px var(--red-glow)}
.btn-primary:hover{background:var(--red-2)}
.btn-outline{--btn-bg:transparent;--btn-bd:#3a3a3a;color:#fff}
.btn-outline:hover{--btn-bd:var(--red);color:#fff}
.btn-sm{padding:10px 18px;font-size:12px}
.btn-block{display:flex;justify-content:center;width:100%}

.ico-arrow{width:16px;height:16px;flex:none}

/* ============= HEADER ============= */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:60;
  padding:14px 0;
  background:linear-gradient(180deg,rgba(0,0,0,.75),rgba(0,0,0,.0));
  backdrop-filter:blur(2px);
}
.site-header.is-scrolled{background:rgba(8,8,8,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:24px}

.brand{display:flex;align-items:center;gap:10px}
.brand-mark{width:56px;height:56px;flex:none}
.brand-name{display:flex;flex-direction:column;line-height:.95;font-family:var(--font-display);font-weight:700}
.brand-mag, .brand-nus{font-size:22px;letter-spacing:.05em}
.brand-mag{color:#fff}
.brand-nus{color:var(--red);margin-top:1px}
.brand-sub{font-size:9px;letter-spacing:.4em;color:#bdbdbd;margin-top:3px;font-weight:500}

/* nav */
.primary-nav{
  display:flex;align-items:center;gap:30px;
  margin-left:40px;
}
.nav-link{
  font-family:var(--font-display);
  font-weight:500;font-size:13px;letter-spacing:.18em;
  text-transform:uppercase;color:#dcdcdc;position:relative;padding:6px 2px;
}
.nav-link:hover{color:#fff}
.nav-link.is-active{color:var(--red)}
.nav-link.is-active::after{
  content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--red);
}

.header-cta{margin-left:auto;display:flex;align-items:center;gap:14px}
.lang-toggle{
  font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:.2em;
  color:#fff;padding:6px 4px;border-bottom:1.5px solid transparent;
}
.lang-toggle:hover{border-bottom-color:var(--red)}
.hamburger{display:none;width:42px;height:42px;flex-direction:column;gap:5px;justify-content:center;align-items:center}
.hamburger span{display:block;width:24px;height:2.5px;background:#fff;border-radius:2px}

/* drawer */
.drawer{
  position:fixed;inset:64px 0 0 0;z-index:55;
  background:rgba(0,0,0,.97);padding:24px;
  display:flex;flex-direction:column;gap:6px;
}
.drawer[hidden]{display:none}
.drawer nav{display:flex;flex-direction:column}
.drawer a{
  padding:14px 4px;border-bottom:1px solid var(--line);
  font-family:var(--font-display);letter-spacing:.18em;font-size:14px;
}
.drawer .btn{margin-top:20px;align-self:flex-start}

/* ============= HERO ============= */
.hero{
  position:relative;overflow:hidden;
  padding:120px 0 36px;
  isolation:isolate;
  background:#000;
}
.hero-bg{position:absolute;inset:0;z-index:-1}
.hero-bg img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  object-position:center right;
  opacity:.55;
  filter:contrast(1.1) saturate(.85);
}
.hero-bg-overlay{
  position:absolute;inset:0;
  background:
    radial-gradient(60% 70% at 18% 50%, rgba(0,0,0,.85), rgba(0,0,0,.55) 55%, rgba(0,0,0,.2) 80%),
    linear-gradient(90deg,#000 0%,rgba(0,0,0,.2) 50%,rgba(0,0,0,.55) 100%);
}
/* red grunge splatter accents */
.splatter{position:absolute;top:0;bottom:0;width:32%;background-repeat:no-repeat;background-size:cover;opacity:.85;pointer-events:none}
.splatter-left{
  left:-2%;
  background-image:
    radial-gradient(ellipse 40% 30% at 30% 20%, rgba(230,13,46,.55), transparent 60%),
    radial-gradient(ellipse 30% 25% at 15% 70%, rgba(230,13,46,.45), transparent 60%),
    radial-gradient(ellipse 18% 14% at 50% 50%, rgba(230,13,46,.3), transparent 70%);
  mask-image:linear-gradient(90deg,#000 60%,transparent 100%);
}
.splatter-right{
  right:-4%;
  background-image:
    radial-gradient(ellipse 40% 30% at 70% 20%, rgba(230,13,46,.55), transparent 60%),
    radial-gradient(ellipse 30% 25% at 85% 70%, rgba(230,13,46,.5), transparent 60%),
    radial-gradient(ellipse 18% 14% at 50% 50%, rgba(230,13,46,.3), transparent 70%);
  mask-image:linear-gradient(270deg,#000 60%,transparent 100%);
}

.hero-inner{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,560px) minmax(0,1fr);
  align-items:end;
  min-height:520px;
  gap:30px;
}
.hero-figure{display:none} /* bg image carries the visual on desktop */
.hero-copy{padding-bottom:30px;min-width:0}

.hero-title{
  margin:0 0 14px;
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(44px, 5.4vw, 76px);
  line-height:1;
  letter-spacing:.01em;
  text-transform:uppercase;
}
.hero-title .line{display:block}
.hero-title .accent{
  font-style:italic;
  color:var(--red);
  text-shadow:0 0 26px rgba(230,13,46,.45);
  font-weight:700;
}
.hero-sub{margin:0 0 22px;color:#e5e5e5;font-size:16px;max-width:46ch}

/* feature strip */
.features{
  position:relative;
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));
  gap:0;
  margin-top:34px;
  border:1px solid var(--line-2);
  border-radius:8px;
  background:rgba(10,10,10,.55);
  backdrop-filter:blur(4px);
  padding:14px 6px;
}
.feature{display:flex;align-items:center;gap:14px;padding:8px 18px;position:relative}
.feature + .feature::before{
  content:"";position:absolute;left:0;top:18%;bottom:18%;width:1px;background:var(--line-2);
}
.feature-ico{
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;
  background:rgba(230,13,46,.12);
  color:var(--red);flex:none;
}
.feature-ico svg{width:24px;height:24px}
.feature-text{display:flex;flex-direction:column;line-height:1.1}
.feature-text strong{font-family:var(--font-display);font-weight:600;letter-spacing:.14em;font-size:14px}
.feature-text em{font-style:normal;color:var(--red);font-size:11px;letter-spacing:.22em;font-weight:600;margin-top:3px}

/* ============= ABOUT ============= */
.about{position:relative;padding:80px 0;overflow:hidden}
.watermark{
  position:absolute;right:-20px;top:50%;transform:translateY(-50%);
  font-family:var(--font-display);font-weight:700;letter-spacing:.05em;
  font-size:clamp(120px,18vw,260px);line-height:.85;
  color:rgba(255,255,255,.025);
  pointer-events:none;
  white-space:pre;
  text-align:right;
}
.watermark::after{content:"\AGYM";white-space:pre;display:block;color:rgba(230,13,46,.04)}

.splatter-tile{
  position:absolute;width:60%;height:60%;pointer-events:none;opacity:.6;
  background:
    radial-gradient(ellipse 40% 30% at 30% 20%, rgba(230,13,46,.5), transparent 60%),
    radial-gradient(ellipse 30% 25% at 15% 70%, rgba(230,13,46,.4), transparent 60%);
}
.splatter-tl{left:-10%;top:-10%}
.splatter-br{right:-10%;bottom:-10%}

.about-inner{
  position:relative;
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);
  gap:60px;align-items:center;
}
.about-figure{margin:0;position:relative}
.about-figure::before{
  content:"";position:absolute;inset:-8% -10% -8% -2%;z-index:-1;
  background:
    radial-gradient(ellipse 60% 60% at 10% 10%, rgba(230,13,46,.45), transparent 60%),
    radial-gradient(ellipse 40% 50% at 80% 70%, rgba(230,13,46,.35), transparent 60%);
  filter:blur(4px);
}
.about-figure img{filter:contrast(1.1) saturate(.9)}

.about-copy .eyebrow{margin-bottom:6px}

/* ============= SERVICES ============= */
.services{padding:80px 0;background:#0a0a0a}
.service-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:18px;margin-bottom:36px;
}
.service-card{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:6px;overflow:hidden;
  transition:transform .25s ease,border-color .25s ease;
  display:flex;flex-direction:column;
}
.service-card:hover{transform:translateY(-4px);border-color:var(--red)}
.service-media{aspect-ratio:1/1;overflow:hidden;background:#000}
.service-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.service-card:hover .service-media img{transform:scale(1.05)}
.service-body{padding:18px 18px 22px;display:flex;flex-direction:column;gap:4px;flex:1}
.service-ico{color:var(--red);margin-bottom:2px}
.service-ico svg{width:26px;height:26px}
.service-title{font-family:var(--font-display);font-weight:700;letter-spacing:.06em;font-size:18px;margin:2px 0 0}
.service-sub{margin:0;font-size:14px;font-weight:500}
.service-body-txt{margin:6px 0 0;color:var(--text-muted);font-size:13px;line-height:1.55}

/* ============= PRICING ============= */
.pricing{position:relative;padding:80px 0;overflow:hidden}
.price-grid{
  display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:18px;
  margin:28px 0 24px;
}
.price-card{
  position:relative;
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:6px;
  padding:28px 22px 24px;
  display:flex;flex-direction:column;gap:6px;
  text-align:center;
  transition:transform .25s ease,border-color .25s ease;
}
.price-card:hover{transform:translateY(-4px);border-color:var(--red)}
.price-card.is-popular{border-color:var(--red);box-shadow:0 12px 40px -20px var(--red-glow)}
.ribbon{
  position:absolute;top:0;right:0;
  background:var(--red);color:#fff;
  font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:.18em;
  padding:5px 14px;
  clip-path:polygon(0 0,100% 0,100% 100%,15% 100%);
}
.price-name{
  font-family:var(--font-display);font-weight:700;letter-spacing:.08em;
  font-size:20px;margin:6px 0 0;
}
.price-sub{font-size:13px;margin:0 0 12px;font-weight:500}
.price-amount{
  font-family:var(--font-display);font-weight:700;
  color:var(--red);
  font-size:46px;line-height:1;margin:2px 0 18px;
  letter-spacing:.02em;
}
.price-amount span{font-size:32px;margin-left:2px}
.price-feats{
  display:flex;flex-direction:column;gap:10px;
  text-align:left;margin:6px 0 22px;flex:1;
}
.price-feats li{
  display:flex;gap:10px;align-items:flex-start;
  font-size:13px;color:var(--text-dim);
}
.price-feats li::before{
  content:"";width:7px;height:7px;border-radius:50%;background:var(--red);
  flex:none;margin-top:7px;
}

.pricing-notes{
  display:flex;justify-content:center;gap:34px;flex-wrap:wrap;
  color:var(--text-muted);font-size:13px;margin-top:8px;
}
.pricing-notes li{display:flex;align-items:center;gap:8px}
.pricing-notes .ico{width:18px;height:18px;color:var(--text-muted)}

/* ============= TRAINERS ============= */
.trainers{padding:80px 0;background:#0a0a0a}
.trainer-row{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;gap:14px;
  margin-bottom:32px;
}
.trn-nav{
  width:42px;height:42px;border-radius:50%;
  background:var(--bg-card);border:1px solid var(--line);color:#fff;
  display:grid;place-items:center;
  transition:background .2s,border-color .2s;
}
.trn-nav:hover{background:var(--red);border-color:var(--red)}
.trn-nav svg{width:18px;height:18px}

.trainer-grid{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;
}
.trainer-card{
  background:var(--bg-card);border:1px solid var(--line);border-radius:6px;
  overflow:hidden;transition:transform .25s ease,border-color .25s ease;
}
.trainer-card:hover{transform:translateY(-4px);border-color:var(--red)}
.trainer-media{aspect-ratio:3/4;background:#000;overflow:hidden;position:relative}
.trainer-media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.7));
}
.trainer-media img{width:100%;height:100%;object-fit:cover}
.trainer-body{padding:18px 18px 22px;text-align:center}
.trainer-name{font-family:var(--font-display);font-weight:700;letter-spacing:.08em;font-size:18px;margin:0 0 4px}
.trainer-role{font-size:11px;letter-spacing:.18em;font-weight:600;margin:0 0 10px;text-transform:uppercase}
.trainer-exp{font-size:13px;color:var(--text-muted);margin:0}

/* ============= GALLERY + CTA ============= */
.gallery-cta{padding:40px 0 70px;background:#0a0a0a}
.gallery-cta-inner{
  display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);
  gap:24px;align-items:stretch;
}
.gallery-block{display:flex;flex-direction:column;gap:14px}
.gallery-block .eyebrow{margin-bottom:0}
.gallery-block .section-title{margin:0 0 6px}
.gallery-grid{
  display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:1fr;gap:8px;flex:1;
}
.gallery-grid li{aspect-ratio:4/3;overflow:hidden;border-radius:4px;background:#000}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery-grid li:hover img{transform:scale(1.05)}

.cta-card{
  position:relative;overflow:hidden;border-radius:8px;
  min-height:300px;
  display:flex;align-items:center;
  border:1px solid var(--line);
}
.cta-bg{position:absolute;inset:0;z-index:-1}
.cta-bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5}
.cta-overlay{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 80% at 100% 50%, rgba(230,13,46,.35), transparent 60%),
    linear-gradient(90deg, rgba(0,0,0,.85) 0%, rgba(0,0,0,.55) 60%, rgba(0,0,0,.2) 100%);
}
.cta-inner{position:relative;padding:38px 36px;max-width:62%}
.cta-inner .section-title{margin:0 0 12px;font-size:clamp(28px,2.6vw,38px)}
.cta-sub{margin:0 0 22px;color:#e5e5e5;font-size:15px}

/* ============= FOOTER ============= */
.site-footer{
  background:#070707;border-top:1px solid var(--line);
  padding:46px 0 18px;color:var(--text-dim);
}
.footer-grid{
  display:grid;grid-template-columns:1.2fr 1.2fr 1.4fr 1fr;
  gap:36px;align-items:start;
}
.foot-brand .brand{margin-bottom:12px}
.foot-tag{color:var(--text-muted);font-size:13px;margin:0;max-width:24ch}
.foot-head{
  font-family:var(--font-display);font-weight:700;letter-spacing:.16em;font-size:14px;
  margin:0 0 16px;color:#fff;
}
.foot-links{display:grid;grid-template-columns:1fr 1fr;gap:8px 24px;margin-bottom:0}
.foot-col .foot-links + .foot-links{margin-top:8px;display:block}
.foot-col > .foot-links{display:block}
.foot-col{font-size:14px}
.foot-col .foot-links li a{color:var(--text-dim);font-size:13px}
.foot-col .foot-links li a:hover{color:var(--red)}

/* two-column foot links: split via grid-template */
.foot-col:nth-child(2) .foot-links{
  display:grid;grid-template-columns:1fr;gap:8px;
}
.foot-col:nth-child(2){
  display:grid;grid-template-columns:1fr 1fr;
  column-gap:30px;row-gap:0;
}
.foot-col:nth-child(2) .foot-head{grid-column:1 / -1}

.foot-contact{display:flex;flex-direction:column;gap:12px;font-size:13px}
.foot-contact li{display:flex;align-items:center;gap:12px}
.ico-circle{
  width:30px;height:30px;border-radius:50%;
  background:#1a1a1a;border:1px solid var(--line);
  display:grid;place-items:center;color:var(--red);flex:none;
}
.ico-circle svg{width:14px;height:14px}

.socials{display:flex;gap:12px;flex-wrap:wrap}
.socials a{
  width:38px;height:38px;border-radius:50%;
  background:#1a1a1a;border:1px solid var(--line);
  display:grid;place-items:center;color:#fff;
  transition:background .2s,border-color .2s,color .2s;
}
.socials a:hover{background:var(--red);border-color:var(--red)}
.socials svg{width:16px;height:16px}

.foot-nav-mobile{display:none}

.foot-bottom{
  margin-top:30px;padding-top:18px;border-top:1px solid var(--line);
  text-align:center;color:var(--text-muted);font-size:13px;
}
.foot-bottom p{margin:0}

/* ============================
   RESPONSIVE
   ============================ */
@media (max-width:1100px){
  .service-grid{grid-template-columns:repeat(3,1fr)}
  .price-grid{grid-template-columns:repeat(3,1fr)}
  .trainer-grid{grid-template-columns:repeat(3,1fr)}
  .trainer-card:nth-child(4){display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
  .gallery-cta-inner{grid-template-columns:1fr}
}

@media (max-width:860px){
  :root{--gutter:18px}
  .primary-nav{display:none}
  .header-cta .btn{display:none}
  .hamburger{display:flex}

  .hero{padding:90px 0 30px}
  .hero-inner{
    grid-template-columns:1fr;
    min-height:auto;
    align-items:start;
  }
  .hero-bg img{object-position:65% center;opacity:.5}
  .hero-copy{padding-bottom:0}
  .hero-title{font-size:clamp(44px,11vw,68px)}
  .hero-title .accent{display:block}

  .features{
    grid-template-columns:1fr 1fr;
    padding:8px;
  }
  .feature{padding:14px 12px}
  .feature + .feature::before{display:none}
  .feature:nth-child(odd) + .feature::before{
    content:"";position:absolute;left:0;top:18%;bottom:18%;width:1px;background:var(--line-2);
  }

  .about{padding:60px 0}
  .about-inner{grid-template-columns:1fr;gap:30px;text-align:left}
  .about-figure{order:2;max-width:420px;margin-inline:auto;width:100%}
  .about-copy{order:1}
  .watermark{display:none}

  .services{padding:60px 0}
  .service-grid{grid-template-columns:1fr 1fr;gap:14px}
  .service-card:last-child{grid-column:1 / -1}
  .service-card:last-child .service-media{aspect-ratio:16/9}

  .pricing{padding:60px 0}
  .price-grid{grid-template-columns:1fr;gap:14px}
  .price-card{padding:24px}
  .pricing-notes{flex-direction:column;align-items:flex-start;gap:12px;padding-inline:12px}

  .trainers{padding:60px 0}
  .trainer-row{grid-template-columns:1fr}
  .trn-nav{display:none}
  .trainer-grid{grid-template-columns:repeat(3,1fr);gap:10px}
  .trainer-card:nth-child(4){display:none}
  .trainer-body{padding:14px 10px 16px}
  .trainer-name{font-size:14px}
  .trainer-role{font-size:10px;letter-spacing:.12em}
  .trainer-exp{font-size:11px}

  .gallery-cta{padding:20px 0 50px}
  .gallery-cta-inner{grid-template-columns:1fr;gap:50px}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .gallery-grid li{aspect-ratio:1/1}
  .cta-inner{padding:32px 24px;max-width:100%}

  .site-footer{padding:40px 0 18px}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .foot-col:nth-child(2){display:none} /* hide quick links grid; show mobile nav list below */
  .foot-brand{order:5;text-align:center;display:flex;flex-direction:column;align-items:center;margin-top:10px}
  .foot-brand .brand{justify-content:center}
  .foot-tag{text-align:center;max-width:none}
  .foot-nav-mobile{
    display:flex;flex-direction:column;align-items:center;gap:14px;
    padding:24px 0 4px;order:6;
  }
  .foot-nav-mobile a{font-size:14px;color:var(--text-dim)}
}

/* a tiny tweak for very narrow screens */
@media (max-width:420px){
  .hero-title{font-size:48px}
  .price-amount{font-size:40px}
  .section-title{font-size:30px}
}
