/* =============================================
   NOT BOX MEDIA v1.3 — styles.css
   ============================================= */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Poppins',sans-serif;font-weight:300;background:#121212;color:#121212;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body.splash-open{overflow:hidden}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}
button{border:none;background:none;cursor:pointer;font-family:inherit}
textarea,input,select{font-family:inherit}

:root{
  --black:#121212;
  --dark:#121212;
  --gray:#D9D9D9;
  --light:#D9D9D9;
  --white:#ffffff;
  --red:#D90404;
  --blue:#03318C;
  --mag:#8C034E;
  --grad:linear-gradient(90deg,#D90404 0%,#8C034E 50%,#03318C 100%);
  --grad135:linear-gradient(135deg,#D90404 0%,#8C034E 50%,#03318C 100%);
  --nav-h:72px;
  --py:clamp(80px,11vw,152px);
  --px:clamp(24px,6.5vw,128px);
  --mw:1380px;
  --radius:10px;
}



/* ─── NAVBAR MEGA MENU ───────────────────── */
.nav__item{position:relative;list-style:none}
.nav__link--btn{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.8125rem;font-weight:400;
  color:rgba(217,217,217,.5);letter-spacing:.025em;
  padding:4px 0;
  background:none;border:none;cursor:pointer;
  transition:color .2s;
  font-family:inherit;
}
.nav__link--btn:hover,.nav__link--btn.is-open{color:#fff}
.nav__chevron{
  transition:transform .3s cubic-bezier(0.16,1,0.3,1);
  opacity:.5;flex-shrink:0;
}
.nav__link--btn.is-open .nav__chevron{transform:rotate(180deg);opacity:1}

/* Sub panel — expands navbar */
.nav__sub{
  position:absolute;
  top:calc(100% + 16px);
  left:50%;
  transform:translateX(-50%);
  background:rgba(18,18,18,.97);
  -webkit-backdrop-filter:blur(24px);
  backdrop-filter:blur(24px);
  border:1px solid rgba(255,255,255,.07);
  border-radius:14px;
  padding:8px;
  min-width:320px;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateX(-50%) translateY(-8px);
  transition:opacity .3s ease,transform .35s cubic-bezier(0.16,1,0.3,1),visibility .3s ease;
  z-index:200;
}
.nav__sub.open{
  opacity:1;
  visibility:visible;
  pointer-events:all;
  transform:translateX(-50%) translateY(0);
}
/* Arrow tip */
.nav__sub::before{
  content:'';
  position:absolute;
  top:-5px;left:50%;transform:translateX(-50%) rotate(45deg);
  width:10px;height:10px;
  background:rgba(18,18,18,.97);
  border-left:1px solid rgba(255,255,255,.07);
  border-top:1px solid rgba(255,255,255,.07);
}

.nav__sub-item{
  display:flex;align-items:center;gap:16px;
  padding:12px 16px;
  border-radius:8px;
  transition:background .2s ease;
  text-decoration:none;
}
.nav__sub-item:hover{background:rgba(255,255,255,.05)}

.nav__sub-num{
  font-size:.5625rem;font-weight:600;
  letter-spacing:.16em;color:rgba(217,217,217,.25);
  flex-shrink:0;width:20px;
  transition:color .2s;
}
.nav__sub-item:hover .nav__sub-num{color:var(--red)}

.nav__sub-text{display:flex;flex-direction:column;gap:2px}
.nav__sub-title{
  font-size:.9375rem;font-weight:400;
  color:rgba(217,217,217,.75);
  transition:color .2s;
  line-height:1.2;
}
.nav__sub-item:hover .nav__sub-title{color:#fff}
.nav__sub-desc{
  font-size:.75rem;font-weight:300;
  color:rgba(217,217,217,.3);
  line-height:1.3;
  transition:color .2s;
}
.nav__sub-item:hover .nav__sub-desc{color:rgba(217,217,217,.55)}

/* Gradient line under active sub item */
.nav__sub-item::before{
  content:'';
  position:absolute;
  left:8px;top:50%;transform:translateY(-50%);
  width:0;height:20px;
  background:var(--grad);
  border-radius:2px;
  transition:width .25s ease;
  opacity:0;
}
.nav__sub-item:hover::before{width:2px;opacity:1}
.nav__sub-item{position:relative}
/* ─── TIME ───────────────────────────────── */
body.time--night .hero{background:#050505}
body.time--night .hero__glow{background:radial-gradient(circle,rgba(140,3,78,.12) 0%,transparent 65%)}
body.time--morning .hero__glow{background:radial-gradient(circle,rgba(3,49,140,.09) 0%,transparent 65%)}

/* ─── SPLASH ─────────────────────────────── */
.splash{position:fixed;inset:0;z-index:9999;background:#121212;display:flex;align-items:center;justify-content:center;transition:opacity .7s ease,visibility .7s ease}
.splash.hiding{opacity:0;visibility:hidden;pointer-events:none}
.splash__inner{display:flex;flex-direction:column;align-items:center;gap:48px;animation:splashIn .8s cubic-bezier(0.16,1,0.3,1) both}
@keyframes splashIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.splash__logo{width:clamp(160px,28vw,280px)}
.splash__hint{display:flex;align-items:center;gap:10px;font-size:.75rem;font-weight:300;letter-spacing:.12em;color:rgba(217,217,217,.35)}
.splash__hint-sep{opacity:.4}
.splash__opts{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.splash__opt{position:relative;overflow:hidden;padding:14px 40px;border:1px solid rgba(217,217,217,.15);font-size:.875rem;font-weight:400;letter-spacing:.1em;color:rgba(217,217,217,.65);transition:color .35s ease,border-color .35s ease;border-radius:var(--radius);cursor:pointer}
.splash__opt-bg{position:absolute;inset:0;background:var(--grad);transform:translateX(-101%);transition:transform .5s cubic-bezier(0.16,1,0.3,1)}
.splash__opt-text{position:relative;z-index:1}
.splash__opt:hover .splash__opt-bg{transform:translateX(0)}
.splash__opt:hover{color:#fff;border-color:transparent}

/* ─── CALL FAB ───────────────────────────── */
.call-fab{display:none;position:fixed;bottom:28px;right:24px;z-index:800;width:54px;height:54px;background:var(--red);border-radius:50%;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 28px rgba(217,4,4,.4);transition:transform .3s ease,box-shadow .3s ease}
.call-fab:hover,.call-fab:active{transform:scale(1.1);box-shadow:0 12px 36px rgba(217,4,4,.55)}

/* ─── NAVBAR ─────────────────────────────── */
.nav{position:fixed;inset:0 0 auto 0;z-index:900;height:var(--nav-h);transition:background .5s ease,border-color .5s ease;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(18,18,18,.92);-webkit-backdrop-filter:blur(24px) saturate(1.4);backdrop-filter:blur(24px) saturate(1.4);border-color:rgba(255,255,255,.05)}
.nav__inner{
  max-width:var(--mw);margin:0 auto;padding:0 var(--px);
  height:100%;display:flex;
  align-items:center;
  gap:0;
}
.nav__logo-img{height:20px;width:auto;display:block}
.nav__links{display:flex;gap:28px;margin-left:auto}
.nav__link{font-size:.8125rem;font-weight:400;color:rgba(217,217,217,.5);letter-spacing:.025em;padding:4px 0;position:relative;transition:color .2s}
.nav__link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--grad);transition:width .35s ease}
.nav__link:hover,.nav__link.is-active{color:#fff;font-weight:500}
.nav__link:hover::after,.nav__link.is-active::after{width:100%}
.lang-toggle{display:flex;align-items:center;gap:5px;margin-left:24px}
.lang-btn{font-size:.6875rem;font-weight:500;letter-spacing:.1em;color:rgba(217,217,217,.32);padding:3px 4px;transition:color .2s;cursor:pointer}
.lang-btn.active,.lang-btn:hover{color:#fff}
.lang-sep{font-size:.6875rem;color:rgba(217,217,217,.2)}
.nav__burger{display:none;flex-direction:column;justify-content:center;gap:5px;padding:8px;margin-left:auto;cursor:pointer}
.nav__burger span{display:block;width:22px;height:1.5px;background:rgba(217,217,217,.8);border-radius:2px;transition:transform .35s ease,opacity .25s ease}
.nav__burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav__burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav__burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.nav__mobile{display:none;flex-direction:column;background:rgba(18,18,18,.97);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);padding:8px var(--px) 48px;opacity:0;transform:translateY(-8px);pointer-events:none;transition:opacity .35s ease,transform .35s ease}
.nav__mobile.open{opacity:1;transform:translateY(0);pointer-events:all}
.nav__mobile-list{display:flex;flex-direction:column}
.nav__mobile-link{display:block;font-size:1.125rem;font-weight:300;color:rgba(217,217,217,.7);padding:18px 0;border-bottom:1px solid rgba(255,255,255,.05);transition:color .2s}
.nav__mobile-link:hover{color:#fff}
.nav__mobile-lang{display:flex;align-items:center;gap:6px;margin-top:28px}

/* ─── HERO ───────────────────────────────── */
.hero{min-height:100vh;min-height:100svh;background:var(--black);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:var(--nav-h) var(--px) 96px;transition:background 1s ease}
.hero__glow{position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(140,3,78,.07) 0%,transparent 65%);top:50%;left:50%;transform:translate(-50%,-55%);pointer-events:none;will-change:transform;transition:background 1s ease}
.hero__content{display:flex;flex-direction:column;align-items:center;text-align:center;gap:clamp(28px,4vw,52px);position:relative;z-index:1;max-width:860px;width:100%;padding-top:clamp(32px,5vw,72px)}
.hero__logo{width:clamp(160px,26vw,300px)}
.hero__text-wrap{display:flex;flex-direction:column;align-items:center;gap:clamp(16px,2.5vw,28px);will-change:transform;transition:transform .08s linear}
.hero__greeting{font-size:clamp(.875rem,1.5vw,1.125rem);font-weight:300;color:rgba(217,217,217,.4);letter-spacing:.06em;min-height:1.5em}
.hero__tagline{display:flex;flex-direction:column;font-size:clamp(1.875rem,5.2vw,5.25rem);font-weight:500;line-height:1.1;letter-spacing:-.025em;color:var(--gray);gap:2px}
.hero__line{display:block}
.hero__line--grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.hero__bar{width:clamp(200px,45vw,480px);height:2px;background:var(--grad)}
.hero__scroll{position:absolute;bottom:44px;left:50%;transform:translateX(-50%)}
.hero__scroll-line{width:1px;height:56px;background:linear-gradient(to bottom,transparent,rgba(217,217,217,.25));animation:scrollPulse 2.2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.15)}}

/* ─── BUTTONS — FILL ─────────────────────── */
.btn--fill{
  position:relative;overflow:hidden;
  display:inline-flex;align-items:center;gap:10px;
  font-size:.875rem;font-weight:400;letter-spacing:.05em;
  color:rgba(217,217,217,.7);
  border:1px solid rgba(217,217,217,.2);
  padding:10px 22px;
  transition:color .3s ease,border-color .3s ease;
  cursor:pointer;
  border-radius:var(--radius);
}
.btn--fill .btn-fill-bg{position:absolute;inset:0;background:var(--grad);transform:translateX(-101%);transition:transform .55s cubic-bezier(0.16,1,0.3,1);pointer-events:none}
.btn--fill .btn-text,.btn--fill svg{position:relative;z-index:1}
.btn--fill:hover .btn-fill-bg{transform:translateX(0)}
.btn--fill:hover{color:#fff;border-color:transparent}
.btn--fill svg{transition:transform .3s ease;flex-shrink:0}
.btn--fill:hover svg{transform:translateX(5px)}

/* Hero CTA special: arrow points down */
.hero__cta{padding:12px 28px}
.hero__cta:hover svg{transform:translateY(5px)!important}

/* ─── HERO ANIMATIONS ────────────────────── */
.anim-logo{opacity:0;transform:scale(.94);transition:opacity 1s ease,transform 1s ease}
.anim-logo.in{opacity:1;transform:scale(1)}
.anim-line{opacity:0;transform:translateY(28px);transition:opacity .85s ease,transform .85s ease;transition-delay:var(--d,.3s)}
.anim-line.in{opacity:1;transform:translateY(0)}
.anim-bar{opacity:0;transform:scaleX(0);transform-origin:left;transition:opacity .7s ease .85s,transform .9s cubic-bezier(0.16,1,0.3,1) .85s}
.anim-bar.in{opacity:1;transform:scaleX(1)}
.anim-cta{opacity:0;transform:translateY(16px);transition:opacity .6s ease 1.1s,transform .6s ease 1.1s}
.anim-cta.in{opacity:1;transform:translateY(0)}

/* ─── SECTIONS ───────────────────────────── */
.sec{padding:var(--py) var(--px)}
.sec--dark{background:var(--black)}
.sec--light{background:var(--light)}
.sec__wrap{max-width:var(--mw);margin:0 auto}
.sec__label{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:56px}
.sec__num{font-size:1.5rem;font-weight:700;letter-spacing:.1em;color:rgba(255,255,255,.9)}
.sec__num--dim{color:rgba(255,255,255,.85)}
.sec__tag{font-size:.875rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.sec__tag--dim{color:rgba(255,255,255,.65)}
.sec__title{font-size:clamp(2.25rem,4.5vw,4.75rem);font-weight:500;line-height:1.08;letter-spacing:-.025em;color:var(--dark);margin-bottom:72px}
.sec__title--light{color:var(--gray)}

/* ─── ABOUT ──────────────────────────────── */
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;margin-bottom:88px}
.about__headline{font-size:clamp(1.875rem,3.2vw,3.25rem);font-weight:500;line-height:1.18;letter-spacing:-.02em;color:var(--dark)}
.about__cols{display:flex;flex-direction:column;gap:44px}
.about__col{padding-left:20px;border-left:1px solid rgba(15,23,31,.1)}
.about__col-label{font-size:.625rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:rgba(15,23,31,.38);margin-bottom:12px}
.about__col-body{font-size:1rem;font-weight:300;line-height:1.8;color:rgba(15,23,31,.65)}
.about__quote{border-top:1px solid rgba(15,23,31,.08);padding-top:64px;max-width:880px}
.about__quote p{font-size:clamp(1.375rem,2.8vw,2.375rem);font-weight:300;font-style:italic;line-height:1.45;letter-spacing:-.01em;color:rgba(15,23,31,.5)}

/* ─── MANIFIESTO — STICKY SCROLL ─────────── */
.mf-section{position:relative;height:320vh;background:var(--black)}
.mf-sticky{position:sticky;top:0;height:100vh;display:flex;align-items:center;overflow:hidden;padding:0 var(--px)}
.mf-sticky .sec__wrap{width:100%;max-width:var(--mw)}
.mf__title{font-size:clamp(2.25rem,4.5vw,4.75rem);font-weight:500;line-height:1.08;letter-spacing:-.025em;color:var(--gray);margin-bottom:48px}
.mf__body{font-size:clamp(1.125rem,2.2vw,1.75rem);font-weight:300;line-height:1.7;letter-spacing:-.01em;max-width:980px}
.mf__word{display:inline;transition:opacity .5s ease;opacity:0;color:rgba(217,217,217,.88)}
.mf__word.lit{opacity:1}
/* Gradient wrapper — last sentence as one unit */
.mf__grad-wrap{
  display:inline;
  background:var(--grad);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}
.mf__grad-wrap .mf__word{
  -webkit-text-fill-color:inherit;
  color:inherit;
}
.mf__grad-wrap .mf__word.lit{opacity:1}

100%{transform:translateX(-50%)}}

/* ─── SERVICES — TICKER ──────────────────── */
.svc-ticker{overflow:hidden;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);padding:6px 0}
.svc-ticker__track{display:inline-flex;align-items:center;white-space:nowrap;animation:svcScroll 30s linear infinite;will-change:transform}
@keyframes svcScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.svc-ticker__item{display:inline-flex;align-items:center;gap:14px;padding:20px 48px;background:none;border:none;cursor:pointer;transition:background .25s ease;white-space:nowrap;border-radius:0}
.svc-ticker__item:hover,.svc-ticker__item.active{background:rgba(255,255,255,.04)}
.svc-ticker__num{font-size:.6875rem;font-weight:500;letter-spacing:.14em;color:rgba(217,217,217,.22);transition:color .25s}
.svc-ticker__name{font-size:clamp(1.25rem,2.5vw,2rem);font-weight:500;letter-spacing:-.02em;color:rgba(217,217,217,.45);transition:color .3s ease}
.svc-ticker__item:hover .svc-ticker__name,.svc-ticker__item.active .svc-ticker__name{color:#fff}
.svc-ticker__item.active .svc-ticker__num{color:var(--red)}
.svc-ticker__sep{font-size:1rem;color:rgba(217,217,217,.1);padding:0 16px;pointer-events:none}

/* Detail panel */
.svc-detail{overflow:hidden}
.svc-detail__panel{display:none;padding:56px 0;animation:panelIn .5s cubic-bezier(0.16,1,0.3,1) both}
.svc-detail__panel.active{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
@keyframes panelIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.svc-detail__left{display:flex;flex-direction:column;gap:24px}
/* FIX: numbers in white */
.svc-detail__num{font-size:5rem;font-weight:900;line-height:1;letter-spacing:-.04em;color:rgba(255,255,255,.75)}
.svc-detail__title{font-size:clamp(1.75rem,3vw,2.75rem);font-weight:500;letter-spacing:-.025em;color:var(--gray)}
.svc-detail__body{font-size:1rem;font-weight:300;line-height:1.8;color:rgba(217,217,217,.55)}
.svc-detail__cta{margin-top:8px}
.svc-detail__list{padding-top:24px;display:flex;flex-direction:column;gap:16px;border-top:1px solid rgba(255,255,255,.06)}
.svc-detail__list li{font-size:.9375rem;font-weight:300;color:rgba(217,217,217,.5);padding-left:20px;position:relative;line-height:1.6}
.svc-detail__list li::before{content:'';position:absolute;left:0;top:.65em;width:8px;height:1px;background:var(--grad)}

/* ─── CAROUSEL 3D ────────────────────────── */
/* Full-width with edge fade mask — words never clip */
.carousel-3d{
  position:relative;
  padding:48px 0 80px;
  width:100vw;
  margin-left:calc(-1 * var(--px));
  overflow:visible;
}
/* Edge fades as overlay layers — don't affect overflow unlike mask-image */
.carousel-3d::before,
.carousel-3d::after{
  content:'';
  position:absolute;
  top:0;bottom:0;
  width:14%;
  z-index:10;
  pointer-events:none;
}
.carousel-3d::before{
  left:0;
  background:linear-gradient(to right,var(--light) 0%,transparent 100%);
}
.carousel-3d::after{
  right:0;
  background:linear-gradient(to left,var(--light) 0%,transparent 100%);
}
.carousel-3d__stage{
  position:relative;
  height:260px;
  display:flex;align-items:center;justify-content:center;
  perspective:1400px;
  margin-bottom:48px;
  overflow:visible;
  padding:0 var(--px);
  padding-bottom:40px;
}
.carousel-3d__item{
  position:absolute;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:transform .7s cubic-bezier(0.16,1,0.3,1),opacity .7s ease;
  -webkit-user-select:none;user-select:none;
  white-space:nowrap;
}
.carousel-3d__word{
  font-size:clamp(2.25rem,5.5vw,5rem);
  font-weight:500;letter-spacing:-.03em;line-height:1;
  white-space:nowrap;
  transition:color .4s ease;
  color:rgba(15,23,31,.2);
}
.carousel-3d__item[data-pos="0"] .carousel-3d__word{
  background:var(--grad);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}
.carousel-3d__info{text-align:center;display:flex;flex-direction:column;align-items:center;gap:28px;padding:0 var(--px)}
.carousel-3d__desc{font-size:1rem;font-weight:300;line-height:1.75;color:rgba(15,23,31,.6);max-width:520px;min-height:3.5em;transition:opacity .4s ease,transform .4s ease}
.carousel-3d__desc.changing{opacity:0;transform:translateY(8px)}
.carousel-3d__dots{display:flex;gap:10px;align-items:center}
.carousel-3d__dot{width:7px;height:7px;border-radius:50%;background:rgba(15,23,31,.2);transition:background .25s,transform .25s;padding:0;border:none;cursor:pointer}
.carousel-3d__dot.active{background:var(--red);transform:scale(1.3)}
.carousel-3d__nav{position:absolute;top:50%;transform:translateY(-130%);width:44px;height:44px;border-radius:50%;border:1px solid rgba(15,23,31,.12);display:flex;align-items:center;justify-content:center;color:rgba(15,23,31,.4);transition:border-color .2s,color .2s,background .2s;z-index:10;cursor:pointer}
.carousel-3d__nav:hover{border-color:rgba(15,23,31,.35);color:var(--dark);background:rgba(15,23,31,.05)}
.carousel-3d__nav--prev{left:var(--px)}
.carousel-3d__nav--next{right:var(--px)}

/* ─── PHILOSOPHY ─────────────────────────── */
.phil__grid{display:grid;grid-template-columns:1fr 1px 1fr;gap:64px;align-items:start;margin-bottom:72px}
.phil__block{display:flex;flex-direction:column;gap:24px}
.phil__header{display:flex;align-items:center;gap:16px}
.phil__label{font-size:.625rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(217,217,217,.32)}
.phil__accent{height:2px;width:28px}
.phil__accent--red{background:var(--red)}
.phil__accent--blue{background:var(--blue)}
.phil__body{font-size:1.0625rem;font-weight:300;line-height:1.82;color:rgba(217,217,217,.58)}
.phil__divider{background:rgba(255,255,255,.07);align-self:stretch;min-height:160px}
.phil__bar{height:2px;width:100%;background:var(--grad);opacity:.5}

/* ─── VALUES ─────────────────────────────── */
.vals__grid{display:grid;grid-template-columns:1fr 1fr}
.val__item{padding:40px 36px;border:1px solid rgba(15,23,31,.07);position:relative;overflow:hidden;transition:background .3s,transform .18s ease,box-shadow .18s ease;transform-style:preserve-3d;will-change:transform}
.val__item:hover{background:rgba(15,23,31,.03)}
.val__item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px}
.val--red::before{background:var(--red)}
.val--blue::before{background:var(--blue)}
.val--mag::before{background:var(--mag)}
.val__title{font-size:1.1875rem;font-weight:500;letter-spacing:-.01em;color:var(--dark);margin-bottom:10px}
.val__body{font-size:.9375rem;font-weight:300;line-height:1.72;color:rgba(15,23,31,.58)}

/* ─── CONTACT SPLIT ──────────────────────── */
.contact-section{background:var(--black);padding-top:var(--py)}
.contact-split{display:grid;grid-template-columns:1fr 1fr;min-height:680px}
.contact-left{padding:var(--py) var(--px);display:flex;flex-direction:column;justify-content:center}
.contact-left__title{font-size:clamp(1.875rem,3.5vw,3.5rem);font-weight:500;line-height:1.12;letter-spacing:-.025em;color:var(--gray);margin-bottom:20px}
.contact-left__sub{font-size:1rem;font-weight:300;line-height:1.75;color:rgba(217,217,217,.45);margin-bottom:48px;max-width:380px}
.contact-left__info{display:flex;flex-direction:column;gap:20px}
.contact-left__row{display:flex;align-items:center;gap:16px;color:rgba(217,217,217,.55);font-size:.9375rem;font-weight:300;transition:color .2s}
.contact-left__row:hover{color:#fff}
.contact-left__icon{width:38px;height:38px;border:1px solid rgba(217,217,217,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .2s,background .2s}
.contact-left__row:hover .contact-left__icon{border-color:rgba(217,217,217,.3);background:rgba(217,217,217,.05)}
.contact-right{background:var(--grad);display:flex;align-items:center;justify-content:center;padding:var(--py) clamp(32px,5vw,64px)}
.contact-right__card{background:#fff;border-radius:20px;padding:40px 36px;width:100%;max-width:480px;box-shadow:0 24px 64px rgba(0,0,0,.25)}
.contact-right__label{font-size:.625rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(15,23,31,.4);margin-bottom:28px}
.contact-form{display:flex;flex-direction:column;gap:18px}
.cf-field{display:flex;flex-direction:column;gap:6px}
.cf-label{font-size:.6875rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:rgba(15,23,31,.45)}
.cf-input{padding:12px 16px;background:rgba(15,23,31,.05);border:1px solid rgba(15,23,31,.1);font-size:.9375rem;font-weight:300;color:var(--dark);outline:none;transition:border-color .25s,background .25s;-webkit-appearance:none;appearance:none;resize:none;border-radius:var(--radius);caret-color:var(--red)}
.cf-input:focus{border-color:var(--red);background:rgba(217,4,4,.03)}
.cf-select{cursor:pointer}
.cf-textarea{min-height:90px}
.cf-submit{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:15px 24px;background:var(--dark);color:#fff;font-size:.9375rem;font-weight:500;letter-spacing:.04em;border-radius:var(--radius);margin-top:8px;transition:background .25s,transform .2s;cursor:pointer}
.cf-submit:hover{background:#111;transform:translateY(-1px)}
.cf-submit svg{transition:transform .3s ease;flex-shrink:0}
.cf-submit:hover svg{transform:translateX(4px)}

/* ─── FOOTER ─────────────────────────────── */
.footer{background:var(--black);border-top:1px solid rgba(255,255,255,.05);padding:72px var(--px) 48px}
.footer__wrap{max-width:var(--mw);margin:0 auto}
.footer__bar{height:2px;background:var(--grad);margin-bottom:64px;opacity:.45}
.footer__body{display:flex;flex-direction:column;align-items:center;gap:36px}
.footer__logo{height:64px;width:auto;opacity:.65;transition:opacity .3s}
.footer__logo:hover{opacity:1}
.footer__nav{display:flex;flex-wrap:wrap;justify-content:center;gap:28px}
.footer__link{font-size:.8125rem;font-weight:300;color:rgba(217,217,217,.35);letter-spacing:.04em;transition:color .2s}
.footer__link:hover{color:rgba(217,217,217,.85)}
.footer__copy{font-size:.6875rem;font-weight:300;color:rgba(217,217,217,.2);letter-spacing:.06em}

/* ─── SCROLL REVEAL ──────────────────────── */
.rev{opacity:0;transform:translateY(36px);transition:opacity .85s cubic-bezier(0.16,1,0.3,1),transform .85s cubic-bezier(0.16,1,0.3,1);transition-delay:var(--d,0s)}
.rev.in{opacity:1;transform:translateY(0)}

/* ─── TILT CARDS ─────────────────────────── */
.tilt-card{transform-style:preserve-3d;will-change:transform}


/* ─── HERO LOGO FLASHLIGHT ───────────────── */
.hero__logo-wrap{
  position:relative;
  width:clamp(200px,32vw,380px);
  cursor:crosshair;
}
.hero__logo-base{
  width:100%;
  display:block;
  filter:brightness(0) invert(1);
  opacity:1;
}
.hero__logo-grad{
  position:absolute;
  inset:0;
  width:100%;
  display:block;
  background:var(--grad);
  -webkit-mask-image:url("assets/logo.svg");
  mask-image:url("assets/logo.svg");
  -webkit-mask-size:100% 100%;
  mask-size:100% 100%;
  -webkit-mask-repeat:no-repeat;
  mask-repeat:no-repeat;
  opacity:0;
  transition:opacity .1s ease;
  pointer-events:none;
  /* Radial mask controlled by JS via --mx --my --mr */
  -webkit-mask-composite:source-in;
  mask-composite:intersect;
}


/* Nav logo hover — gradient filter trick */
.nav__logo:hover .nav__logo-img{
  filter:none;
}
.nav__logo-img{
  transition:filter .35s ease;
}

.svc-ticker__icon{
  width:28px;height:28px;
  object-fit:contain;
  opacity:.45;
  filter:brightness(0) invert(1);
  transition:opacity .25s;
  flex-shrink:0;
}
.svc-ticker__item:hover .svc-ticker__icon,
.svc-ticker__item.active .svc-ticker__icon{opacity:.9}

/* ─── MORSE MULTI-LINE ───────────────────── */
.morse-strip{
  overflow:hidden;
  background:var(--black);
  border-top:1px solid rgba(255,255,255,.04);
  border-bottom:1px solid rgba(255,255,255,.04);
  padding:10px 0;
  display:flex;flex-direction:column;gap:4px;
}
.morse-strip__track{
  display:inline-flex;
  white-space:nowrap;
  will-change:transform;
}
.morse-strip__track--1{animation:morseScroll 55s linear infinite}
.morse-strip__track--2{animation:morseScroll 70s linear infinite reverse}
.morse-strip__track--3{animation:morseScroll 45s linear infinite}
.morse-strip__seg{
  font-size:.5625rem;font-weight:300;letter-spacing:.1em;
  color:rgba(217,217,217,.55);padding:0 32px;
}
.morse-strip__seg--accent{color:rgba(217,4,4,.9)}
.morse-strip__seg--accent-blue{color:rgba(3,49,140,.95)}
@keyframes morseScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ─── SOCIAL ICONS SECTION ───────────────── */
.social-strip{
  display:flex;align-items:center;justify-content:center;
  gap:40px;padding:52px var(--px);
  background:var(--black);
  flex-wrap:wrap;
}
.social-strip__item{
  display:flex;align-items:center;
  gap:14px;text-decoration:none;
  transition:opacity .25s ease;
}
.social-strip__item:hover{opacity:.75}
.social-strip__icon{
  width:28px;height:28px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.social-strip__icon svg{display:block;width:100%;height:100%}
.social-strip__label{
  font-size:.9375rem;font-weight:300;
  letter-spacing:.04em;
  color:rgba(217,217,217,.75);
}

/* ─── THE CREW ───────────────────────────── */
.crew-section{
  background:var(--black);
  padding:var(--py) var(--px);
}
.crew-section .sec__wrap{max-width:var(--mw);margin:0 auto}
.crew__title{
  font-size:clamp(2.5rem,5vw,5rem);
  font-weight:500;line-height:1;letter-spacing:-.035em;
  color:var(--gray);margin-bottom:72px;
}
.crew__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
  width:100%;
}
@media(min-width:1200px){.crew__grid{grid-template-columns:repeat(5,minmax(0,1fr))}}
.crew__card{
  border-radius:24px;
  overflow:hidden;
  position:relative;
  cursor:default;
  background:#1a1a1a;
  transition:transform .4s cubic-bezier(0.16,1,0.3,1),box-shadow .4s ease;
  display:flex;
  flex-direction:column;
  box-shadow:
    0 0 30px 5px rgba(217,4,4,.06),
    0 0 30px 5px rgba(3,49,140,.06),
    0 0 60px 10px rgba(140,3,78,.04);
}
.crew__card:hover{
  transform:translateY(-10px);
  box-shadow:
    0 0 40px 10px rgba(217,4,4,.12),
    0 0 40px 10px rgba(3,49,140,.12),
    0 0 80px 20px rgba(140,3,78,.08),
    0 30px 60px rgba(0,0,0,.4);
}
.crew__photo-wrap{
  position:relative;
  width:100%;
  padding-top:110%;
  overflow:hidden;
  flex-shrink:0;
}
.crew__photo-wrap::after{
  content:'';
  position:absolute;
  bottom:0;left:0;right:0;
  height:60%;
  background:linear-gradient(to top,#1a1a1a 0%,rgba(26,26,26,.6) 40%,transparent 100%);
  pointer-events:none;
  z-index:1;
}
.crew__photo{
  position:absolute;
  inset:0;
  width:100%;height:100%;
  object-fit:cover;
  object-position:top center;
  display:block;
  transition:transform .6s cubic-bezier(0.16,1,0.3,1);
}
.crew__card:hover .crew__photo{transform:scale(1.05)}
.crew__body{
  background:#1a1a1a;
  padding:24px 24px 28px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.crew__name{
  font-size:1.125rem;font-weight:500;
  color:#fff;letter-spacing:-.01em;
  display:flex;align-items:center;gap:8px;
}
.crew__badge{
  width:16px;height:16px;flex-shrink:0;
  background:var(--blue);border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
}
.crew__badge svg{display:block}
.crew__role{
  font-size:.8125rem;font-weight:300;
  color:rgba(217,217,217,.55);
  line-height:1.5;
}
.crew__desc{
  font-size:.75rem;font-weight:300;
  color:rgba(217,217,217,.4);
  line-height:1.55;
}
.crew__divider{
  height:1px;background:rgba(255,255,255,.08);
  margin:4px 0;
}
.crew__cta{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:rgba(255,255,255,.94);
  color:#111;
  font-size:.875rem;font-weight:500;
  letter-spacing:.02em;
  padding:13px 20px;
  border-radius:50px;
  text-decoration:none;
  margin-top:4px;
  transition:background .25s ease,transform .2s ease;
  width:100%;
}
.crew__cta:hover{background:#fff;transform:scale(1.02)}

@media(max-width:900px){.crew__grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:560px){.crew__grid{grid-template-columns:minmax(0,1fr);max-width:360px;margin:0 auto}}

/* ─── VALUES REDESIGN — gradient card style ─ */
.vals-new__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.val-new__item{
  position:relative;
  border-radius:20px;
  overflow:hidden;
  background:var(--grad135);
  padding:3px;
  transition:transform .3s ease,box-shadow .3s ease;
}
.val-new__item:hover{
  transform:translateY(-4px);
  box-shadow:0 24px 56px rgba(0,0,0,.2);
}
.val-new__inner{
  background:rgba(255,255,255,.95);
  border-radius:18px;
  padding:40px 32px;
  height:100%;
  display:flex;flex-direction:column;gap:14px;
}
.val-new__num{
  font-size:.625rem;font-weight:600;
  letter-spacing:.2em;
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
.val-new__title{
  font-size:1.375rem;font-weight:500;
  letter-spacing:-.01em;color:var(--dark);
}
.val-new__body{
  font-size:.9375rem;font-weight:300;
  line-height:1.72;color:rgba(15,23,31,.6);
}

@media(max-width:1100px){.vals-new__grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.vals-new__grid{grid-template-columns:1fr}}

/* ─── VIDEO SECTION ─────────────────────── */
.video-section{
  position:relative;
  width:100%;
  min-height:100vh;
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.video-section__video{
  position:absolute;
  inset:0;width:100%;height:100%;
  object-fit:cover;
  z-index:0;
}
.video-section__overlay{
  position:absolute;inset:0;
  background:rgba(15,23,31,.72);
  z-index:1;
}
.video-section__content{
  position:relative;z-index:2;
  text-align:center;
  padding:0 var(--px);
  max-width:1100px;
}

.video-section__title{
  font-size:clamp(2.5rem,7vw,7rem);
  font-weight:500;line-height:1.05;
  letter-spacing:-.025em;
  color:#fff;
}
.video-section__title-grad{
  display:block;
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}

/* ─── FOOTER REDESIGN ───────────────────── */
.footer-new{
  background:var(--black);
  padding:var(--py) var(--px) 48px;
  border-top:1px solid rgba(255,255,255,.06);
}
.footer-new__wrap{max-width:var(--mw);margin:0 auto}
.footer-new__top{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:64px;
  padding-bottom:64px;
  border-bottom:1px solid rgba(255,255,255,.06);
  margin-bottom:40px;
}
.footer-new__logo{
  height:52px;width:auto;
  margin-bottom:0;
  opacity:.9;
}
.footer-new__col-title{
  font-size:.625rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:rgba(217,217,217,.45);
  margin-bottom:20px;
}
.footer-new__links{
  display:flex;flex-direction:column;gap:12px;
}
.footer-new__link{
  font-size:.9375rem;font-weight:300;
  color:rgba(217,217,217,.5);
  text-decoration:none;
  transition:color .2s;
  letter-spacing:.02em;
}
.footer-new__link:hover{color:#fff}
.footer-new__bottom{
  display:flex;align-items:center;justify-content:center;
}
.footer-new__copy{
  font-size:.75rem;font-weight:300;
  color:rgba(217,217,217,.22);letter-spacing:.08em;
}
@media(max-width:860px){
  .footer-new__top{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:560px){
  .footer-new__top{grid-template-columns:1fr}
}

/* ─── SVC NAV BUTTONS ───────────────────── */
.svc-nav{
  display:flex;align-items:center;gap:12px;
  margin-top:32px;
}
.svc-nav__btn{
  width:44px;height:44px;border-radius:50%;
  border:1px solid rgba(217,217,217,.2);
  display:flex;align-items:center;justify-content:center;
  color:rgba(217,217,217,.5);
  background:none;cursor:pointer;
  transition:border-color .25s,color .25s,background .25s;
}
.svc-nav__btn:hover{
  border-color:rgba(217,217,217,.6);
  color:#fff;
  background:rgba(217,217,217,.05);
}
.svc-nav__count{
  font-size:.75rem;font-weight:300;
  color:rgba(217,217,217,.35);
  letter-spacing:.08em;
  padding:0 4px;
}

/* ─── SOCIAL STRIP UPDATED ──────────────── */
.social-strip{
  display:flex;align-items:center;justify-content:center;
  gap:64px;padding:64px var(--px);
  background:var(--black);
  flex-wrap:wrap;
}
.social-strip__item{
  display:flex;align-items:center;
  gap:20px;text-decoration:none;
  transition:opacity .25s ease;
}
.social-strip__item:hover{opacity:.7}
.social-strip__icon{
  width:48px;height:48px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.social-strip__icon svg{
  display:block;
  width:100%;height:100%;
  fill:white;
}
.social-strip__icon svg path,
.social-strip__icon svg circle,
.social-strip__icon svg rect,
.social-strip__icon svg polygon{fill:white}
.social-strip__label{
  font-size:1.375rem;font-weight:400;
  letter-spacing:.02em;
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
@media(max-width:600px){
  .social-strip{gap:36px;flex-direction:column;align-items:flex-start;padding-left:var(--px)}
}

/* ─── PREMIUM FOLDER CARDS ──────────────── */
.prem-section{padding:var(--py) var(--px)}
.prem-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
}


/* ─── FOOTER SOCIAL ──────────────────────── */
.footer-social{
  display:flex;align-items:center;gap:32px;
  padding:32px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
  margin-bottom:40px;
  flex-wrap:wrap;
}
.footer-social__item{
  display:flex;align-items:center;gap:10px;
  text-decoration:none;
  transition:opacity .2s;
}
.footer-social__item:hover{opacity:.8}
.footer-social__item span{
  font-size:.875rem;font-weight:300;
  color:rgba(217,217,217,.5);
  letter-spacing:.03em;
}
/* ─── RESPONSIVE ─────────────────────────── */
@media(max-width:1100px){
  .about__grid{grid-template-columns:1fr;gap:48px}
  .phil__grid{grid-template-columns:1fr;gap:48px}
  .phil__divider{display:none}
  .svc-detail__panel.active{grid-template-columns:1fr;gap:36px}
  .contact-split{grid-template-columns:1fr}
  .contact-left{padding-bottom:0}
  .contact-right{padding-top:clamp(32px,5vw,64px);padding-bottom:var(--py);padding-bottom:36px}
  .carousel-3d__word{font-size:clamp(1.75rem,7vw,2.5rem)}
}

/* ─── ACCESSIBILITY ──────────────────────── */
a:focus-visible,button:focus-visible{outline:2px solid rgba(217,217,217,.5);outline-offset:4px;border-radius:2px}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .rev,.anim-logo,.anim-line,.anim-bar,.anim-cta{opacity:1!important;transform:none!important}
}

/* ─── NOSOTROS PAGE ──────────────────────── */
.page-nosotros .sec--light .sec__num,.page-nosotros .sec--light .sec__tag{color:rgba(15,23,31,.85)}

/* Values hover-reveal cards */
.vals-reveal__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
}
.val-reveal__item{
  position:relative;
  overflow:hidden;
  padding:56px 44px 52px;
  border:1px solid rgba(255,255,255,.06);
  cursor:default;
  min-height:320px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  transition:border-color .4s ease;
}
.val-reveal__item::before{
  content:'';
  position:absolute;
  inset:0;
  opacity:0;
  transition:opacity .5s ease;
}
.val-reveal__item.color--red::before  { background:linear-gradient(135deg,rgba(217,4,4,.18) 0%,transparent 70%); }
.val-reveal__item.color--blue::before { background:linear-gradient(135deg,rgba(3,49,140,.18) 0%,transparent 70%); }
.val-reveal__item.color--mag::before  { background:linear-gradient(135deg,rgba(140,3,78,.18) 0%,transparent 70%); }
.val-reveal__item:hover::before{ opacity:1; }

.val-reveal__num{
  font-size:7rem;
  font-weight:900;
  line-height:1;
  letter-spacing:-.04em;
  color:rgba(255,255,255,.04);
  position:absolute;
  top:24px;right:32px;
  transition:color .4s ease, transform .4s cubic-bezier(0.16,1,0.3,1);
  -webkit-user-select:none;user-select:none;
}
.val-reveal__item:hover .val-reveal__num{
  color:rgba(255,255,255,.08);
  transform:scale(1.1) translateY(-4px);
}
.val-reveal__accent{
  width:32px;height:2px;
  margin-bottom:20px;
  transition:width .4s cubic-bezier(0.16,1,0.3,1);
}
.color--red  .val-reveal__accent{ background:var(--red); }
.color--blue .val-reveal__accent{ background:var(--blue); }
.color--mag  .val-reveal__accent{ background:var(--mag); }
.val-reveal__item:hover .val-reveal__accent{ width:56px; }

.val-reveal__title{
  font-size:1.5rem;
  font-weight:500;
  letter-spacing:-.02em;
  color:var(--gray);
  margin-bottom:14px;
  transition:color .3s ease;
}
.val-reveal__item:hover .val-reveal__title{ color:#fff; }

.val-reveal__body{
  font-size:.9375rem;
  font-weight:300;
  line-height:1.72;
  color:rgba(217,217,217,.35);
  max-height:0;
  overflow:hidden;
  transition:max-height .5s cubic-bezier(0.16,1,0.3,1), color .4s ease;
}
.val-reveal__item:hover .val-reveal__body{
  max-height:120px;
  color:rgba(217,217,217,.65);
}

/* Phil blocks on nosotros */
.phil-nosotros{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
}
.phil-nosotros__item{
  padding:64px 56px;
  border:1px solid rgba(255,255,255,.06);
  display:flex;
  flex-direction:column;
  gap:24px;
  position:relative;
  overflow:hidden;
  transition:background .3s ease;
}
.phil-nosotros__item:hover{ background:rgba(255,255,255,.02); }
.phil-nosotros__accent{
  width:40px;height:2px;margin-bottom:4px;
}
.phil-nosotros__label{
  font-size:.625rem;font-weight:600;letter-spacing:.2em;
  text-transform:uppercase;color:rgba(217,217,217,.35);
}
.phil-nosotros__title{
  font-size:clamp(2rem,4vw,3.5rem);
  font-weight:500;line-height:1.08;letter-spacing:-.025em;
  color:var(--gray);
}
.phil-nosotros__body{
  font-size:1rem;font-weight:300;line-height:1.82;
  color:rgba(217,217,217,.55);max-width:480px;
}

@media(max-width:1100px){
  .vals-reveal__grid{grid-template-columns:1fr 1fr}
  .phil-nosotros{grid-template-columns:1fr}
}
@media(max-width:600px){
  .vals-reveal__grid{grid-template-columns:1fr}
  .val-reveal__item{min-height:220px}
  .val-reveal__body{max-height:none!important;color:rgba(217,217,217,.55)!important}
}

/* ─── VALUES NEW CARDS ───────────────────── */
.vals-new__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
  width:100%;
}
.val-new__item{
  border-radius:20px;
  background:var(--grad135);
  padding:2px;
  transition:transform .35s cubic-bezier(0.16,1,0.3,1),box-shadow .35s ease;
  cursor:default;
}
.val-new__item:hover{
  transform:translateY(-6px) scale(1.01);
  box-shadow:0 24px 56px rgba(0,0,0,.25);
}
.val-new__inner{
  background:rgba(255,255,255,.96);
  border-radius:18px;
  padding:36px 28px 32px;
  height:100%;
  display:flex;flex-direction:column;gap:12px;
}
.val-new__num{
  font-size:.625rem;font-weight:700;
  letter-spacing:.22em;
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
.val-new__title{
  font-size:1.25rem;font-weight:500;
  letter-spacing:-.01em;color:var(--dark);
  line-height:1.2;
}
.val-new__body{
  font-size:.9375rem;font-weight:300;
  line-height:1.7;color:rgba(15,23,31,.6);
}
@media(max-width:1100px){.vals-new__grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:560px){.vals-new__grid{grid-template-columns:minmax(0,1fr)}}

/* ─── PREMIUM FOLDER CARDS ──────────────── */
.prem-section{padding:0 var(--px) var(--py)}
.prem-cta-bridge{
  padding:48px 0 40px;
  border-bottom:1px solid rgba(255,255,255,.06);
  margin-bottom:48px;
  text-align:center;
}
.prem-cta-bridge__text{
  font-size:clamp(1rem,1.6vw,1.25rem);
  font-weight:300;
  color:rgba(217,217,217,.45);
  line-height:1.7;
  max-width:680px;
  letter-spacing:.01em;
  margin:0 auto;
}
.prem-cta-bridge__text strong{
  font-weight:700;
  color:rgba(217,217,217,.8);
}
.prem-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
}
.prem-card{
  background:#1a1a1a;
  border-radius:20px;
  overflow:hidden;
  display:flex;flex-direction:column;
  font-family:'Poppins',sans-serif;
  transition:transform .35s cubic-bezier(0.16,1,0.3,1),box-shadow .35s ease;
  padding:32px 28px 28px;
  position:relative;
}
.prem-card::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(217,4,4,.12) 0%,rgba(140,3,78,.07) 40%,rgba(3,49,140,.04) 70%,transparent 100%);
  pointer-events:none;
  border-radius:20px;
  z-index:0;
}
.prem-card__body,.prem-card__divider,.prem-card__footer{position:relative;z-index:1}
.prem-card:hover{
  transform:translateY(-6px);
  box-shadow:0 24px 48px rgba(0,0,0,.4);
}
.prem-card__body{
  display:flex;flex-direction:column;gap:10px;
  flex:1;
  text-align:center;
  align-items:center;
}
.prem-card__title{
  font-size:1.25rem;font-weight:600;
  color:#fff;letter-spacing:-.01em;line-height:1.2;
}
.prem-card__desc{
  font-size:.9375rem;font-weight:300;
  color:rgba(217,217,217,.45);line-height:1.65;
}
.prem-card__divider{
  height:1px;
  background:rgba(255,255,255,.08);
  margin:24px 0 20px;
}
.prem-card__footer{display:flex;align-items:center;justify-content:center}
.prem-card__click{
  display:inline-flex;align-items:center;gap:6px;
  text-decoration:none;
  font-size:.8125rem;font-weight:500;
  letter-spacing:.12em;
  padding:11px 28px;
  border:1px solid rgba(255,255,255,.15);
  border-radius:50px;
  transition:border-color .25s,background .25s;
}
.prem-card:hover .prem-card__click{
  border-color:rgba(255,255,255,.35);
  background:rgba(255,255,255,.04);
}
.prem-card__click-white{color:#fff}
.prem-card__click-grad{
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
@media(max-width:900px){.prem-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.prem-grid{grid-template-columns:1fr}}

  100%{transform:translateX(-50%)}
}
.clients-ticker__logo{
  display:flex;align-items:center;justify-content:center;
  padding:0 40px;
  flex-shrink:0;
}
.clients-ticker__logo img{
  height:36px;width:auto;
  max-width:120px;
  object-fit:contain;
  opacity:.75;
  transition:opacity .3s;
}
.clients-ticker__logo img:hover{opacity:1}
.clients-ticker__sep{
  color:rgba(217,217,217,.1);
  font-size:.4rem;
  flex-shrink:0;
}

/* ─── PORTFOLIO SECTION ─────────────────── */
.portf-section{padding:var(--py) var(--px)}
.portf-section .sec__wrap{display:flex;flex-direction:column;gap:96px}
.portf-section .sec__label{margin-bottom:0}

/* Split block */
.portf-block--split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}
.portf-block--reverse .portf-block__info{order:2}
.portf-block--reverse .portf-block__media{order:1}

.portf-block__info{display:flex;flex-direction:column;gap:20px}
.portf-block__title{
  font-size:clamp(2rem,4vw,3.5rem);
  font-weight:500;letter-spacing:-.025em;
  color:var(--gray);line-height:1.08;
}
.portf-block__desc{
  font-size:1rem;font-weight:300;
  line-height:1.8;color:rgba(217,217,217,.5);
  max-width:400px;
}

/* Video card */
.portf-video-card{
  position:relative;border-radius:16px;overflow:hidden;
  aspect-ratio:16/9;background:#111;
}
.portf-video-card__video{
  width:100%;height:100%;object-fit:cover;display:block;
}
.portf-video-card__overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,.3);
  display:flex;align-items:flex-end;padding:20px;
}
.portf-video-card__label{
  font-size:.6875rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.5);
}

/* Logos rows */
.portf-logos{display:flex;flex-direction:column;gap:24px}
.portf-logos__label{
  font-size:.625rem;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;
  color:rgba(217,217,217,.25);
  text-align:center;
  margin-bottom:8px;
}
.portf-logos__row{
  display:flex;align-items:center;justify-content:center;
  gap:0;flex-wrap:nowrap;
  border-top:1px solid rgba(255,255,255,.04);
  border-bottom:1px solid rgba(255,255,255,.04);
  padding:20px 0;
}
.portf-logos__logo{
  display:flex;align-items:center;justify-content:center;
  padding:0 32px;flex-shrink:0;
}
.portf-logos__logo img{
  height:32px;width:auto;max-width:110px;
  object-fit:contain;opacity:.6;
  transition:opacity .3s;
}
.portf-logos__logo img:hover{opacity:1}

/* Photo collage */
.portf-collage{
  position:relative;
  height:400px;
}
.portf-collage__item{
  position:absolute;border-radius:12px;overflow:hidden;
  box-shadow:0 16px 40px rgba(0,0,0,.4);
}
.portf-collage__item img{width:100%;height:100%;object-fit:cover;display:block}
.portf-collage__item--1{width:55%;height:260px;top:0;left:0;z-index:3}
.portf-collage__item--2{width:45%;height:200px;top:20px;right:0;z-index:2}
.portf-collage__item--3{width:40%;height:180px;bottom:0;left:8%;z-index:4}
.portf-collage__item--4{width:48%;height:190px;bottom:10px;right:4%;z-index:1}

/* Branding */
.portf-branding{display:flex;flex-direction:column;gap:40px}
.portf-branding__header{display:flex;flex-direction:column;gap:16px}
.portf-branding__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
.portf-branding__placeholder{
  aspect-ratio:4/3;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.02);
  display:flex;align-items:center;justify-content:center;
}
.portf-branding__placeholder span{
  font-size:.6875rem;font-weight:300;
  letter-spacing:.14em;text-transform:uppercase;
  color:rgba(217,217,217,.2);
}

@media(max-width:900px){
  .portf-block--split{grid-template-columns:1fr;gap:40px}
  .portf-block--reverse .portf-block__info{order:0}
  .portf-block--reverse .portf-block__media{order:0}
  .portf-branding__grid{grid-template-columns:1fr 1fr}
  .portf-collage{height:300px}
}

/* ─── PORTFOLIO CAROUSEL ────────────────── */
.portf-section{padding:var(--py) var(--px)}
.portf-section .sec__wrap{display:flex;flex-direction:column;gap:64px}
.portf-section .sec__label{margin-bottom:0}

.portf-carousel{
  position:relative;
  min-height:420px;
}

/* Slides */
.portf-slide{
  display:none;
  animation:portfSlideIn .45s cubic-bezier(0.16,1,0.3,1) both;
}
.portf-slide.active{display:block}
@keyframes portfSlideIn{
  from{opacity:0;transform:translateX(32px)}
  to{opacity:1;transform:translateX(0)}
}
.portf-slide.slide-prev{
  animation:portfSlideInLeft .45s cubic-bezier(0.16,1,0.3,1) both;
}
@keyframes portfSlideInLeft{
  from{opacity:0;transform:translateX(-32px)}
  to{opacity:1;transform:translateX(0)}
}

/* Split layout */
.portf-block--split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
  padding:0 64px;
}

.portf-block__info{display:flex;flex-direction:column;gap:20px}
.portf-block__title{
  font-size:clamp(2rem,4vw,3.5rem);
  font-weight:500;letter-spacing:-.025em;
  color:var(--gray);line-height:1.08;
}
.portf-block__desc{
  font-size:1rem;font-weight:300;
  line-height:1.8;color:rgba(217,217,217,.5);
  max-width:400px;
}

/* Nav arrows */
.portf-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;border-radius:50%;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.03);
  display:flex;align-items:center;justify-content:center;
  color:rgba(217,217,217,.6);
  cursor:pointer;z-index:10;
  transition:border-color .25s,color .25s,background .25s;
}
.portf-arrow:hover{border-color:rgba(255,255,255,.5);color:#fff;background:rgba(255,255,255,.07)}
.portf-arrow--prev{left:0}
.portf-arrow--next{right:0}

/* Counter */
.portf-counter{
  position:absolute;bottom:-32px;left:50%;transform:translateX(-50%);
  font-size:.75rem;font-weight:300;
  color:rgba(217,217,217,.3);letter-spacing:.12em;
  display:flex;align-items:center;gap:6px;
}
.portf-counter__sep{opacity:.4}

/* Video card */
.portf-video-card{
  position:relative;border-radius:16px;overflow:hidden;
  aspect-ratio:16/9;background:#111;
}
.portf-video-card__video{width:100%;height:100%;object-fit:cover;display:block}
.portf-video-card__overlay{
  position:absolute;inset:0;background:rgba(0,0,0,.25);
  display:flex;align-items:flex-end;padding:20px;
}
.portf-video-card__label{
  font-size:.6875rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.5);
}

/* Photo collage */
.portf-collage{
  position:relative;
  height:480px;
}
.portf-collage__item{
  position:absolute;border-radius:10px;overflow:hidden;
  box-shadow:0 12px 32px rgba(0,0,0,.45);
  transition:transform .3s ease,z-index .3s;
}
.portf-collage__item:hover{transform:scale(1.03);z-index:10!important}
.portf-collage__item img{width:100%;height:100%;object-fit:cover;display:block}
.portf-collage__item--1{width:52%;height:210px;top:0;left:0;z-index:4}
.portf-collage__item--2{width:44%;height:180px;top:0;right:0;z-index:3}
.portf-collage__item--3{width:36%;height:170px;top:50%;left:0;transform:translateY(-50%);z-index:5}
.portf-collage__item--4{width:40%;height:190px;top:180px;right:4%;z-index:2}
.portf-collage__item--5{width:44%;height:160px;bottom:0;left:14%;z-index:6}
.portf-collage__item--6{width:32%;height:150px;bottom:10px;right:0;z-index:1}
.portf-collage__item--7{width:28%;height:130px;top:50%;left:38%;transform:translateY(-50%);z-index:7}

/* Branding grid */
.portf-branding__grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px;
}
.portf-branding__placeholder{
  aspect-ratio:4/3;border-radius:12px;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.02);
  display:flex;align-items:center;justify-content:center;
}
.portf-branding__placeholder span{
  font-size:.6875rem;font-weight:300;
  letter-spacing:.14em;text-transform:uppercase;
  color:rgba(217,217,217,.2);
}

/* Logos ticker */
.portf-logos-ticker{
  display:flex;flex-direction:column;gap:16px;
  margin-top:32px;
}
.portf-logos__label{
  font-size:.625rem;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;
  color:rgba(217,217,217,.25);text-align:center;
}
.portf-logos-track-wrap{
  overflow:hidden;position:relative;
  border-top:1px solid rgba(255,255,255,.04);
  border-bottom:1px solid rgba(255,255,255,.04);
  padding:20px 0;
}
.portf-logos-track-wrap::before,
.portf-logos-track-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:100px;z-index:1;pointer-events:none;
}
.portf-logos-track-wrap::before{left:0;background:linear-gradient(to right,var(--black),transparent)}
.portf-logos-track-wrap::after{right:0;background:linear-gradient(to left,var(--black),transparent)}
.portf-logos-track{
  display:inline-flex;align-items:center;white-space:nowrap;
  animation:portfLogosScroll 60s linear infinite;
  will-change:transform;
}
@keyframes portfLogosScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.portf-logos__logo{
  display:flex;align-items:center;justify-content:center;
  padding:0 48px;flex-shrink:0;
}
.portf-logos__logo img{
  height:44px;width:auto;max-width:140px;
  object-fit:contain;opacity:.65;
  transition:opacity .3s;
}
.portf-logos__logo img:hover{opacity:1}
.portf-logos__sep{
  color:rgba(217,217,217,.1);font-size:.4rem;flex-shrink:0;
}

@media(max-width:900px){
  .portf-block--split{grid-template-columns:1fr;gap:40px;padding:0 40px}
  .portf-collage{height:280px}
  .portf-branding__grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  .portf-block--split{padding:0 16px}
  .portf-arrow--prev{left:-8px}
  .portf-arrow--next{right:-8px}
}

/* ============================================
   BENTO GRID — Branding Portfolio
   ============================================ */
.portf-bento{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-auto-rows:200px;
  gap:8px;
}
.portf-bento__item{
  overflow:hidden;border-radius:8px;
  position:relative;
}
.portf-bento__item img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .6s cubic-bezier(.16,1,.3,1),filter .4s ease;
  filter:brightness(.85);
}
.portf-bento__item:hover img{
  transform:scale(1.05);
  filter:brightness(1);
}
.portf-bento__item::after{
  content:'';position:absolute;inset:0;
  border-radius:8px;opacity:0;
  background:linear-gradient(135deg,rgba(217,4,4,.15),rgba(140,3,78,.15),rgba(3,49,140,.15));
  transition:opacity .4s ease;pointer-events:none;
}
.portf-bento__item:hover::after{opacity:1}
.portf-bento__item--lg{grid-row:span 2}
.portf-bento__item--wide{grid-column:span 2}

@media(max-width:900px){
  .portf-bento{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .portf-bento__item--lg{grid-row:span 2}
  .portf-bento__item--wide{grid-column:span 2}
}
@media(max-width:600px){
  .portf-bento{grid-template-columns:1fr 1fr;grid-auto-rows:150px;gap:6px}
  .portf-bento__item--wide{grid-column:span 2}
  .portf-bento__item--lg{grid-row:span 1}
}

/* ============================================
   COLLAGE 4 PHOTOS — Photography
   ============================================ */
.portf-collage--4{
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:220px 220px;
  gap:8px;
  height:auto;position:relative;
}
.portf-collage--4 .portf-collage__item{
  position:relative;overflow:hidden;border-radius:8px;
  top:auto;left:auto;right:auto;bottom:auto;
  width:100%;height:100%;
  transform:none;
}
.portf-collage--4 .portf-collage__item img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .6s cubic-bezier(.16,1,.3,1);
}
.portf-collage--4 .portf-collage__item:hover img{transform:scale(1.05)}

@media(max-width:600px){
  .portf-collage--4{grid-template-rows:180px 180px}
}

/* ============================================
   CREW CARD FLIP
   ============================================ */
.crew__card{perspective:1000px;cursor:pointer}
.crew__card-inner{
  position:relative;
  transition:transform .7s cubic-bezier(.16,1,.3,1);
  transform-style:preserve-3d;
}
.crew__card.flipped .crew__card-inner{transform:rotateY(180deg)}
.crew__card-front,
.crew__card-back{
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
}
.crew__card-front{position:relative;z-index:2}
.crew__card-back{
  position:absolute;inset:0;
  transform:rotateY(180deg);
  background:#1a1a1a;
  display:flex;align-items:center;justify-content:center;
  padding:32px 24px;
  text-align:center;
  border-radius:0 0 4px 4px;
}
.crew__card-back p{
  font-size:.9rem;font-weight:300;
  color:rgba(217,217,217,.75);
  line-height:1.65;
  max-width:280px;
}
.crew__card-back .crew__flip-hint{
  position:absolute;bottom:16px;right:16px;
  font-size:.625rem;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(217,217,217,.25);
}
/* Flip CTA on front of card */
.crew__flip-cta{
  display:flex;align-items:center;gap:6px;
  font-size:.6875rem;font-weight:400;
  letter-spacing:.05em;
  color:rgba(217,217,217,.35);
  margin-top:4px;
  transition:color .3s ease;
}
.crew__card:hover .crew__flip-cta{color:rgba(217,217,217,.65)}

/* ============================================
   FLOATING BRANDING — animated elements
   ============================================ */
.portf-float{
  position:relative;
  width:100%;height:500px;
  overflow:hidden;
}
.portf-float__item{
  position:absolute;
  left:var(--x);top:var(--y);
  transform:rotate(var(--r)) scale(var(--s));
  animation:floatDrift var(--dur) ease-in-out var(--del) infinite;
  will-change:transform;
}
.portf-float__item img{
  max-width:260px;max-height:240px;
  object-fit:contain;display:block;
  filter:drop-shadow(0 4px 24px rgba(0,0,0,.4));
  transition:filter .3s ease,transform .4s cubic-bezier(.16,1,.3,1);
}
.portf-float__item:hover img{
  filter:drop-shadow(0 8px 32px rgba(217,4,4,.2));
  transform:scale(1.2);
}
@keyframes floatDrift{
  0%,100%{transform:rotate(var(--r)) scale(var(--s)) translate(0,0)}
  25%{transform:rotate(calc(var(--r) + 1.5deg)) scale(var(--s)) translate(6px,-8px)}
  50%{transform:rotate(calc(var(--r) - 1deg)) scale(var(--s)) translate(-4px,6px)}
  75%{transform:rotate(calc(var(--r) + 1deg)) scale(var(--s)) translate(5px,4px)}
}
@media(max-width:900px){.portf-float{height:400px}
  .portf-float__item img{max-width:190px;max-height:170px}}
@media(max-width:600px){.portf-float{height:340px}
  .portf-float__item img{max-width:140px;max-height:130px}}

/* ============================================
   VIDEO HOVER PLAY
   ============================================ */
.portf-video-card{position:relative;cursor:pointer}

/* ============================================
   CTA BANNER
   ============================================ */
.cta-banner{
  background:var(--black);
  padding:120px var(--px);
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta-banner::before{
  content:'';position:absolute;
  top:50%;left:50%;
  width:600px;height:600px;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(217,4,4,.06) 0%,rgba(140,3,78,.04) 40%,transparent 70%);
  pointer-events:none;
}
.cta-banner__inner{
  position:relative;z-index:1;
  max-width:700px;margin:0 auto;
  display:flex;flex-direction:column;align-items:center;gap:24px;
}
.cta-banner__title{
  font-size:clamp(2rem,4.5vw,3.5rem);
  font-weight:500;line-height:1.1;
  letter-spacing:-.03em;
  background:linear-gradient(90deg,#fff 0%,rgba(217,217,217,.7) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.cta-banner__sub{
  font-size:clamp(.9rem,1.2vw,1.125rem);
  font-weight:300;line-height:1.6;
  color:rgba(217,217,217,.5);
}
.cta-banner__btn{
  position:relative;display:inline-flex;align-items:center;gap:10px;
  padding:16px 36px;
  font-size:.875rem;font-weight:500;letter-spacing:.02em;
  color:#fff;text-decoration:none;
  border-radius:50px;overflow:hidden;
  margin-top:8px;
  transition:transform .3s ease;
}
.cta-banner__btn:hover{transform:scale(1.04)}
.cta-banner__btn-bg{
  position:absolute;inset:0;
  background:linear-gradient(90deg,#D90404 0%,#8C034E 50%,#03318C 100%);
  border-radius:50px;
  transition:opacity .3s ease;
}
.cta-banner__btn-text,.cta-banner__btn svg{position:relative;z-index:1}
.cta-banner__morse-strip{
  overflow:hidden;white-space:nowrap;
  opacity:.2;
}

/* ============================================
   VALORES SHOWCASE — immersive layout
   ============================================ */
.vals-showcase{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  border-top:1px solid rgba(255,255,255,.06);
}
.vals-showcase__item{
  display:flex;align-items:flex-start;gap:24px;
  padding:48px 40px;
  border-bottom:1px solid rgba(255,255,255,.06);
  border-right:1px solid rgba(255,255,255,.06);
  position:relative;
  transition:background .5s ease;
}
.vals-showcase__item:nth-child(even){border-right:none}
.vals-showcase__item:hover{background:rgba(255,255,255,.02)}
.vals-showcase__num{
  font-size:clamp(2.5rem,5vw,4rem);
  font-weight:100;line-height:1;
  letter-spacing:-.04em;
  background:linear-gradient(180deg,#D90404 0%,rgba(255,255,255,.85) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  flex-shrink:0;
  min-width:60px;
}
.vals-showcase__content{display:flex;flex-direction:column;gap:12px;padding-top:8px}
.vals-showcase__title{
  font-size:1.25rem;font-weight:500;
  color:#fff;letter-spacing:-.01em;
}
.vals-showcase__line{
  width:40px;height:2px;
  background:linear-gradient(90deg,#D90404,#8C034E,#03318C);
  border-radius:2px;
}
.vals-showcase__body{
  font-size:.875rem;font-weight:300;
  color:rgba(217,217,217,.5);
  line-height:1.65;
  max-width:360px;
}
@media(max-width:800px){
  .vals-showcase{grid-template-columns:1fr}
  .vals-showcase__item{border-right:none}
}
@media(max-width:500px){
  .vals-showcase__item{padding:32px 20px;gap:16px}
  .vals-showcase__num{font-size:2rem;min-width:40px}
}

/* ============================================
   BRANDING GALLERY — horizontal carousel + white cards
   ============================================ */
.bg-section-title{
  font-size:clamp(1.5rem,3vw,2.5rem);
  font-weight:600;color:#fff;
  text-align:center;letter-spacing:-.02em;
  margin-bottom:8px;
}
.bg-section-desc{
  font-size:.85rem;font-weight:300;
  color:rgba(217,217,217,.45);
  text-align:center;margin-bottom:32px;
}
.bg-carousel-wrap{
  overflow-x:auto;overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding:20px 0 32px;
}
.bg-carousel-wrap::-webkit-scrollbar{display:none}
.bg-carousel{
  display:inline-flex;gap:24px;
  padding:0 80px;/* FIX 7: wider padding so cards don't overlap arrow buttons */
  min-width:max-content;
}
.bg-card{
  position:relative;
  width:300px;height:480px;
  flex-shrink:0;
  cursor:pointer;
  transition:transform .5s cubic-bezier(.16,1,.3,1);
}
.bg-card:hover{transform:translateY(-8px)}
/* FIX 2+5: visible glow behind card */
.bg-card__glow{
  position:absolute;inset:-16px;
  border-radius:48px;
  background:radial-gradient(ellipse at center,var(--gc) 0%,transparent 60%);
  opacity:.45;
  filter:blur(24px);
  transition:opacity .4s ease;
  z-index:0;
}
.bg-card:hover .bg-card__glow{opacity:.7}
/* FIX 5: gradient border via pseudo-element */
.bg-card__face{
  position:relative;z-index:1;
  width:100%;height:100%;
  background:#fff;
  border-radius:32px;
  display:flex;flex-direction:column;
  align-items:center;
  padding:0;
  overflow:hidden;
  box-shadow:0 8px 32px rgba(0,0,0,.15);
  transition:box-shadow .4s ease;
}
.bg-card__face::before{
  content:'';
  position:absolute;inset:0;
  border-radius:32px;
  padding:2px;
  background:linear-gradient(135deg,#D90404,#8C034E,#03318C);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  pointer-events:none;
  z-index:2;
}
.bg-card:hover .bg-card__face{
  box-shadow:0 20px 50px rgba(0,0,0,.25);
}
/* FIX 3+4: 70% image, 30% label, centered */
.bg-card__hero-wrap{
  flex:0 0 70%;
  width:100%;
  display:flex;align-items:center;justify-content:center;
  padding:16px 12px 8px;
}
.bg-card__hero{
  width:100%;height:100%;
  object-fit:contain;
  filter:drop-shadow(0 6px 20px rgba(0,0,0,.15));
  transition:transform .5s cubic-bezier(.16,1,.3,1),filter .4s ease;
  display:block;
}
.bg-card:hover .bg-card__hero{
  transform:translateY(-4px) scale(1.06);
  filter:drop-shadow(0 12px 28px rgba(0,0,0,.2));
}
.bg-card__name-wrap{
  flex:0 0 30%;
  width:100%;
  display:flex;align-items:center;justify-content:center;
  padding:8px 16px 20px;
  border-top:1px solid rgba(0,0,0,.06);
}
.bg-card__name{
  font-size:.875rem;font-weight:600;
  color:#1a1a1a;letter-spacing:-.01em;
  text-align:center;
  font-family:'Poppins',sans-serif;
}
/* Detail Overlay — simplified */
.bg-detail{
  position:fixed;inset:0;z-index:9000;
  background:rgba(0,0,0,.88);
  -webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;
  transition:opacity .4s ease,visibility .4s ease;
  padding:40px;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.bg-detail.open{opacity:1;visibility:visible}
.bg-detail.open ~ .portf-arrow,
body.brand-open .portf-arrow,
body.brand-open .portf-counter{
  opacity:0;pointer-events:none;
}
.bg-detail__close{
  position:absolute;top:24px;right:24px;
  width:48px;height:48px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:10;
  transition:background .3s ease;
}
.bg-detail__close:hover{background:rgba(255,255,255,.15)}
.bg-detail__inner{
  display:grid;grid-template-columns:1.2fr 1fr;
  gap:60px;max-width:1100px;width:100%;
  align-items:center;
  margin:auto;
  padding:40px 0;
}
.bg-detail__left{text-align:center}
.bg-detail__main-img{
  max-width:630px;max-height:700px;
  object-fit:contain;
  filter:drop-shadow(0 20px 60px rgba(0,0,0,.5));
  animation:bgDetailImgIn .6s cubic-bezier(.16,1,.3,1) both;
}
.bg-detail__right{display:flex;flex-direction:column;gap:20px}
.bg-detail__title{
  font-size:clamp(1.75rem,3.5vw,2.75rem);
  font-weight:600;color:#fff;letter-spacing:-.02em;
  animation:bgDetailFadeUp .5s .15s cubic-bezier(.16,1,.3,1) both;
}
.bg-detail__desc{
  font-size:1rem;font-weight:300;line-height:1.75;
  color:rgba(217,217,217,.6);max-width:440px;
  animation:bgDetailFadeUp .5s .25s cubic-bezier(.16,1,.3,1) both;
}
@keyframes bgDetailImgIn{
  from{opacity:0;transform:translateY(30px) scale(.9)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes bgDetailFadeUp{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}
@media(max-width:900px){
  .bg-detail__inner{grid-template-columns:1fr;gap:32px;text-align:center}
  .bg-detail__main-img{max-width:400px;max-height:480px}
  .bg-detail__desc{max-width:100%}
}
@media(max-width:600px){
  .bg-card{width:240px;height:380px}
  .bg-card__face{border-radius:24px}
  .bg-detail{padding:20px}
  .bg-detail__main-img{max-width:320px;max-height:400px}
}

/* ============================================
   BRANDING 2-COL GRID (Slide 3)
   ============================================ */
.portf-branding-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.portf-branding-grid__item{
  border-radius:12px;overflow:hidden;
  aspect-ratio:4/5;
  background:#1a1a1a;
}
.portf-branding-grid__item img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .5s cubic-bezier(.16,1,.3,1);
}
.portf-branding-grid__item:hover img{transform:scale(1.04)}

/* ============================================
   ADS GRID (Slide 4)
   ============================================ */
.portf-ads-grid{
  display:flex;gap:48px;
  align-items:center;justify-content:center;
  min-height:280px;
}
.portf-ads-grid__item{
  display:flex;flex-direction:column;align-items:center;gap:16px;
  cursor:default;
}
.portf-ads-grid__item img{
  width:120px;height:120px;object-fit:contain;
  filter:drop-shadow(0 8px 24px rgba(0,0,0,.3));
  transition:transform .4s cubic-bezier(.16,1,.3,1);
}
.portf-ads-grid__item:hover img{transform:scale(1.08)}
.portf-ads-grid__item span{
  font-size:.875rem;font-weight:500;
  color:rgba(217,217,217,.6);
  letter-spacing:.02em;
}

/* ============================================
   WEBSITES GRID (Slide 5)
   ============================================ */
.portf-web-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.portf-web-grid__item{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:20px 16px;
  border-radius:16px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);
  text-decoration:none;
  transition:background .3s,border-color .3s,transform .3s;
  cursor:pointer;
}
.portf-web-grid__item:hover{
  background:rgba(255,255,255,.07);
  border-color:rgba(255,255,255,.15);
  transform:translateY(-3px);
}
.portf-web-grid__item img{
  max-width:140px;max-height:48px;
  object-fit:contain;
  filter:brightness(.8);
  transition:filter .3s;
}
.portf-web-grid__item:hover img{filter:brightness(1)}
.portf-web-grid__item span{
  font-size:.6875rem;font-weight:300;
  color:rgba(217,217,217,.35);
  letter-spacing:.04em;
}

/* ============================================
   TICKER more spacing from above
   ============================================ */
.portf-logos-ticker{margin-top:48px}

/* ============================================
   PREMIUM CARDS — dual buttons
   ============================================ */
.prem-card__footer--dual{
  display:flex;gap:10px;
}
.prem-card__btn{
  flex:1;text-align:center;
  padding:10px 8px;
  border-radius:40px;
  font-size:.75rem;font-weight:500;
  letter-spacing:.04em;
  text-decoration:none;
  transition:opacity .3s,transform .2s;
}
.prem-card__btn:hover{transform:scale(1.03);opacity:.85}
.prem-card__btn--view{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  color:rgba(217,217,217,.8);
}
.prem-card__btn--dl{
  background:linear-gradient(90deg,#D90404,#8C034E,#03318C);
  color:#fff;
  border:none;
}

@media(max-width:600px){
  .portf-branding-grid{grid-template-columns:1fr 1fr;gap:8px}
  .portf-web-grid{grid-template-columns:1fr}
  .portf-ads-grid{gap:32px}
  .portf-ads-grid__item img{width:90px;height:90px}
  .prem-card__footer--dual{flex-direction:column}
}
