/*
Theme Name: GalleMagic Creative Studio
Theme URI: https://gallemagic.lk
Author: GalleMagic
Author URI: https://gallemagic.lk
Description: A modern dark neon portfolio WordPress theme for GalleMagic Creative Studio. Includes editable Portfolio post type and dual infinite carousel preview.
Version: 1.0.7
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GPL-2.0-or-later
Text Domain: gallemagic
*/

:root{
  --bg:#030718;
  --bg2:#0d092f;
  --card:#11162b;
  --line:rgba(255,255,255,.12);
  --text:#fff;
  --muted:#bfc3d8;
  --purple:#a931ff;
  --magenta:#ee42ff;
  --orange:#ff7a00;
  --glow:0 0 32px rgba(181,49,255,.45);
  --radius:22px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Poppins","Noto Sans Sinhala",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 80% 5%, rgba(168,49,255,.35), transparent 34%),
    radial-gradient(circle at 12% 35%, rgba(255,122,0,.12), transparent 26%),
    radial-gradient(circle at 55% 50%, rgba(110,20,200,.18), transparent 34%),
    linear-gradient(180deg,#030718 0%,#06091f 48%,#050818 100%);
  overflow-x:hidden;
}
body:before{
  content:"";
  position:fixed;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(circle at 75% 20%,black,transparent 62%);
  pointer-events:none;
  z-index:-1;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1180px,calc(100% - 36px));margin:0 auto}

