:root{
  --bg-0:#0A0A0A;--bg-1:#0D0D0D;--bg-2:#111111;--bg-3:#171717;
  --gold:#FFC700;--gold-l:#FFD600;--gold-p:#FFF59D;--gold-d:#B88E00;
  --gold-pure:#FFC700;
  --gold-a:rgba(255,199,0,.15);--gold-b:rgba(255,199,0,.30);--gold-c:rgba(255,199,0,.08);
  --txt:#F8F9FA;--txt-2:#B0B0B0;--txt-3:#6C757D;
  --border:rgba(255,255,255,.08);--border-2:rgba(255,255,255,.05);
  --glass:rgba(255,255,255,.04);--glass-h:rgba(255,255,255,.08);
  --grid-step:32px;
  --r-sm:0px;--r-md:0px;--r-lg:0px;--r-xl:0px;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg-0);color:var(--txt);font-family:'Inter',sans-serif;overflow-x:hidden;line-height:1.65;position:relative}
body::before{
  content:'';position:fixed;top:0;left:0;width:100%;height:100%;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
  opacity:.02;pointer-events:none;z-index:9999;
}
img{max-width:100%;display:block;object-fit:cover;width:100%;height:100%}

/* ── GRID PATTERN ── */
.grid-bg{
  background-image:linear-gradient(rgba(201,151,42,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(201,151,42,.04) 1px,transparent 1px);
  background-size:60px 60px;
}

/* ── GLOW ORBS ── */
.orb{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none;z-index:0}
.orb-1{width:600px;height:600px;background:rgba(201,151,42,.12);top:-100px;right:-150px}
.orb-2{width:400px;height:400px;background:rgba(201,151,42,.07);bottom:-80px;left:-100px}

/* ── GLASSMORPHISM ── */
.glass{
  background:var(--glass);
  backdrop-filter:blur(24px) saturate(220%);
  -webkit-backdrop-filter:blur(24px) saturate(220%);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
  transition:all .3s var(--ease);
  position:relative;
  z-index:1;
}
.glass::before {
  content: '';
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
  background: linear-gradient(135deg, rgba(255,255,255,0.05), transparent);
  border-radius: inherit;
  pointer-events: none;
  z-index: -1;
}
.glass:hover{
  background:var(--glass-h);
  border-color:var(--gold-b);
  transform:translateY(-4px);
  box-shadow: 0 10px 40px rgba(255, 215, 0, 0.05);
}

/* ── NAVBAR ── */
nav{
  position:fixed;
  top:0; left:0; right:0; z-index:100;
  height:80px; display:flex; align-items:center;
  background:rgba(10,10,10,.6);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border-2);
  transition:all .3s ease;
}
nav.scrolled{
  background:rgba(10,10,10,.95);
}
.nav-inner{width:100%;max-width:1280px;margin:0 auto;padding:0 clamp(16px,5vw,80px);display:flex;align-items:center;justify-content:space-between;gap:40px}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.nav-logo-img{height:64px;width:auto;}
.nav-logo-text{font-family:'Space Grotesk',sans-serif;font-weight:800;font-size:18px;color:#fff;letter-spacing:.02em;text-transform:uppercase}
.nav-links{display:flex;gap:28px;margin-left:auto;list-style:none}
.nav-links a{color:#fff;text-decoration:none;font-size:14px;transition:color .2s;font-weight:500;}
.nav-links a:hover{color:var(--gold)}
.btn-nav{
  margin-left:12px;padding:9px 24px;
  background: var(--gold);
  color:#000;
  font-family:'Inter', sans-serif;
  font-weight:800; font-size:12px; letter-spacing:0.12em;
  border:none; cursor:pointer;
  text-decoration:none; transition:all .3s var(--ease); 
  white-space:nowrap;
  text-transform: uppercase;
}
.btn-nav:hover{
  background: var(--gold-l);
  transform:translateY(-1px);
  box-shadow: 0 4px 12px rgba(255, 199, 0, 0.3);
}
.menu-toggle{
  display:none; flex-direction:column; gap:5px; background:transparent; 
  border:1px solid rgba(255,255,255,0.3); cursor:pointer; padding:10px 8px;
  transition: all .3s var(--ease);
}
.menu-toggle:hover{ border-color:#fff; background:rgba(255,255,255,0.1); }
.menu-toggle span{
  width:22px; height:2px; background:#fff; transition:all 0.3s;
}

@media(max-width:768px){
  .nav-links,.btn-nav{display:none}
  .menu-toggle{display:flex}
}

/* ── MOBILE MENU OVERLAY ── */
.mobile-menu{
  position:fixed; top:0; right:0; width:100%; height:100vh; overflow-y:auto;
  background:rgba(10,10,10,0.85); backdrop-filter:blur(32px); z-index:1000;
  transform:translateX(100%); transition:transform 0.4s var(--ease); pointer-events:none;
}
.mobile-menu.open{ transform:translateX(0); pointer-events:all; }

.mobile-menu-inner{ padding:40px clamp(16px,8vw,60px); display:flex; flex-direction:column; gap:60px; min-height:100%; }
.mobile-menu-top{ display:flex; justify-content:space-between; align-items:center; }
.mobile-menu-top .logo-text{ font-family:'Space Grotesk',sans-serif; font-weight:800; font-size:24px; color:#fff; text-transform:uppercase; }
.close-menu{ background:transparent; border:none; color:#fff; font-size:28px; cursor:pointer; }

.mobile-links{ list-style:none; display:flex; flex-direction:column; gap:32px; }
.mobile-links a{
  text-decoration:none; color:#fff; font-family:'Space Grotesk',sans-serif; font-weight:800;
  font-size:28px; letter-spacing:0.02em; transition:all 0.3s; text-transform:uppercase;
}
.mobile-links a:hover{ color:var(--gold); transform:translateX(8px); }

.btn-mobile-contact{
  display:inline-block; margin-top:20px; padding:16px 28px;
  background:var(--gold); color:#0A0A0A !important; font-size:18px !important;
  font-weight:700; text-align:center;
}
.btn-mobile-contact:hover{ background:var(--gold-l); }

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:10px;font-weight:600;font-size:15px;cursor:pointer;text-decoration:none;transition:all .25s var(--ease);border:none}
.btn-primary{
  background: var(--gold);
  color:#000;
  font-family:'Inter', sans-serif;
  font-weight:800; font-size:14px; letter-spacing:0.15em;
  position: relative;
  overflow: hidden;
  transition: all 0.4s var(--ease);
  text-transform: uppercase;
}
.btn-primary:hover{
  background: var(--gold-l);
  transform:translateY(-2px);
  box-shadow: 0 8px 25px rgba(255, 199, 0, 0.4);
}
.btn-primary:active{ transform: translateY(0) scale(0.98); }
.btn-secondary{background:transparent;color:var(--gold-l);border:1px solid rgba(201,151,42,.5)}
.btn-secondary:hover{background:var(--gold-a);border-color:var(--gold)}
.btn-group{display:flex;flex-wrap:wrap;gap:12px}

/* ── SECTION BASE ── */
section{position:relative;overflow:hidden}
.container{max-width:1280px;margin:0 auto;padding:0 clamp(16px,5vw,80px)}
.section-pad{padding:clamp(60px,8vw,120px) 0}
.section-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:12px;display:block}
.section-headline{font-family:'Space Grotesk',sans-serif;font-weight:800;font-size:clamp(32px,5vw,56px);line-height:1.05;margin-bottom:16px;letter-spacing:-0.03em;text-transform:uppercase}
.section-sub{color:var(--txt-2);font-size:17px;line-height:1.65;max-width:520px}
.divider{height:1px;background:linear-gradient(90deg,transparent,rgba(196,155,55,.3),transparent);max-width:480px;margin:0 auto}

/* ── ASYMMETRIC GRID SYSTEM ── */
.bespoke-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px; }
.col-span-8 { grid-column: span 8; }
.col-span-6 { grid-column: span 6; }
.col-span-4 { grid-column: span 4; }
.col-offset-1 { grid-column-start: 2; }
.col-offset-2 { grid-column-start: 3; }

/* ── HERO SECTION ── */
#hero{
  position:relative;
  overflow:hidden;
  height: 100vh;
  width: 100%;
  display:flex;
  flex-direction:column;
  justify-content:flex-end; /* Empressa a stat-bar para baixo */
  background:#0A0A0A;
}

/* Transição suave em degradê entre Hero e Serviços */
#hero::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 100%;
  height: 25vh; /* Ocupa os últimos 25% da tela para criar um esmaecimento lento */
  background: linear-gradient(to top, #0A0A0A 0%, transparent 100%);
  z-index: 1;
  pointer-events: none;
}

.hero-video-bg {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  z-index: 0;
}

.hero-overlay {
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
  background: linear-gradient(to right,rgba(10,10,10,.98) 0%,rgba(10,10,10,.75) 55%,rgba(10,10,10,.3) 100%),
              linear-gradient(to top,rgba(10,10,10,.95) 0%,transparent 45%);
  z-index: 1;
}

.hero-content{
  position:relative;z-index:2;
  flex:1;display:flex;align-items:center;
  padding:clamp(40px,6vw,80px) 0 clamp(30px,4vw,60px);
}
.hero-inner{max-width:1280px;margin:0 auto;padding:0 clamp(16px,5vw,80px);width:100%}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 16px;border-radius:99px;
  background:var(--gold-a);border:1px solid var(--gold-b);
  color:var(--gold-l);font-size:12px;font-weight:500;letter-spacing:.06em;
  margin-bottom:24px;
}
.hero-eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse-dot 2s ease infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
.hero-h1{
  font-family:'Bebas Neue',Impact,sans-serif;
  font-size:clamp(56px,10vw,120px);
  line-height:.95;letter-spacing:-.01em;
  margin-bottom:24px;
}
.hero-h1 .gold-word{
  background:linear-gradient(135deg,var(--gold),var(--gold-l));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-sub{color:var(--txt-2);font-size:clamp(15px,2vw,18px);line-height:1.7;max-width:440px;margin-bottom:36px}
.hero-badge{display:flex;align-items:center;gap:8px;margin-top:32px}
.hero-badge-dot{width:8px;height:8px;border-radius:50%;background:#22C55E;animation:pulse-dot 1.5s ease infinite}
.hero-badge-text{font-size:13px;color:var(--txt-3)}

/* ── STAT BAR ── */
.stat-bar{
  position:relative;z-index:2;
  width:calc(100% - 48px); max-width:960px; margin:0 auto 24px auto;
  background:rgba(10,10,10,.4);
  backdrop-filter:blur(24px) saturate(220%);
  -webkit-backdrop-filter:blur(24px) saturate(220%);
  border:1px solid var(--border-2);
  padding:28px 0;
}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.stat-item{
  text-align:center;padding:0 24px;
  border-right:1px solid rgba(255,255,255,.07);
}
.stat-item:last-child{border-right:none}
.stat-number{font-family:'JetBrains Mono',monospace;font-size:clamp(28px,4vw,48px);font-weight:500;color:var(--gold-l);line-height:1}
.stat-label{font-size:11px;color:#fff;font-weight:500;text-transform:uppercase;letter-spacing:.08em;margin-top:6px}
@media(max-width:640px){
  .stat-grid{grid-template-columns:repeat(3,1fr)}
  .stat-item{padding:16px 8px;border-right:1px solid rgba(255,255,255,.07);border-bottom:none}
  .stat-item:last-child{border-right:none}
  .stat-number{font-size:22px}
  .stat-label{font-size:9px;letter-spacing:0.02em}
}

/* ── SERVICES ── */
.service-card.alt{
  position:relative; padding:40px; background:var(--glass); border:1px solid var(--border-2);
  display:flex; flex-direction:column; gap:16px; transition:all .45s var(--ease);
  min-height:420px; text-align:left;
}
.service-card.alt:hover{
  border-color:var(--gold); transform:translateY(-8px);
  box-shadow:0 32px 64px rgba(0,0,0,.5), 0 0 40px var(--gold-c);
}
.service-title{ 
  font-family:'Space Grotesk',sans-serif; font-weight:800; font-size:24px; 
  margin-top:8px; line-height:1.2; text-transform:uppercase; letter-spacing:-0.01em; 
}
.service-divider { width: 32px; height: 2px; background: var(--gold); margin: 4px 0 8px; transition: width 0.3s; }
.service-card.alt:hover .service-divider { width: 64px; }
.service-desc{ color:var(--txt-2); font-size:14px; line-height:1.7; margin-bottom:12px;}

.service-top{ display:flex; justify-content:space-between; align-items:flex-start; }
.service-icon.alt{
  width:56px; height:56px; 
  background:transparent;
  border: 1px solid var(--gold-b);
  display:flex; align-items:center; justify-content:center;
  color: var(--gold);
}
.service-icon.alt svg { width: 28px; height: 28px; fill:none; }

.service-icon.alt svg{ width:28px; height:28px; stroke:var(--gold); }
.service-number{
  position:absolute; bottom:20px; right:20px; font-family:'Space Grotesk',sans-serif;
  font-size:72px; font-weight:800; color:rgba(255,199,0,.04); line-height:1; pointer-events:none;
  transition:all .45s var(--ease);
}
.service-card.alt:hover .service-number{ color:var(--gold-a); transform:translateX(-10px); }
.service-badge{ font-family: 'Inter', sans-serif; font-size:9px; text-transform:uppercase; letter-spacing:.15em; color:var(--gold); font-weight:700; opacity:0.8; }
.service-tags{ display:flex; flex-wrap:wrap; gap:6px; margin-top:auto; }
.tag{ font-size:9px; font-weight:800; color:var(--gold); border:1px solid var(--gold-b); padding:4px 8px; text-transform:uppercase; letter-spacing:0.05em; background:rgba(255,199,0,0.03); }

@media(max-width:1024px){
  .bespoke-grid{ grid-template-columns:repeat(2,1fr); }
  .col-span-8,.col-span-4,.col-span-3,.col-offset-1{ grid-column:span 1 !important; grid-column-start:auto !important; }
}
@media(max-width:640px){
  .bespoke-grid{ grid-template-columns:1fr; }
}

/* ── PROCESS ── */
.timeline-container{
  position:relative; max-width:800px; margin:0 auto; padding:40px 0;
}
.timeline-line{
  position:absolute; left:31px; top:0; width:2px; height:100%; background:var(--border-2);
}
.timeline-progress{
  position:absolute; left:0; top:0; width:100%; height:0%; background:var(--gold);
  transition:height 0.1s linear; box-shadow:0 0 15px var(--gold-b);
}
.timeline-item{
  position:relative; padding-left:80px; margin-bottom:80px;
}
.timeline-item:last-child{ margin-bottom:0; }
.timeline-dot{
  position:absolute; left:23px; top:12px; width:18px; height:18px; 
  background:var(--bg-1); border:2px solid var(--border-2); z-index:2;
  transition:all .45s var(--ease);
}
.timeline-dot.active{
  background:var(--gold); border-color:var(--gold);
  box-shadow:0 0 20px var(--gold-c); transform:scale(1.2);
}


.process-step-num{
  font-family:'JetBrains Mono',monospace; font-size:14px; color:var(--gold); font-weight:700; margin-bottom:8px;
}
.process-step-title{ font-family:'Space Grotesk',sans-serif; font-weight:800; font-size:28px; margin-bottom:12px; letter-spacing:-0.01em; }
.process-step-text{ color:var(--txt-2); font-size:16px; line-height:1.7; max-width:600px; }

@media(max-width:768px){
  .timeline-container{ padding-left:10px; }
  .timeline-line{ left:21px; }
  .timeline-dot{ left:14px; }
  .timeline-item{ padding-left:50px; }
}


/* ── BESPOKE PORTFOLIO ── */
.portfolio-filter-bar{
  position:relative; z-index:50; display:flex; gap:12px; margin-bottom:40px;
}
.filter-btn{
  padding:10px 24px; background:transparent; border:1px solid var(--gold-b);
  color:var(--gold); font-family:'Inter', sans-serif; 
  font-weight:800; font-size:12px; letter-spacing:0.12em; 
  cursor:pointer; transition:all 0.4s var(--ease);
  text-transform: uppercase;
}
.filter-btn.active{
  background:var(--gold-a); border-color:var(--gold);
}
.filter-btn:hover{
  border-color:var(--gold); background:var(--gold-c);
}


.portfolio-item-wrap{ 
  position:relative; 
  transition:all .6s var(--ease); 
}

.portfolio-frame{
  position:absolute; top:12px; left:12px; width:100%; height:100%;
  border:1px solid var(--gold-b); z-index:0; transition:all .45s var(--ease);
}
/* Technical coordinate marker */
.portfolio-frame::before {
  content: '+ 0.00';
  position: absolute;
  top: -1px; left: -1px;
  background: var(--gold-b);
  color: #000;
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px;
  padding: 1px 4px;
  opacity: 0.5;
  transition: all .45s var(--ease);
}
.portfolio-item-wrap:hover .portfolio-frame::before {
  opacity: 1;
  background: var(--gold);
}

.portfolio-img-container{
  position:absolute; inset:0; z-index:1; width:100%; height:100%; overflow:hidden;
  background-color: #ffffff; /* O branco perfeito pedido pelo user */
}
/* A Marca De Água da Logo massiva por cima do video */
.portfolio-img-container::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 400px; height: 400px;
  max-width: 85%;
  background-image: url('../assets/images/logo.png');
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 5;
  pointer-events: none;
  opacity: 0.1;
  transition: all 0.3s ease;
}
.portfolio-img-container.is-flashing::before {
  opacity: 0.4;
  filter: brightness(0);
}
.portfolio-img-container::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; width: 100%; height: 60%;
  background: linear-gradient(to top, rgba(0,0,0,0.8), transparent);
  opacity: 0; transition: opacity .45s var(--ease);
  z-index: 2;
}
.portfolio-item-wrap:hover .portfolio-img-container::after { opacity: 1; }

.img-antes, .img-depois {
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .8s var(--ease);
  filter: brightness(1.05) contrast(1.1) saturate(1.05);
}

/* Portfolio video */
.portfolio-img-container video {
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .8s var(--ease), opacity 0.3s ease-out;
  z-index: 1;
}
.portfolio-item-wrap:hover .portfolio-img-container video { transform: scale(1.04); }

.img-depois {
  animation: ba-crossfade var(--ba-time, 6s) infinite alternate var(--ease) var(--ba-delay, 0s);
  z-index: 1;
}

.ba-badge {
  position: absolute;
  top: 15px; right: 15px;
  background: var(--gold);
  color: #000;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 800;
  padding: 4px 12px;
  z-index: 10;
  text-transform: uppercase;
  pointer-events: none;
}

.ba-badge::after {
  content: 'ANTES';
  animation: ba-text-change var(--ba-time, 6s) infinite alternate var(--ease) var(--ba-delay, 0s);
}

@keyframes ba-crossfade {
  0%, 35% { opacity: 0; }
  65%, 100% { opacity: 1; }
}

@keyframes ba-text-change {
  0%, 35% { content: 'ANTES'; }
  65%, 100% { content: 'DEPOIS'; }
}

.portfolio-item-wrap:hover img{ transform:scale(1.08); filter:grayscale(0); }
.portfolio-item-wrap:hover .portfolio-frame{ transform:translate(-8px,-8px); border-color:var(--gold); }

.portfolio-meta{
  display:none;
  position:absolute; bottom:24px; left:24px; z-index:2; pointer-events:none;
}
.portfolio-loc{
  display:block; font-size:11px; text-transform:uppercase; letter-spacing:.15em;
  color:var(--gold); margin-bottom:4px; transform:translateY(10px); opacity:0; transition:all .45s var(--ease);
}
.portfolio-name{
  font-family:'Space Grotesk',sans-serif; font-weight:800; font-size:24px; line-height:1;
  transform:translateY(10px); opacity:0; transition:all .45s var(--ease) .1s;
}
.portfolio-item-wrap:hover .portfolio-loc,
.portfolio-item-wrap:hover .portfolio-name{ display: none; }

/* Grid Mapping & Compact Bento Industrial Composition */
.bespoke-portfolio {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 250px;
  grid-auto-flow: dense;
  gap: 24px;
}

.p-item-1  { grid-column: span 1; grid-row: span 2; --ba-time: 6s;   --ba-delay: 0s;   } /* Bath */
.p-item-2  { grid-column: span 2; grid-row: span 2; --ba-time: 7.5s; --ba-delay: 1s;   } /* Kitchen */
.p-item-3  { grid-column: span 2; grid-row: span 2; --ba-time: 5.2s; --ba-delay: 2.5s; } /* Kitchen */
.p-item-4  { grid-column: span 1; grid-row: span 2; --ba-time: 8s;   --ba-delay: 0.5s; } /* Bath */
.p-item-5  { grid-column: span 1; grid-row: span 2; --ba-time: 6.8s; --ba-delay: 3s;   } /* Bath */
.p-item-6  { grid-column: span 2; grid-row: span 2; --ba-time: 5.7s; --ba-delay: 1.8s; } /* Kitchen */
.p-item-7  { grid-column: span 2; grid-row: span 2; --ba-time: 7.1s; --ba-delay: 0.2s; } /* Kitchen */
.p-item-8  { grid-column: span 1; grid-row: span 2; --ba-time: 6.2s; --ba-delay: 4.5s; } /* Bath */
.p-item-9  { grid-column: span 1; grid-row: span 2; --ba-time: 9.1s; --ba-delay: 2.1s; } /* Bath */
.p-item-10 { grid-column: span 2; grid-row: span 2; --ba-time: 7.3s; --ba-delay: 1.3s; } /* Kitchen */

/* --- DYNAMIC FILTERING LOGIC --- */
/* Filter: Kitchens (Horizontal emphasis) */
.bespoke-portfolio[data-filtered="kitchen"] {
  grid-template-columns: repeat(2, 1fr) !important;
  grid-auto-rows: 600px !important;
}
.bespoke-portfolio[data-filtered="kitchen"] .portfolio-item-wrap[data-category="bathroom"] {
  display: none !important;
}
.bespoke-portfolio[data-filtered="kitchen"] .portfolio-item-wrap[data-category="kitchen"] {
  grid-column: auto !important;
  grid-row: auto !important;
}

/* Filter: Bathrooms (Vertical emphasis) */
.bespoke-portfolio[data-filtered="bathroom"] {
  grid-template-columns: repeat(2, 1fr) !important;
  grid-auto-rows: 580px !important;
}
.bespoke-portfolio[data-filtered="bathroom"] .portfolio-item-wrap[data-category="kitchen"] {
  display: none !important;
}
.bespoke-portfolio[data-filtered="bathroom"] .portfolio-item-wrap[data-category="bathroom"] {
  grid-column: auto !important;
  grid-row: auto !important;
}

@media(max-width:1100px){
  .bespoke-portfolio { 
    grid-template-columns: repeat(2, 1fr); 
    grid-auto-rows: 250px;
    gap: 16px; 
  }
  /* Somente aplica grid-span na vista COMPLETA (não filtrada) */
  .bespoke-portfolio:not([data-filtered="bathroom"]):not([data-filtered="kitchen"]) .p-item-1,
  .bespoke-portfolio:not([data-filtered="bathroom"]):not([data-filtered="kitchen"]) .p-item-4,
  .bespoke-portfolio:not([data-filtered="bathroom"]):not([data-filtered="kitchen"]) .p-item-5,
  .bespoke-portfolio:not([data-filtered="bathroom"]):not([data-filtered="kitchen"]) .p-item-8 { grid-column: span 1; grid-row: span 2; }
  
  .bespoke-portfolio:not([data-filtered="bathroom"]):not([data-filtered="kitchen"]) .p-item-2,
  .bespoke-portfolio:not([data-filtered="bathroom"]):not([data-filtered="kitchen"]) .p-item-3,
  .bespoke-portfolio:not([data-filtered="bathroom"]):not([data-filtered="kitchen"]) .p-item-6,
  .bespoke-portfolio:not([data-filtered="bathroom"]):not([data-filtered="kitchen"]) .p-item-7,
  .bespoke-portfolio:not([data-filtered="bathroom"]):not([data-filtered="kitchen"]) .p-item-9,
  .bespoke-portfolio:not([data-filtered="bathroom"]):not([data-filtered="kitchen"]) .p-item-10 { grid-column: span 2; grid-row: span 2; }
}

@media(max-width:640px){
  .bespoke-portfolio { 
    grid-template-columns: 1fr !important;
    grid-auto-rows: 280px !important;
  }
  .bespoke-portfolio[data-filtered="bathroom"] {
    grid-auto-rows: 600px !important;
  }
  
  /* Mobile Galeria Completa: Banheiros ocupam 2 blocos de 280px (Vertical), Cozinhas ocupam 1 (Horizontal) */
  .bespoke-portfolio:not([data-filtered="bathroom"]):not([data-filtered="kitchen"]) .portfolio-item-wrap[data-category="kitchen"] { 
    grid-column: span 1 !important; 
    grid-row: span 1 !important;
  }
  .bespoke-portfolio:not([data-filtered="bathroom"]):not([data-filtered="kitchen"]) .portfolio-item-wrap[data-category="bathroom"] { 
    grid-column: span 1 !important; 
    grid-row: span 2 !important;
  }
}


/* ── BESPOKE ABOUT GRID ── */
.bespoke-about-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 80px;
  align-items: center;
}
.about-visual-stack {
  position: relative;
  z-index: 1;
}
.visual-bg-box {
  position: absolute;
  top: -30px; left: -30px;
  width: 100%; height: 100%;
  border: 1px solid var(--gold-b);
  z-index: -1;
}
.award-badge {
    position: absolute;
    top: 20px;
    right: -20px;
    background: var(--primary);
    color: var(--dark-bg);
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 20px;
    font-weight: 700;
    box-shadow: 10px 10px 0 rgba(0,0,0,0.5);
    z-index: 5;
    border: 1px solid var(--dark-bg);
    max-width: 220px;
}

.award-icon svg {
    color: var(--dark-bg);
    stroke-width: 3px;
}

.award-text {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
}

.award-title {
    font-size: 0.7rem;
    letter-spacing: 0.05em;
    opacity: 0.8;
    text-transform: uppercase;
}

.award-partner {
    font-family: var(--font-heading);
    font-size: 1rem;
    letter-spacing: -0.02em;
}

/* Ajuste no stamp padrão para não conflitar */
.rigor-stamp {
    position: absolute;
    bottom: -30px;
    left: -35px;
    background: var(--primary);
    color: var(--dark-bg);
    padding: 20px 10px;
    transform: rotate(-90deg);
    font-weight: 800;
    letter-spacing: 0.1em;
    font-size: 0.8rem;
    z-index: 5;
    box-shadow: 5px 5px 0 rgba(0,0,0,0.3);
}

@media (max-width: 768px) {
    .award-badge {
        right: 0;
        top: 10px;
        padding: 8px 15px;
    }
    .award-partner {
        font-size: 0.85rem;
    }
}
.visual-marker {
  position: absolute;
  bottom: 20px; left: -10px;
  background: var(--gold);
  color: #0A0A0A;
  padding: 8px 16px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  font-weight: 700;
  transform: rotate(-90deg);
  transform-origin: left bottom;
}
.about-text-wrap p {
  margin-bottom: 20px;
  color: var(--txt-2);
}
.p-lead {
  font-size: 1.2rem;
  color: #fff !important;
  font-weight: 500;
}
.about-stats-bespoke {
  display: flex;
  gap: 40px;
  margin-top: 40px;
}
.stat-mini {
  display: flex;
  flex-direction: column;
}
.stat-val {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 40px;
  color: var(--gold);
  line-height: 1;
}
.stat-lab {
  font-size: 12px;
  color: var(--txt-3);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

@media(max-width: 991px) {
  .bespoke-about-grid { grid-template-columns: 1fr; gap: 60px; }
  .about-visual-stack { max-width: 500px; margin: 0 auto; }
  .about-content-bespoke { text-align: center; }
  .about-stats-bespoke { justify-content: center; }
  .stat-mini { align-items: center; }
  .section-sub { margin: 0 auto; }
}

/* ── TESTIMONIALS MARQUEE ── */
.marquee-wrapper{
  overflow:hidden; width:100%; padding:20px 0;
  mask-image:linear-gradient(to right,transparent,black 10%,black 90%,transparent);
}
.marquee-track{
  display:flex; width:max-content; gap:32px;
  animation:marquee-scroll 40s linear infinite;
}
.marquee-wrapper:hover .marquee-track{ animation-play-state:paused; }

.marquee-group{
  display:flex; gap:32px;
}
.testi-card-premium{
  width:400px; padding:32px; background:var(--glass); border:1px solid var(--border-2);
  display:flex; flex-direction:column; gap:20px; transition:border-color .3s;
}
.testi-card-premium:hover{ border-color:var(--gold-b); }
.testi-stars{ color:var(--gold); font-size:12px; letter-spacing:3px; }
.testi-quote{ color:var(--txt); font-size:16px; line-height:1.7; font-style:italic; }
.testi-info{ display:flex; flex-direction:column; gap:4px; border-top:1px solid var(--border-2); padding-top:16px; }
.testi-user{ font-weight:600; color:var(--txt); }
.testi-loc{ font-size:12px; color:var(--gold); text-transform:uppercase; letter-spacing:.05em; }

@keyframes marquee-scroll{
  0%{ transform:translateX(0); }
  100%{ transform:translateX(-50%); }
}

@media(max-width:768px){
  .testi-card-premium{ width:300px; padding:24px; }
  .testi-quote{ font-size:14px; }
}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.form-field{margin-bottom:16px}
.form-field label{display:block;font-size:12px;color:#fff;letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px;font-weight:600}
.form-field input,.form-field select,.form-field textarea{
  width:100%;background:rgba(255,255,255,.05);border:1px solid var(--border-2);
  border-radius:0;padding:13px 16px;color:#fff;font-size:15px;
  font-family:'Inter',sans-serif;transition:border-color .2s;outline:none;
}
.form-field input::placeholder,.form-field textarea::placeholder{color:rgba(255,255,255,.3)}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--gold)}
.form-field select option{background:#1C1C1C;color:#fff}
.form-field textarea{resize:vertical;min-height:100px}
.btn-submit{
  width:100%;padding:20px;
  background: var(--gold);
  color:#000;
  font-family:'Inter', sans-serif;
  font-weight:800; font-size:15px; letter-spacing:0.2em;
  border:none;cursor:pointer;
  transition:all .3s var(--ease);
  text-transform: uppercase;
}
.btn-submit:hover{
  background: var(--gold-l);
  box-shadow: 0 8px 30px rgba(255, 199, 0, 0.4);
  transform:translateY(-2px);
}
.contact-info-items{display:flex;flex-direction:column;gap:32px; padding-top:20px;}
.contact-info-item{display:flex;align-items:center;gap:20px}
.contact-info-icon{width:56px;height:56px;border-radius:0;background:transparent;border:1px solid var(--gold-b);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-info-icon svg{width:24px;height:24px;stroke:var(--gold);fill:none;stroke-width:1.8}
.contact-info-label{font-size:11px;color:var(--gold);text-transform:uppercase;letter-spacing:.12em;font-weight:600}
.contact-info-value{font-size:18px;color:#fff;margin-top:4px;font-weight:500}
.contact-info-value a{color:#fff;text-decoration:none}
.contact-info-value a:hover{color:var(--gold-l)}
@media(max-width:768px){
  .contact-grid{grid-template-columns:1fr}
  .contact-info-item { flex-direction: column; text-align: center; gap: 12px; }
  .contact-info-icon { margin: 0 auto; }
}

/* ── FOOTER ── */
footer{background:var(--bg-1);border-top:1px solid var(--border-2);padding:60px 0 32px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-brand .logo-text{font-family:'Space Grotesk',sans-serif;font-weight:800;font-size:20px;letter-spacing:.04em;color:#fff;margin-bottom:12px;text-transform:uppercase}
.footer-desc{font-size:13px;color:var(--txt-3);line-height:1.65;max-width:280px;margin-bottom:20px}
.footer-social{display:flex;gap:12px}
.footer-social a{width:36px;height:36px;border-radius:0;background:transparent;border:1px solid var(--gold-b);display:flex;align-items:center;justify-content:center;transition:all .2s}
.footer-social a:hover{border-color:var(--gold);background:var(--gold-a)}
.footer-social a svg{width:16px;height:16px;stroke:var(--gold);fill:none;stroke-width:1.5;stroke-linecap:round}
.footer-col h4{font-size:11px;color:var(--txt-3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col ul a{font-size:14px;color:var(--txt-2);text-decoration:none;transition:color .2s}
.footer-col ul a:hover{color:var(--gold-l)}
.footer-bottom{border-top:1px solid var(--border-2);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-copy{font-size:12px;color:var(--txt-3)}
.footer-nif{font-size:12px;color:var(--txt-3)}
@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr; text-align: center;}
  .footer-desc { margin: 0 auto 20px; }
  .footer-social { justify-content: center; }
  .footer-col ul { align-items: center; }
  .footer-bottom { justify-content: center; text-align: center; }
}

/* ── WHATSAPP FLOAT ── */
.wa-float{
  position:fixed;bottom:24px;right:24px;z-index:200;
  width:56px;height:56px;border-radius:50%;
  background:#25D366;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.4);
  animation:wa-pulse 2.5s ease infinite;cursor:pointer;
  text-decoration:none;transition:transform .2s;
}
.wa-float:hover{transform:scale(1.1)}
.wa-float svg{width:28px;height:28px;fill:#fff}
@keyframes wa-pulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.4)}50%{box-shadow:0 4px 32px rgba(37,211,102,.65),0 0 0 8px rgba(37,211,102,.08)}}

/* ── REVEAL ANIMATION ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}

/* ── SQUARED & LIQUID OVERRIDES ── */
:root {
  --r-sm: 0px !important;
  --r-md: 0px !important;
  --r-lg: 0px !important;
  --r-xl: 0px !important;
}

.btn, .btn-nav, .btn-submit, button, .form-field input, .form-field select, .form-field textarea, .nav-logo-img, .glass, .service-card, .service-icon, .portfolio-card, .portfolio-img-wrap, .testi-card, .hero-eyebrow, .portfolio-tag {
  border-radius: 0 !important;
}

/* Garantir que MESMO OS ÍCONES (WhatsApp, números, pontinhos) ficam 100% quadrados a pedido do utilizador */
.orb, .step-num, .hero-badge-dot, .wa-float, .wa-float svg, .hero-eyebrow::before, .contact-info-icon {
  border-radius: 0 !important;
}

/* ── SYSTEM RESET & FINAL REFINEMENTS ── */
.btn-nav, .filter-btn, .btn-submit, .btn-primary {
  background: transparent !important;
  border: 1px solid var(--gold-b) !important;
  color: var(--gold) !important;
  text-shadow: none !important;
  box-shadow: none !important;
  transition: all .3s var(--ease) !important;
}
.btn-nav:hover, .filter-btn:hover, .filter-btn.active, .btn-submit:hover, .btn-primary:hover {
  background: var(--gold) !important;
  color: #000 !important;
  border-color: var(--gold) !important;
  box-shadow: 0 8px 24px var(--gold-c) !important;
}

/* --- VIEW TRANSITION API (Organic Grid Movement) --- */
.p-item-1 { view-transition-name: p-item-1; }
.p-item-2 { view-transition-name: p-item-2; }
.p-item-3 { view-transition-name: p-item-3; }
.p-item-4 { view-transition-name: p-item-4; }
.p-item-5 { view-transition-name: p-item-5; }
.p-item-6 { view-transition-name: p-item-6; }
.p-item-7 { view-transition-name: p-item-7; }
.p-item-8 { view-transition-name: p-item-8; }
.p-item-9 { view-transition-name: p-item-9; }
.p-item-10 { view-transition-name: p-item-10; }

::view-transition-group(*) {
  animation-duration: 0.65s;
  animation-timing-function: cubic-bezier(0.25, 1, 0.35, 1);
}

/* --- VIDEO MODAL POPUP (9:16) --- */
.video-modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.95);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s var(--ease);
  backdrop-filter: blur(5px);
}
.video-modal.active {
  opacity: 1;
  pointer-events: all;
}
.close-modal {
  position: absolute;
  top: 30px;
  right: 30px;
  background: transparent;
  border: none;
  color: var(--gold);
  font-size: 32px;
  cursor: pointer;
  z-index: 10050; /* Ensure it is definitively above the video (10010) and watermark (10020) */
  transition: transform 0.3s var(--ease);
}
.close-modal:hover {
  transform: scale(1.1);
  color: #fff;
}
.video-modal-content {
  width: 90vw;
  height: 90vh;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
.modal-vid-backdrop {
  position: absolute;
  max-width: 100%;
  height: 100%;
  aspect-ratio: 9/16;
  background-color: #ffffff;
  border-radius: 4px;
  z-index: 10005;
  box-shadow: 0 0 40px rgba(0,0,0,0.8);
}
.video-modal-content video {
  max-width: 100%;
  max-height: 100%;
  aspect-ratio: 9/16;
  object-fit: contain;
  background: transparent;
  border: 1px solid var(--gold-b);
  border-radius: 4px;
  z-index: 10010;
  transition: opacity 0.3s ease-out;
}
.video-modal-content::after {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 300px; height: 300px;
  max-width: 80%;
  background-image: url('../assets/images/logo.png');
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0.1;
  z-index: 10020;
  pointer-events: none;
  transition: all 0.3s ease;
}
.video-modal-content.is-flashing::after {
  opacity: 0.4;
  filter: brightness(0);
}