.site-header{
  position:sticky;
  top:0;
  z-index:100;
  backdrop-filter:blur(18px);
  background:rgba(3,7,24,.72);
  border-bottom:1px solid var(--line)
}
.nav{
  min-height:82px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px
}
.logo{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:215px
}
.logo-img{
  width:62px;
  height:62px;
  border-radius:16px;
  object-fit:cover;
  box-shadow:var(--glow)
}
.logo-text strong{display:block;font-size:22px;line-height:1;letter-spacing:-.5px}
.logo-text span{display:block;margin-top:5px;font-size:9px;letter-spacing:4px;color:var(--muted);text-transform:uppercase}
.logo-text b{color:var(--magenta);font-weight:900}
.nav-links{display:flex;align-items:center;gap:28px;font-size:14px;color:#e9eafe}
.nav-links a{opacity:.86;transition:.25s}
.nav-links a:hover,.nav-links .current-menu-item a{color:var(--magenta);opacity:1}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:48px;
  padding:0 22px;
  border-radius:13px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.04);
  color:white;
  font-weight:700;
  transition:.25s;
  cursor:pointer
}
.btn:hover{transform:translateY(-2px);border-color:rgba(238,66,255,.55);box-shadow:var(--glow)}
.btn-primary{border:none;background:linear-gradient(135deg,var(--purple),var(--magenta),var(--orange));box-shadow:0 12px 40px rgba(169,49,255,.34)}
.btn-whatsapp{background:linear-gradient(135deg,#7c18ff,#d936ff);border:1px solid rgba(255,255,255,.25)}
.mobile-toggle{display:none;width:48px;height:48px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.06);color:#fff;font-size:26px}

.hero{padding:88px 0 60px;position:relative}
.hero-grid{display:grid;grid-template-columns:1.03fr .97fr;gap:56px;align-items:center}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  border:1px solid rgba(238,66,255,.32);
  background:rgba(238,66,255,.08);
  color:#f39cff;
  border-radius:999px;
  padding:9px 16px;
  font-size:12px;
  font-weight:800;
  letter-spacing:2.5px;
  text-transform:uppercase;
  margin-bottom:26px
}
h1{font-size:clamp(46px,6.4vw,84px);line-height:1.03;letter-spacing:-3px;max-width:760px}
.gradient-text{background:linear-gradient(90deg,#fff,#f05cff 36%,#a931ff 66%,#ff7a00);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-copy{margin-top:24px;max-width:660px;color:var(--muted);font-size:17px;line-height:1.8}
.hero-actions{margin-top:34px;display:flex;flex-wrap:wrap;gap:16px}
.stats{margin-top:44px;display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.stat{padding:18px;border-left:1px solid rgba(255,255,255,.16);background:linear-gradient(180deg,rgba(255,255,255,.05),transparent);border-radius:14px}
.stat strong{display:block;font-size:24px}
.stat span{color:var(--muted);font-size:12px}

.hero-visual{position:relative;min-height:520px}
.orbit{position:absolute;inset:18px 12px;border:1px solid rgba(238,66,255,.32);border-radius:50%;transform:rotate(-18deg);filter:drop-shadow(0 0 18px rgba(238,66,255,.45))}
.device{position:absolute;background:linear-gradient(155deg,rgba(255,255,255,.12),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.18);box-shadow:0 30px 90px rgba(0,0,0,.45);backdrop-filter:blur(18px)}
.laptop{left:3%;top:60px;width:78%;min-height:315px;border-radius:24px;transform:rotate(4deg);padding:18px}
.screen{
  min-height:260px;
  border-radius:18px;
  background:radial-gradient(circle at 75% 20%,rgba(238,66,255,.5),transparent 34%),linear-gradient(135deg,rgba(169,49,255,.95),rgba(17,8,52,.95));
  padding:30px;
  overflow:hidden;
  position:relative
}
.screen:after{content:"";position:absolute;width:250px;height:250px;border:1px solid rgba(255,255,255,.22);border-radius:50%;right:-60px;bottom:-80px}
.screen h3{font-size:44px;line-height:1;letter-spacing:-1px}
.screen p{margin-top:18px;color:#f4ddff;max-width:260px}
.phone{right:0;top:130px;width:210px;min-height:405px;border-radius:36px;transform:rotate(-8deg);padding:14px}
.phone-inner{min-height:375px;border-radius:28px;background:#090b1e;padding:20px 14px;border:1px solid rgba(255,255,255,.12)}
.post-card{height:94px;border-radius:15px;margin-top:11px;background:linear-gradient(135deg,rgba(255,122,0,.9),rgba(238,66,255,.8))}
.post-card:nth-child(2n){background:linear-gradient(135deg,rgba(169,49,255,.9),rgba(16,16,64,.9))}
.tablet{right:6%;bottom:18px;width:55%;min-height:205px;border-radius:22px;transform:rotate(-2deg);padding:16px}
.timeline{height:18px;border-radius:99px;margin:16px 0;background:linear-gradient(90deg,var(--orange),var(--purple),var(--magenta))}

section{padding:54px 0;border-top:1px solid rgba(255,255,255,.06)}
.section-title{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:26px}
.section-title h2{font-size:clamp(30px,3.6vw,48px);letter-spacing:-1.2px}
.section-title p{max-width:560px;color:var(--muted);line-height:1.7}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{
  position:relative;
  overflow:hidden;
  padding:30px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(160deg,rgba(255,255,255,.08),rgba(255,255,255,.025));
  border-radius:var(--radius);
  min-height:220px;
  transition:.25s
}
.card:hover{transform:translateY(-6px);border-color:rgba(238,66,255,.45);box-shadow:var(--glow)}
.card:before{content:"";position:absolute;width:160px;height:160px;border-radius:50%;right:-58px;top:-62px;background:rgba(238,66,255,.14);filter:blur(5px)}
.icon{width:72px;height:72px;display:grid;place-items:center;border-radius:20px;background:rgba(238,66,255,.12);color:#f17cff;font-size:36px;box-shadow:inset 0 0 28px rgba(238,66,255,.22);margin-bottom:26px}
.card h3{font-size:22px;margin-bottom:13px}
.card p{color:var(--muted);line-height:1.7;font-size:14px}
.learn{display:inline-block;margin-top:20px;color:#f17cff;font-weight:700;font-size:14px}

/* Two-line infinite portfolio carousel */
.portfolio-carousel-wrap{
  width:100%;
  overflow:hidden;
  padding:16px 0 8px;
  position:relative
}
.portfolio-carousel-wrap:before,
.portfolio-carousel-wrap:after{
  content:"";
  position:absolute;
  top:0;
  width:130px;
  height:100%;
  z-index:3;
  pointer-events:none
}
.portfolio-carousel-wrap:before{
  left:0;
  background:linear-gradient(90deg,#050818,rgba(5,8,24,0))
}
.portfolio-carousel-wrap:after{
  right:0;
  background:linear-gradient(-90deg,#050818,rgba(5,8,24,0))
}
.marquee-row{
  display:flex;
  overflow:hidden;
  gap:18px;
  margin:18px 0;
  mask-image:linear-gradient(90deg,transparent,black 8%,black 92%,transparent)
}
.marquee-track{
  display:flex;
  gap:18px;
  min-width:max-content;
  animation:marquee-left 36s linear infinite
}
.marquee-row.reverse .marquee-track{
  animation-name:marquee-right;
  animation-duration:42s
}
.marquee-row:hover .marquee-track{animation-play-state:paused}
.portfolio-item{
  width:290px;
  height:210px;
  flex:0 0 auto;
  position:relative;
  overflow:hidden;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.13);
  background:linear-gradient(135deg,rgba(169,49,255,.7),rgba(5,8,28,.92));
  box-shadow:0 18px 48px rgba(0,0,0,.22)
}
.portfolio-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.88;
  transition:.35s
}
.portfolio-item:hover img{transform:scale(1.05);opacity:1}
.portfolio-item .overlay{
  position:absolute;
  inset:auto 0 0 0;
  padding:42px 18px 18px;
  background:linear-gradient(0deg,rgba(0,0,0,.86),rgba(0,0,0,0));
}
.portfolio-item b{
  display:block;
  font-size:18px;
  line-height:1.15
}
.portfolio-item span{
  display:inline-flex;
  margin-top:9px;
  padding:5px 10px;
  border-radius:99px;
  background:rgba(238,66,255,.22);
  color:#f7c2ff;
  font-size:11px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.8px
}
.placeholder-item{
  display:grid;
  align-items:end;
  padding:18px;
}
.placeholder-item:nth-child(3n+1){background:linear-gradient(135deg,#1b1239,#8b32ff)}
.placeholder-item:nth-child(3n+2){background:linear-gradient(135deg,#ff9a21,#5621bf)}
.placeholder-item:nth-child(3n+3){background:linear-gradient(135deg,#11162b,#ee42ff)}
.placeholder-item:after{
  content:"";
  position:absolute;
  width:110px;
  height:110px;
  right:-25px;
  top:-25px;
  border-radius:28px;
  background:rgba(255,255,255,.13);
  transform:rotate(18deg)
}
@keyframes marquee-left{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
@keyframes marquee-right{
  from{transform:translateX(-50%)}
  to{transform:translateX(0)}
}


/* Reel video carousel - separate section under portfolio carousel */
.reel-section-inner{margin-top:44px}
.reel-carousel-wrap{width:100%;overflow:hidden;padding:10px 0 8px;position:relative}
.reel-carousel-wrap:before,.reel-carousel-wrap:after{content:"";position:absolute;top:0;width:130px;height:100%;z-index:3;pointer-events:none}
.reel-carousel-wrap:before{left:0;background:linear-gradient(90deg,#050818,rgba(5,8,24,0))}
.reel-carousel-wrap:after{right:0;background:linear-gradient(-90deg,#050818,rgba(5,8,24,0))}
.reel-item{width:210px;height:375px;flex:0 0 auto;position:relative;overflow:hidden;border-radius:24px;border:1px solid rgba(255,255,255,.14);background:linear-gradient(135deg,rgba(169,49,255,.65),rgba(5,8,28,.95));box-shadow:0 22px 65px rgba(0,0,0,.28)}
.reel-item img,.reel-item video{width:100%;height:100%;object-fit:cover;display:block;opacity:.9;transition:.35s}
.reel-item:hover img,.reel-item:hover video{transform:scale(1.05);opacity:1}
.reel-item .reel-overlay{position:absolute;inset:auto 0 0 0;padding:70px 16px 18px;background:linear-gradient(0deg,rgba(0,0,0,.88),rgba(0,0,0,0))}
.reel-item b{display:block;font-size:16px;line-height:1.15}
.reel-item span{display:inline-flex;margin-top:8px;padding:5px 10px;border-radius:99px;background:rgba(255,122,0,.24);color:#ffd7b2;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.8px}
.reel-play-icon{position:absolute;top:16px;right:16px;width:44px;height:44px;display:grid;place-items:center;border-radius:50%;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25);backdrop-filter:blur(10px);font-size:17px}
.reel-placeholder{display:grid;align-items:end;padding:18px}
.reel-placeholder:nth-child(3n+1){background:linear-gradient(160deg,#11162b,#a931ff)}
.reel-placeholder:nth-child(3n+2){background:linear-gradient(160deg,#ff7a00,#28115f)}
.reel-placeholder:nth-child(3n+3){background:linear-gradient(160deg,#151331,#ee42ff)}
.reel-placeholder:after{content:"";position:absolute;width:110px;height:110px;right:-24px;top:-20px;border-radius:50%;background:rgba(255,255,255,.12)}
.single-reel-video{width:min(430px,100%);margin:28px auto;border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.14);box-shadow:0 25px 80px rgba(0,0,0,.35)}
.single-reel-video video{width:100%;height:auto;display:block}
@media (max-width:620px){.reel-item{width:180px;height:320px}}

/* Reel carousel autoplay video behavior */
.reel-item video{
  background:#050818;
}
.reel-item.is-video .reel-play-icon{
  opacity:.95;
}
.reel-sound-hint{
  position:absolute;
  left:14px;
  top:16px;
  z-index:2;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(0,0,0,.42);
  border:1px solid rgba(255,255,255,.16);
  color:#fff;
  font-size:10px;
  font-weight:800;
  letter-spacing:.5px;
  backdrop-filter:blur(10px);
  pointer-events:none;
}


.cta{
  padding:36px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:28px;
  border-radius:24px;
  border:1px solid rgba(238,66,255,.52);
  background:radial-gradient(circle at 15% 45%,rgba(238,66,255,.28),transparent 18%),linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.02));
  box-shadow:var(--glow)
}
.whatsapp-icon{width:92px;height:92px;display:grid;place-items:center;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);font-size:44px}
.cta h2{font-size:clamp(28px,4vw,42px);line-height:1.1}
.cta p{color:var(--muted);margin-top:10px}
.number{font-size:34px;font-weight:900;letter-spacing:2px;margin-bottom:12px;text-align:right}

footer{padding:50px 0 30px;border-top:1px solid rgba(255,255,255,.08)}
.footer-grid{display:grid;grid-template-columns:1.25fr repeat(3,1fr);gap:32px;color:var(--muted)}
.footer-grid h4{color:#fff;margin-bottom:14px}
.footer-grid ul{list-style:none;display:grid;gap:9px;font-size:14px}
.footer-about p{max-width:320px;line-height:1.7;margin-top:16px}
.copyright{margin-top:38px;padding-top:24px;border-top:1px solid rgba(255,255,255,.07);color:rgba(255,255,255,.5);display:flex;justify-content:space-between;gap:18px;font-size:13px}



/* Single portfolio gallery - added images display top-to-bottom, centered, no crop */
.single-portfolio-gallery{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:34px;
  margin-top:36px;
}
.single-portfolio-gallery-title{
  width:100%;
  margin-top:26px;
  margin-bottom:2px;
  font-size:clamp(26px,3vw,42px);
  letter-spacing:-1px;
}
.single-portfolio-gallery figure{
  width:100%;
  margin:0;
  display:flex;
  justify-content:center;
}
.single-portfolio-gallery img{
  display:block;
  width:auto;
  max-width:100%;
  height:auto;
  object-fit:contain;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 22px 70px rgba(0,0,0,.28);
  background:rgba(255,255,255,.035);
}
.single-featured-image{
  border-radius:22px;
  overflow:hidden;
  margin:26px auto;
  display:flex;
  justify-content:center;
}
.single-featured-image img{
  width:auto;
  max-width:100%;
  height:auto;
  object-fit:contain;
  border-radius:22px;
}

.page-content{
  padding:70px 0;
  min-height:50vh;
}
.page-content h1,.page-content h2,.page-content h3{margin-bottom:16px}
.page-content p{color:var(--muted);line-height:1.8;margin-bottom:18px}

@media (max-width:980px){
  .mobile-toggle{display:block}
  .nav-links,.nav .btn-whatsapp{display:none}
  .nav-links.open{
    display:grid;
    position:absolute;
    top:82px;
    left:18px;
    right:18px;
    padding:22px;
    border-radius:20px;
    background:rgba(8,9,30,.96);
    border:1px solid var(--line);
    box-shadow:var(--glow)
  }
  .hero-grid,.cta{grid-template-columns:1fr}
  .hero-visual{min-height:470px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .cards{grid-template-columns:1fr}
  .number{text-align:left}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:620px){
  .hero{padding-top:54px}
  h1{letter-spacing:-1.5px}
  .hero-actions .btn{width:100%}
  .laptop{width:92%;left:0}
  .phone{width:160px;top:180px}
  .tablet{width:80%;right:0}
  .footer-grid{grid-template-columns:1fr}
  .copyright{flex-direction:column}
  .section-title{align-items:flex-start;flex-direction:column}
  .logo-text strong{font-size:18px}
  .logo-img{width:54px;height:54px}
  .portfolio-item{width:240px;height:180px}
}


/* Carousel: rotate only when more than 4 items; otherwise center align */
.marquee-row.static-row{
  justify-content:center;
  overflow:visible;
  mask-image:none;
}
.marquee-row.static-row .marquee-track,
.marquee-track.static-track{
  animation:none !important;
  transform:none !important;
  min-width:auto;
  width:100%;
  justify-content:center;
  flex-wrap:wrap;
}
.marquee-row.static-row .portfolio-item,
.marquee-row.static-row .reel-item{
  margin-left:0;
  margin-right:0;
}
.portfolio-carousel-wrap.static-carousel:before,
.portfolio-carousel-wrap.static-carousel:after,
.reel-carousel-wrap.static-carousel:before,
.reel-carousel-wrap.static-carousel:after{
  display:none;
}


/* Reel video performance mode: no autoplay; play only on hover/touch */
.reel-item .reel-sound-hint{
  transition:.25s;
}
.reel-item.is-playing .reel-sound-hint{
  opacity:0;
  transform:translateY(-6px);
}


/* v1.0.6: Strong center alignment for static carousels */
.portfolio-carousel-wrap.static-carousel,
.reel-carousel-wrap.static-carousel{
  display:flex;
  justify-content:center;
  overflow:visible;
  width:100%;
}
.portfolio-carousel-wrap.static-carousel .marquee-row,
.reel-carousel-wrap.static-carousel .marquee-row{
  width:100%;
  display:flex;
  justify-content:center;
  overflow:visible;
  margin-left:auto;
  margin-right:auto;
}
.portfolio-carousel-wrap.static-carousel .marquee-track,
.reel-carousel-wrap.static-carousel .marquee-track{
  width:auto !important;
  max-width:1180px;
  min-width:0 !important;
  margin-left:auto;
  margin-right:auto;
  display:flex;
  justify-content:center;
  align-items:center;
  flex-wrap:wrap;
  animation:none !important;
  transform:none !important;
}
.reel-carousel-wrap.static-carousel .marquee-track{
  gap:22px;
}


/* v1.0.7 final hard fix: static carousels must be exactly centered */
.static-carousel{
  max-width:1180px;
  margin-left:auto !important;
  margin-right:auto !important;
  padding-left:18px;
  padding-right:18px;
  overflow:visible !important;
}
.static-carousel .marquee-row{
  width:100% !important;
  margin-left:auto !important;
  margin-right:auto !important;
  display:flex !important;
  justify-content:center !important;
  overflow:visible !important;
  mask-image:none !important;
}
.static-carousel .marquee-track{
  width:auto !important;
  min-width:0 !important;
  max-width:100% !important;
  margin-left:auto !important;
  margin-right:auto !important;
  display:flex !important;
  flex-wrap:wrap !important;
  justify-content:center !important;
  align-items:center !important;
  gap:22px !important;
  animation:none !important;
  transform:none !important;
}
.static-carousel .portfolio-item,
.static-carousel .reel-item{
  flex:0 0 auto !important;
}
.static-carousel:before,
.static-carousel:after{
  display:none !important;
}
