:root {
  --red: #8B1E2F;
  --red-mid: #A8243A;
  --red-bright: #C02B3E;
  --blue: #1A4EC8;
  --blue-mid: #1C56D4;
  --navy: #060E28;
  --gold: #C4A04A;
  --gold-light: #DDB95F;
  --white: #FFFFFF;
  --off-white: #F5F6FA;
  --gray: #7A7A8A;
  --light-gray: #EDEEF5;
  --dark: #07080F;
  --text: #111827;
  --shadow: 0 20px 60px rgba(6,14,40,0.15);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;width:100%;max-width:100%;overflow-x:hidden;}
body{font-family:var(--font-body);color:var(--text);background:var(--white);overflow-x:hidden;width:100%;max-width:100%;}
body *{min-width:0;}
p,li,span,a,h1,h2,h3,h4,h5,h6,.section-sub,.feat-text p,.why-card p,.card-title,.city-name,.office-address,.footer-desc{overflow-wrap:break-word;word-wrap:break-word;}

/* SCROLL PROGRESS */
#progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--red),var(--gold));width:0%;z-index:9999;transition:width .1s;}

/* NAV */
nav{position:fixed;top:0;width:100%;z-index:1000;padding:0 5%;transition:all .4s;background:transparent;}
nav.scrolled{background:rgba(6,14,40,0.97);backdrop-filter:blur(12px);box-shadow:0 2px 30px rgba(0,0,0,0.3);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;}
.nav-logo img,.footer-logo img,.portal-logo img{display:none!important;}
.nav-logo::before,.footer-logo::before{content:'REDEX';font-family:'Montserrat',sans-serif;font-weight:900;font-size:26px;letter-spacing:1px;color:white;}
.footer-logo::after{content:'INMOBILIARIA';font-family:'Montserrat',sans-serif;font-weight:700;font-size:11px;letter-spacing:2px;color:var(--gold);}
.portal-logo::before{content:'REDEX';font-family:'Montserrat',sans-serif;font-weight:900;font-size:28px;letter-spacing:1px;color:white;display:block;}
.logo-icon{width:42px;height:42px;position:relative;}
.logo-r{font-family:var(--font-display);font-weight:900;font-size:28px;color:var(--blue);line-height:1;display:inline-block;}
.logo-d{font-family:var(--font-display);font-weight:900;font-size:28px;color:var(--red);line-height:1;display:inline-block;}
.logo-dot{width:8px;height:8px;background:var(--gold);border-radius:50%;display:inline-block;margin:0 2px;vertical-align:middle;}
.logo-text{font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--white);letter-spacing:2px;text-transform:uppercase;}
.logo-text span{color:var(--gold);}
.nav-links{display:flex;align-items:center;gap:8px;}
.nav-links a{color:rgba(255,255,255,0.85);text-decoration:none;font-family:var(--font-display);font-weight:700;font-size:12px;letter-spacing:0.8px;text-transform:uppercase;padding:8px 14px;border-radius:4px;transition:all .3s;position:relative;}
.nav-links a:hover{color:var(--gold);}
.nav-links a.active{color:var(--gold);}
.nav-cta{display:flex;gap:10px;align-items:center;}
.btn-portal{background:transparent;border:1.5px solid var(--gold);color:var(--gold);padding:9px 18px;border-radius:4px;font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:0.3px;text-transform:uppercase;cursor:pointer;transition:all .3s;text-decoration:none;}
.btn-portal:hover{background:var(--gold);color:var(--navy);}
.btn-nav-main{background:var(--red);color:var(--white);padding:9px 20px;border-radius:4px;font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:0.3px;text-transform:uppercase;cursor:pointer;transition:all .3s;text-decoration:none;border:none;}
.btn-nav-main:hover{background:#6E1624;transform:translateY(-1px);}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:5px;}
.hamburger span{width:24px;height:2px;background:white;transition:all .3s;display:block;}

/* HERO */
.hero{height:100vh;min-height:700px;position:relative;display:flex;align-items:center;overflow:hidden;}
.hero-bg{position:absolute;inset:0;z-index:0;}
.hero-bg img{width:100%;height:100%;object-fit:cover;filter:brightness(0.45);}
.hero-bg-gradient{position:absolute;inset:0;background:linear-gradient(135deg,rgba(6,14,40,0.92) 0%,rgba(26,78,200,0.5) 50%,rgba(139,30,47,0.3) 100%);}
.hero-video-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(0.45);}
.hero-particles{position:absolute;inset:0;overflow:hidden;}
.hero-particles::before{content:'';position:absolute;width:400px;height:400px;border:1px solid rgba(200,168,75,0.15);border-radius:50%;top:-100px;right:10%;animation:rotate 25s linear infinite;}
.hero-particles::after{content:'';position:absolute;width:200px;height:200px;border:1px solid rgba(200,168,75,0.1);border-radius:50%;top:50px;right:15%;animation:rotate 15s linear infinite reverse;}
@keyframes rotate{from{transform:rotate(0deg);}to{transform:rotate(360deg);}}
.hero-content{position:relative;z-index:2;padding:50px 7% 0;max-width:900px;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(200,168,75,0.15);border:1px solid rgba(200,168,75,0.4);padding:6px 16px;border-radius:2px;margin-bottom:28px;}
.hero-badge span{font-family:var(--font-display);font-weight:600;font-size:12px;letter-spacing:3px;color:var(--gold);text-transform:uppercase;}
.hero-badge::before{content:'';width:6px;height:6px;background:var(--gold);border-radius:50%;}
.hero-title{font-family:var(--font-display);font-weight:900;font-size:clamp(40px,7vw,88px);line-height:.95;color:var(--white);text-transform:uppercase;margin-bottom:8px;letter-spacing:-1.5px;}
.hero-title .accent{color:var(--gold);}
.hero-title .red-accent{color:var(--red);}
.hero-subtitle{font-family:var(--font-accent);font-style:italic;font-size:clamp(18px,2.5vw,26px);color:rgba(255,255,255,0.7);margin-bottom:36px;letter-spacing:.5px;}
.hero-search{background:rgba(255,255,255,0.07);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.15);border-radius:6px;padding:6px;display:flex;gap:4px;max-width:680px;margin-bottom:36px;}
.hero-search select,.hero-search input{background:transparent;border:none;color:var(--white);font-family:var(--font-body);font-size:14px;padding:12px 16px;flex:1;outline:none;cursor:pointer;}
.hero-search select option{color:var(--text);background:white;}
.hero-search select::placeholder,.hero-search input::placeholder{color:rgba(255,255,255,0.5);}
.btn-search{background:var(--red);color:white;border:none;padding:12px 24px;border-radius:4px;font-family:var(--font-display);font-weight:700;font-size:13px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:all .3s;white-space:nowrap;}
.btn-search:hover{background:#6E1624;}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:50px;}
.btn-primary{background:var(--red);color:white;padding:14px 28px;border-radius:4px;font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:0.5px;text-transform:uppercase;cursor:pointer;transition:all .3s;text-decoration:none;display:inline-flex;align-items:center;gap:8px;border:none;}
.btn-primary:hover{background:#6E1624;transform:translateY(-2px);box-shadow:0 10px 30px rgba(139,30,47,0.45);}
.btn-outline-gold{background:transparent;color:var(--gold);padding:15px 32px;border-radius:4px;font-family:var(--font-display);font-weight:600;font-size:14px;letter-spacing:0.5px;text-transform:uppercase;cursor:pointer;transition:all .3s;text-decoration:none;display:inline-flex;align-items:center;gap:8px;border:2px solid var(--gold);}
.btn-outline-gold:hover{background:var(--gold);color:var(--navy);}
.btn-whatsapp{background:#25D366;color:white;padding:15px 28px;border-radius:4px;font-family:var(--font-display);font-weight:600;font-size:14px;letter-spacing:0.5px;text-transform:uppercase;cursor:pointer;transition:all .3s;text-decoration:none;display:inline-flex;align-items:center;gap:8px;border:none;}
.btn-whatsapp:hover{background:#1eb857;transform:translateY(-2px);}
.hero-stats{display:flex;gap:40px;flex-wrap:wrap;}
.hero-stat{display:flex;flex-direction:column;align-items:flex-start;}
.hero-stat-num{font-family:var(--font-display);font-weight:900;font-size:34px;color:var(--gold);line-height:1;}
.hero-stat-label{font-size:12px;color:rgba(255,255,255,0.6);text-transform:uppercase;letter-spacing:1.5px;margin-top:4px;}
.hero-scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:2;display:none;flex-direction:column;align-items:center;gap:8px;}
.hero-scroll span{font-size:11px;color:rgba(255,255,255,0.5);letter-spacing:3px;text-transform:uppercase;}
.scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,rgba(200,168,75,0.8),transparent);animation:scrollLine 2s ease-in-out infinite;}
@keyframes scrollLine{0%,100%{transform:scaleY(1);opacity:1;}50%{transform:scaleY(.5);opacity:.5;}}


/* VIDEO FULLWIDTH */
.video-fullwidth{position:relative;background:var(--navy);overflow:hidden;}
.video-wrapper{position:relative;width:100%;padding-bottom:56.25%;}
.video-wrapper iframe{position:absolute;top:0;left:0;width:100%;height:100%;display:block;}
.video-overlay-bar{background:linear-gradient(90deg,var(--navy) 0%,var(--blue) 50%,var(--navy) 100%);padding:14px 7%;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;border-top:2px solid rgba(196,160,74,0.3);}
.video-bar-label{font-family:var(--font-display);font-weight:700;font-size:14px;letter-spacing:2px;color:var(--gold);text-transform:uppercase;}
.video-bar-slogan{font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:3px;color:rgba(255,255,255,0.45);text-transform:uppercase;}


/* GROWING SECTION */
.growing-section{background:var(--off-white);}
.growing-ticker-wrap{background:var(--navy);overflow:hidden;padding:12px 0;border-bottom:2px solid var(--gold);}
.growing-ticker{display:flex;flex-wrap:nowrap;width:max-content;gap:32px;animation:ticker 30s linear infinite;white-space:nowrap;}
.growing-ticker span{font-family:var(--font-display);font-weight:600;font-size:13px;color:rgba(255,255,255,0.7);text-transform:uppercase;letter-spacing:1.5px;flex:0 0 auto;}
.gtick-sep{color:var(--gold) !important;}
.growing-content{padding:80px 7%;}
.growing-header{margin-bottom:56px;max-width:560px;}
.offices-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.office-card{background:white;border-radius:6px;overflow:hidden;box-shadow:0 4px 20px rgba(6,14,40,0.08);transition:all .4s;}
.office-card:hover{transform:translateY(-8px);box-shadow:0 20px 50px rgba(6,14,40,0.16);}
.office-img{height:200px;position:relative;overflow:hidden;}
.office-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s;filter:brightness(.75);}
.office-card:hover .office-img img{transform:scale(1.06);filter:brightness(.65);}
.office-placeholder{width:100%;height:100%;background:#07184A;display:flex;align-items:center;justify-content:center;color:white;font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:1px;text-align:center;padding:18px;filter:brightness(.75);}
.office-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(6,14,40,.7) 0%,transparent 60%);}
.office-badge{position:absolute;top:14px;right:14px;background:var(--red);color:white;font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:1.5px;padding:4px 12px;text-transform:uppercase;}
.office-info{padding:20px;}
.office-city{font-family:var(--font-display);font-weight:900;font-size:18px;color:var(--navy);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;}
.office-name{font-size:12px;color:var(--gold);font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;}
.office-address{font-size:13px;color:var(--gray);line-height:1.6;margin-bottom:8px;}
.office-phone{font-size:13px;color:var(--navy);font-weight:600;margin-bottom:14px;}
.office-map-btn{font-family:var(--font-display);font-weight:700;font-size:12px;color:var(--blue);text-decoration:none;letter-spacing:.5px;text-transform:uppercase;transition:color .3s;}
.office-map-btn:hover{color:var(--red);}
@media(max-width:960px){.offices-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:600px){.offices-grid{grid-template-columns:1fr;}}

/* MAPS SECTION */
.maps-section{background:white;}
.maps-header{padding:60px 7% 0;}
.maps-tabs{display:flex;gap:8px;padding:20px 7%;flex-wrap:wrap;}
.map-tab{background:transparent;border:1.5px solid var(--light-gray);color:var(--gray);padding:10px 20px;border-radius:30px;font-family:var(--font-display);font-weight:600;font-size:12px;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;transition:all .3s;}
.map-tab:hover,.map-tab.active{background:var(--navy);border-color:var(--navy);color:white;}
.map-frame-wrap{width:100%;border-top:3px solid var(--gold);}

/* SECTIONS */
section{padding:90px 7%;}
.section-label{font-family:var(--font-display);font-weight:600;font-size:11px;letter-spacing:3px;color:var(--red);text-transform:uppercase;margin-bottom:12px;display:flex;align-items:center;gap:10px;}
.section-label::before{content:'';width:30px;height:2px;background:var(--red);}
.section-title{font-family:var(--font-display);font-weight:900;font-size:clamp(30px,4.5vw,58px);color:var(--navy);text-transform:uppercase;line-height:.97;margin-bottom:20px;letter-spacing:-1px;}
.section-title .gold{color:var(--gold);}
.section-title .red{color:var(--red);}
.section-sub{font-size:17px;color:var(--gray);max-width:560px;line-height:1.7;}

/* TICKER */
.ticker{background:var(--navy);padding:14px 0;overflow:hidden;border-top:2px solid var(--gold);}
.ticker-inner{display:flex;flex-wrap:nowrap;width:max-content;gap:60px;animation:ticker 25s linear infinite;white-space:nowrap;}
.ticker-item{display:flex;align-items:center;gap:12px;font-family:var(--font-display);font-weight:500;font-size:13px;letter-spacing:2px;color:rgba(255,255,255,0.7);text-transform:uppercase;flex:0 0 auto;}
.ticker-item .dot{width:6px;height:6px;background:var(--gold);border-radius:50%;flex-shrink:0;}
@keyframes ticker{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.about-img-wrap{position:relative;}
.about-img-wrap img{width:100%;height:550px;object-fit:cover;border-radius:2px;}
.about-img-badge{position:absolute;bottom:30px;left:-30px;background:var(--navy);padding:24px 28px;border-left:4px solid var(--gold);}
.about-img-badge .num{font-family:var(--font-display);font-weight:900;font-size:44px;color:var(--gold);line-height:1;}
.about-img-badge .lbl{font-size:13px;color:rgba(255,255,255,0.7);text-transform:uppercase;letter-spacing:2px;}
.about-features{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:36px;}
.about-feat{display:flex;align-items:flex-start;gap:14px;}
.feat-icon{width:44px;height:44px;background:rgba(26,78,200,0.1);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;color:var(--blue);}
.feat-text h4{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--navy);text-transform:uppercase;letter-spacing:0.3px;margin-bottom:4px;}
.feat-text p{font-size:14px;color:var(--gray);line-height:1.5;}

/* PROJECTS */
.projects-section{background:var(--off-white);}
.projects-filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:40px;}
.filter-btn{background:white;border:1.5px solid #E0E0E0;color:var(--gray);padding:9px 20px;border-radius:30px;font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:0.3px;text-transform:uppercase;cursor:pointer;transition:all .3s;}
.filter-btn:hover,.filter-btn.active{background:var(--navy);border-color:var(--navy);color:white;}
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.project-card{background:white;border-radius:4px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,0.06);transition:all .4s;cursor:pointer;position:relative;}
.project-card:hover{transform:translateY(-8px);box-shadow:0 20px 50px rgba(0,0,0,0.15);}
.project-card:hover .card-img img{transform:scale(1.06);}
.card-img{height:240px;overflow:hidden;position:relative;}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s;}
.card-badge{position:absolute;top:16px;left:16px;background:var(--red);color:white;font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:2px;padding:5px 12px;text-transform:uppercase;}
.card-badge.sold{background:var(--gray);}
.card-badge.available{background:#27ae60;}
.card-status{position:absolute;top:16px;right:16px;background:rgba(0,0,0,0.6);color:white;font-size:11px;padding:4px 10px;border-radius:2px;backdrop-filter:blur(4px);}
.card-body{padding:22px;}
.card-location{font-size:12px;color:var(--gold);font-weight:600;text-transform:uppercase;letter-spacing:2px;margin-bottom:8px;display:flex;align-items:center;gap:6px;}
.card-title{font-family:var(--font-display);font-weight:800;font-size:19px;color:var(--navy);text-transform:uppercase;line-height:1.1;margin-bottom:10px;letter-spacing:-0.3px;}
.card-price{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--red);margin-bottom:14px;}
.card-price span{color:var(--gray);font-weight:400;font-size:13px;}
.card-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;}
.card-tag{background:var(--light-gray);color:var(--gray);padding:4px 10px;border-radius:2px;font-size:12px;font-weight:500;}
.card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid var(--light-gray);}
.card-advisor{display:flex;align-items:center;gap:8px;}
.card-advisor img{width:28px;height:28px;border-radius:50%;object-fit:cover;}
.card-advisor span{font-size:12px;color:var(--gray);}
.btn-card{background:var(--navy);color:white;padding:8px 18px;border-radius:3px;font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:0.3px;text-transform:uppercase;text-decoration:none;transition:all .3s;}
.btn-card:hover{background:var(--red);}

/* WHY REDEX */
.why-section{background:var(--navy);position:relative;overflow:hidden;}
.why-section::before{content:'';position:absolute;top:-100px;right:-100px;width:500px;height:500px;border:1px solid rgba(200,168,75,0.08);border-radius:50%;}
.why-section::after{content:'';position:absolute;bottom:-150px;left:-50px;width:350px;height:350px;border:1px solid rgba(200,168,75,0.05);border-radius:50%;}
.why-section .section-title{color:white;}
.why-section .section-sub{color:rgba(255,255,255,0.6);}
.why-section .section-label{color:var(--gold);}
.why-section .section-label::before{background:var(--gold);}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:60px;}
.why-card{padding:40px 30px;position:relative;border:1px solid rgba(255,255,255,0.06);transition:all .4s;}
.why-card:hover{background:rgba(255,255,255,0.04);border-color:rgba(200,168,75,0.3);}
.why-card:hover .why-num{-webkit-text-stroke-color:var(--gold);}
.why-num{font-family:var(--font-display);font-weight:900;font-size:80px;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,0.08);line-height:1;margin-bottom:20px;transition:all .4s;}
.why-icon{font-size:32px;margin-bottom:16px;display:block;}
.why-card h3{font-family:var(--font-display);font-weight:800;font-size:18px;color:white;text-transform:uppercase;letter-spacing:-0.3px;margin-bottom:12px;}
.why-card p{font-size:14px;color:rgba(255,255,255,0.55);line-height:1.7;}

/* CITIES */
.cities-section{padding:90px 0;}
.cities-header{padding:0 7%;margin-bottom:40px;}
.cities-scroll{display:flex;gap:16px;overflow-x:auto;padding:0 7% 20px;scrollbar-width:none;}
.cities-scroll::-webkit-scrollbar{display:none;}
.city-card{min-width:220px;height:320px;border-radius:4px;overflow:hidden;position:relative;cursor:pointer;flex-shrink:0;}
.city-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s;filter:brightness(0.6);}
.city-card:hover img{transform:scale(1.08);filter:brightness(0.5);}
.city-placeholder{width:100%;height:100%;background:#07184A;display:flex;align-items:center;justify-content:center;color:white;font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:1px;text-align:center;padding:18px;}
.city-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(6,14,40,0.92),transparent 50%);}
.city-info{position:absolute;bottom:0;left:0;right:0;padding:20px;}
.city-name{font-family:var(--font-display);font-weight:800;font-size:22px;color:white;text-transform:uppercase;letter-spacing:1px;}
.city-count{font-size:12px;color:var(--gold);font-weight:600;letter-spacing:2px;}

/* METRICS */
.metrics-section{background:linear-gradient(135deg,var(--navy) 0%,#0A1A52 100%);padding:80px 7%;}
.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,0.05);}
.metric-card{background:var(--navy);padding:50px 30px;text-align:center;transition:all .4s;}
.metric-card:hover{background:rgba(255,255,255,0.04);}
.metric-num{font-family:var(--font-display);font-weight:900;font-size:clamp(52px,6vw,80px);color:var(--gold);line-height:1;display:block;}
.metric-suffix{font-size:0.5em;color:var(--red);}
.metric-label{font-family:var(--font-display);font-weight:600;font-size:14px;color:rgba(255,255,255,0.5);text-transform:uppercase;letter-spacing:3px;margin-top:10px;}

/* ADVISORS */
.advisors-section{background:var(--off-white);}
.advisors-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:50px;}
.advisor-card{background:white;border-radius:4px;overflow:hidden;text-align:center;padding:30px 20px;box-shadow:0 2px 12px rgba(0,0,0,0.06);transition:all .4s;cursor:pointer;}
.advisor-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.advisor-avatar{width:90px;height:90px;border-radius:50%;object-fit:cover;margin:0 auto 16px;border:3px solid var(--light-gray);transition:border-color .3s;}
.advisor-card:hover .advisor-avatar{border-color:var(--gold);}
.advisor-name{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--navy);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;}
.advisor-role{font-size:13px;color:var(--gold);font-weight:600;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:12px;}
.advisor-zone{font-size:13px;color:var(--gray);margin-bottom:16px;}
.advisor-stats{display:flex;justify-content:center;gap:20px;padding-top:16px;border-top:1px solid var(--light-gray);}
.adv-stat{display:flex;flex-direction:column;align-items:center;}
.adv-stat-num{font-family:var(--font-display);font-weight:800;font-size:20px;color:var(--navy);}
.adv-stat-lbl{font-size:11px;color:var(--gray);text-transform:uppercase;letter-spacing:1px;}
.advisors-cta{text-align:center;margin-top:50px;padding:50px;background:white;border-radius:4px;box-shadow:0 4px 20px rgba(0,0,0,0.06);}
.advisors-cta h3{font-family:var(--font-display);font-weight:800;font-size:36px;color:var(--navy);text-transform:uppercase;margin-bottom:12px;}
.advisors-cta p{color:var(--gray);margin-bottom:24px;font-size:16px;}

/* TESTIMONIALS */
.testimonials-section{overflow:hidden;}
.testimonials-track{display:flex;gap:24px;margin-top:50px;overflow-x:auto;padding-bottom:20px;scrollbar-width:none;}
.testimonials-track::-webkit-scrollbar{display:none;}
.testimonial-card{min-width:380px;background:var(--off-white);padding:36px;border-radius:4px;border-left:4px solid var(--gold);flex-shrink:0;transition:all .3s;}
.testimonial-card:hover{background:white;box-shadow:var(--shadow);}
.testimonial-stars{color:var(--gold);font-size:16px;margin-bottom:16px;letter-spacing:3px;}
.testimonial-text{font-family:var(--font-accent);font-style:italic;font-size:17px;color:var(--text);line-height:1.7;margin-bottom:24px;}
.testimonial-author{display:flex;align-items:center;gap:12px;}
.author-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;}
.author-name{font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--navy);text-transform:uppercase;letter-spacing:1px;}
.author-project{font-size:13px;color:var(--gold);}

/* FORCE */
.force-section{background:var(--navy);color:white;position:relative;overflow:hidden;}
.force-section::before{content:'REDEX';position:absolute;right:-5%;top:50%;transform:translateY(-50%);font-family:var(--font-display);font-weight:900;font-size:250px;color:rgba(255,255,255,0.02);text-transform:uppercase;pointer-events:none;white-space:nowrap;}
.force-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.force-content .section-title{color:white;}
.force-content .section-sub{color:rgba(255,255,255,0.6);}
.force-content .section-label{color:var(--gold);}
.force-content .section-label::before{background:var(--gold);}
.force-numbers{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:40px;}
.force-num-card{padding:28px;border:1px solid rgba(255,255,255,0.08);border-radius:4px;transition:all .3s;}
.force-num-card:hover{border-color:rgba(200,168,75,0.4);background:rgba(255,255,255,0.02);}
.force-num-card .num{font-family:var(--font-display);font-weight:900;font-size:46px;color:var(--gold);line-height:1;}
.force-num-card .lbl{font-size:13px;color:rgba(255,255,255,0.5);text-transform:uppercase;letter-spacing:2px;margin-top:6px;}
.force-visual{position:relative;}
.force-visual img{width:100%;height:500px;object-fit:cover;border-radius:4px;filter:brightness(0.8);}
.force-visual::before{content:'';position:absolute;top:-20px;left:-20px;right:20px;bottom:20px;border:2px solid rgba(200,168,75,0.3);border-radius:4px;z-index:-1;}

/* CTA FINAL */
.cta-section{background:linear-gradient(135deg,#8B1E2F 0%,#4A0E1A 100%);padding:100px 7%;text-align:center;position:relative;overflow:hidden;}
.cta-section::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse at center,rgba(255,255,255,0.05) 0%,transparent 60%);}
.cta-section h2{font-family:var(--font-display);font-weight:900;font-size:clamp(42px,7vw,80px);color:white;text-transform:uppercase;line-height:.95;margin-bottom:20px;letter-spacing:-1px;}
.cta-section p{font-size:18px;color:rgba(255,255,255,0.8);margin-bottom:40px;}
.cta-buttons{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;}
.btn-cta-white{background:white;color:var(--red);padding:16px 36px;border-radius:4px;font-family:var(--font-display);font-weight:800;font-size:16px;letter-spacing:2px;text-transform:uppercase;text-decoration:none;transition:all .3s;display:inline-flex;align-items:center;gap:8px;}
.btn-cta-white:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,0,0,0.3);}
.btn-cta-outline{background:transparent;color:white;padding:16px 36px;border-radius:4px;border:2px solid rgba(255,255,255,0.4);font-family:var(--font-display);font-weight:800;font-size:16px;letter-spacing:2px;text-transform:uppercase;text-decoration:none;transition:all .3s;display:inline-flex;align-items:center;gap:8px;}
.btn-cta-outline:hover{border-color:white;background:rgba(255,255,255,0.1);}
.contact-form{max-width:860px;margin:42px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:14px;text-align:left;}
.contact-form input,.contact-form select,.contact-form textarea{width:100%;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.22);color:white;border-radius:4px;padding:14px 16px;font-family:var(--font-body);font-size:15px;outline:none;}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:rgba(255,255,255,0.55);}
.contact-form select option{color:var(--text);background:white;}
.contact-form textarea{grid-column:1/-1;min-height:100px;resize:vertical;}
.contact-form button{grid-column:1/-1;justify-content:center;}
.form-status{grid-column:1/-1;min-height:20px;font-size:14px;color:white;text-align:center;}
.form-status.ok{color:#7ee2a8;}
.form-status.error{color:#ffb3b3;}

/* FOOTER */
footer{background:var(--dark);padding:70px 7% 30px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:50px;margin-bottom:50px;}
.footer-brand{}
.footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:20px;text-decoration:none;}
.footer-logo-text{font-family:var(--font-display);font-weight:700;font-size:20px;color:white;letter-spacing:2px;text-transform:uppercase;}
.footer-logo-text span{color:var(--gold);}
.footer-desc{font-size:14px;color:rgba(255,255,255,0.45);line-height:1.7;margin-bottom:24px;}
.footer-socials{display:flex;gap:12px;}
.footer-social{width:38px;height:38px;border:1px solid rgba(255,255,255,0.15);border-radius:4px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.6);font-size:14px;transition:all .3s;text-decoration:none;}
.footer-social:hover{border-color:var(--gold);color:var(--gold);}
.footer-col h4{font-family:var(--font-display);font-weight:700;font-size:14px;color:white;text-transform:uppercase;letter-spacing:2px;margin-bottom:20px;}
.footer-col ul{list-style:none;}
.footer-col ul li{margin-bottom:10px;}
.footer-col ul li a{color:rgba(255,255,255,0.45);text-decoration:none;font-size:14px;transition:color .3s;}
.footer-col ul li a:hover{color:var(--gold);}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.08);padding-top:28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;}
.footer-copy{font-size:13px;color:rgba(255,255,255,0.3);}
.footer-legal{display:flex;gap:20px;}
.footer-legal a{font-size:13px;color:rgba(255,255,255,0.3);text-decoration:none;transition:color .3s;}
.footer-legal a:hover{color:var(--gold);}

/* FLOATING WA */
.float-wa{position:fixed;bottom:30px;right:30px;z-index:998;width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 30px rgba(37,211,102,0.4);animation:float-pulse 3s ease-in-out infinite;text-decoration:none;}
.float-wa:hover{transform:scale(1.1);}
.float-wa svg{fill:white;width:26px;height:26px;}
@keyframes float-pulse{0%,100%{box-shadow:0 6px 30px rgba(37,211,102,0.4);}50%{box-shadow:0 6px 50px rgba(37,211,102,0.6);}}

/* ===================== PORTAL ===================== */
#portal-overlay{display:none;position:fixed;inset:0;z-index:2000;background:rgba(6,14,40,0.98);backdrop-filter:blur(20px);}
#portal-overlay.active{display:flex;align-items:stretch;}
.portal-sidebar{width:280px;background:rgba(0,0,0,0.4);border-right:1px solid rgba(255,255,255,0.06);display:flex;flex-direction:column;flex-shrink:0;}
.portal-logo{padding:28px 24px;border-bottom:1px solid rgba(255,255,255,0.06);}
.portal-logo span{display:none!important;}
.portal-nav{position:static;top:auto;width:auto;z-index:auto;padding:20px 0;flex:1;overflow-y:auto;background:none;transition:none;}
.portal-nav-item{display:flex;align-items:center;gap:12px;padding:13px 24px;color:rgba(255,255,255,0.55);font-family:var(--font-display);font-weight:500;font-size:13px;letter-spacing:0.3px;text-transform:uppercase;cursor:pointer;transition:all .3s;border-left:3px solid transparent;text-decoration:none;}
.portal-nav-item:hover,.portal-nav-item.active{color:white;background:rgba(255,255,255,0.05);border-left-color:var(--gold);}
.portal-nav-item .pni{font-size:18px;width:22px;text-align:center;}
.portal-section-label{padding:16px 24px 6px;font-size:11px;color:rgba(255,255,255,0.2);text-transform:uppercase;letter-spacing:2px;}
.portal-footer{padding:18px 24px;border-top:1px solid rgba(255,255,255,0.06);background:rgba(0,0,0,0.16);}
.portal-user{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.portal-user-avatar{width:40px;height:40px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--navy);}
.portal-user-name{font-family:var(--font-display);font-weight:700;font-size:15px;color:white;text-transform:uppercase;}
.portal-user-role{font-size:12px;color:var(--gold);text-transform:uppercase;letter-spacing:1px;}
.portal-close{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,0.4);font-size:13px;cursor:pointer;transition:color .3s;background:none;border:none;font-family:var(--font-body);padding:0;}
.portal-close:hover{color:var(--red);}
.portal-main{flex:1;overflow-y:auto;padding:0;}
.portal-login{display:none;min-height:100%;width:100%;align-items:center;justify-content:center;padding:30px;position:relative;overflow:hidden;background:
radial-gradient(circle at 18% 18%, rgba(196,160,74,0.16), transparent 28%),
radial-gradient(circle at 82% 12%, rgba(26,78,200,0.18), transparent 30%),
linear-gradient(135deg, #060E28 0%, #0b1435 48%, #050912 100%);}
.portal-login::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.035) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,0.035) 1px, transparent 1px);background-size:42px 42px;mask-image:linear-gradient(to bottom, rgba(0,0,0,0.45), transparent 80%);pointer-events:none;}
#portal-overlay.login-required{align-items:center;justify-content:center;}
#portal-overlay.login-required .portal-login{display:flex;}
#portal-overlay.login-required .portal-sidebar,#portal-overlay.login-required .portal-main{display:none;}
.portal-login-shell{position:relative;z-index:1;width:min(460px,100%);}
.portal-login-card{width:100%;background:linear-gradient(180deg, rgba(255,255,255,0.09), rgba(255,255,255,0.045));border:1px solid rgba(255,255,255,0.16);border-radius:10px;padding:36px;box-shadow:0 32px 90px rgba(0,0,0,0.42);}
.portal-login-brand{text-align:center;margin-bottom:22px;}
.portal-login-logo{text-align:center;font-family:var(--font-display);font-weight:900;font-size:34px;color:white;letter-spacing:1px;margin-bottom:6px;}
.portal-login-brand span{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--gold);font-family:var(--font-display);font-weight:700;}
.portal-login-card h2{font-family:var(--font-display);font-weight:900;font-size:25px;color:white;text-transform:uppercase;margin-bottom:8px;}
.portal-login-card p{font-size:14px;color:rgba(255,255,255,0.62);line-height:1.55;margin-bottom:22px;}
.portal-login-field{display:block;margin-bottom:14px;}
.portal-login-field span{display:block;margin-bottom:7px;font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.68);}
.portal-login-field input{width:100%;background:rgba(0,0,0,0.22);border:1px solid rgba(255,255,255,0.18);border-radius:5px;padding:14px 15px;color:white;font-family:var(--font-body);font-size:15px;outline:none;transition:border .2s, box-shadow .2s;}
.portal-login-field input:focus{border-color:rgba(196,160,74,0.85);box-shadow:0 0 0 3px rgba(196,160,74,0.12);}
.portal-login-password{position:relative;}
.portal-login-card button{width:100%;justify-content:center;margin-top:4px;}
.portal-login-error{min-height:20px;color:#ffb3b3;font-size:13px;margin-top:12px;text-align:center;}
.portal-login-card input[name="password"]{padding-right:56px;}
.password-toggle{position:absolute;right:9px;bottom:8px;width:40px!important;height:40px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.14);color:var(--gold);padding:0;border-radius:5px;margin:0!important;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.password-toggle.active{background:rgba(196,160,74,0.14);border-color:var(--gold);color:white;}
.portal-login-home{display:block;text-align:center;margin-top:14px;color:rgba(255,255,255,0.62);font-family:var(--font-display);font-weight:700;font-size:12px;letter-spacing:1px;text-transform:uppercase;text-decoration:none;border:1px solid rgba(255,255,255,0.12);border-radius:5px;padding:12px 16px;background:rgba(255,255,255,0.04);transition:all .2s;}
.portal-login-home:hover{color:white;border-color:rgba(196,160,74,0.5);background:rgba(196,160,74,0.08);}
.login-spinner{display:none;width:14px;height:14px;border:2px solid rgba(255,255,255,0.35);border-top-color:white;border-radius:50%;margin-right:8px;vertical-align:-2px;animation:spin .8s linear infinite;}
.portal-login-card.is-loading .login-spinner{display:inline-block;}
@keyframes spin{to{transform:rotate(360deg);}}
@media (max-width: 560px){.portal-login{padding:18px;align-items:flex-start;padding-top:42px;}.portal-login-card{padding:26px 20px;}.portal-login-logo{font-size:30px;}.portal-login-card h2{font-size:22px;}}
.portal-header{padding:24px 36px;border-bottom:1px solid rgba(255,255,255,0.06);display:flex;justify-content:space-between;align-items:center;}
.portal-header h1{font-family:var(--font-display);font-weight:800;font-size:24px;color:white;text-transform:uppercase;letter-spacing:1px;}
.portal-header-actions{display:flex;gap:10px;}
.btn-portal-action{padding:9px 18px;border-radius:3px;font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:all .3s;border:none;}
.btn-portal-action.primary{background:var(--red);color:white;}
.btn-portal-action.primary:hover{background:#6E1624;}
.btn-portal-action.secondary{background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.7);}
.btn-portal-action.secondary:hover{background:rgba(255,255,255,0.12);}
.portal-content{padding:32px 36px;}
.portal-panel{display:none;}
.portal-panel.active{display:block;}
.admin-overlay{display:none;position:fixed;inset:0;z-index:2100;background:rgba(6,14,40,0.98);backdrop-filter:blur(20px);--red:#CC1E2F;--blue:#1A3EC8;--navy:#060E28;--gold:#C4A04A;}
.admin-overlay.active{display:flex;align-items:stretch;}
.admin-admin-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px;}
.admin-mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.admin-chart-wrap{height:260px;}
.admin-modal{display:none;position:fixed;inset:0;z-index:4600;background:rgba(0,0,0,.72);align-items:center;justify-content:center;padding:24px;}
.admin-modal.active{display:flex;}
.admin-modal-card{width:min(560px,100%);max-height:90vh;overflow-y:auto;background:#101933;border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:22px;}
.admin-filter-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px;}
.admin-filter-row select,.admin-filter-row input,.admin-modal-card input,.admin-modal-card select{background:rgba(0,0,0,.22);border:1px solid rgba(255,255,255,.12);color:white;border-radius:4px;padding:11px 12px;}
.admin-progress{height:10px;background:rgba(255,255,255,.09);border-radius:99px;overflow:hidden;}
.admin-progress span{display:block;height:100%;background:linear-gradient(90deg,var(--blue),var(--gold));}
.admin-podium{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;align-items:end;}
.admin-podium-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:16px;text-align:center;}
.admin-podium-card:nth-child(1){min-height:160px;border-color:rgba(196,160,74,.5);}
.admin-podium-card:nth-child(2){min-height:130px;}
.admin-podium-card:nth-child(3){min-height:112px;}
.admin-status-pill{display:inline-flex;padding:5px 10px;border-radius:999px;font-size:11px;text-transform:uppercase;font-weight:800;letter-spacing:.8px;background:rgba(255,255,255,.1);color:white;}
.admin-status-pill.pagado{background:#1A6B44;}
.admin-status-pill.en-proceso{background:var(--gold);color:var(--navy);}
.admin-status-pill.pendiente{background:var(--red);}
.table-wrap{width:100%;overflow-x:auto;}

/* PORTAL DASHBOARD */
.portal-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;}
.kpi-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.07);border-radius:4px;padding:24px;transition:all .3s;}
.kpi-card:hover{background:rgba(255,255,255,0.07);border-color:rgba(200,168,75,0.3);}
.kpi-num{font-family:var(--font-display);font-weight:900;font-size:40px;color:var(--gold);line-height:1;margin-bottom:4px;}
.kpi-label{font-size:12px;color:rgba(255,255,255,0.4);text-transform:uppercase;letter-spacing:2px;}
.kpi-trend{font-size:12px;margin-top:8px;font-weight:600;}
.kpi-trend.up{color:#27ae60;}
.kpi-trend.down{color:var(--red);}
.portal-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;}
.portal-card{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.07);border-radius:4px;padding:24px;}
.portal-card h3{font-family:var(--font-display);font-weight:700;font-size:16px;color:white;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;}
.portal-card h3 .see-all{font-size:12px;color:var(--gold);cursor:pointer;font-weight:600;}
.client-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid rgba(255,255,255,0.05);}
.client-row:last-child{border-bottom:none;}
.client-info{display:flex;align-items:center;gap:10px;}
.client-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#1A4EC8,#060E28);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:13px;color:white;flex-shrink:0;}
.client-name{font-family:var(--font-display);font-weight:600;font-size:14px;color:white;text-transform:uppercase;}
.client-project{font-size:12px;color:rgba(255,255,255,0.4);}
.status-badge{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;}
.status-badge.hot{background:rgba(139,30,47,0.2);color:#ff6b6b;}
.status-badge.warm{background:rgba(200,168,75,0.2);color:var(--gold);}
.status-badge.cold{background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.4);}
.status-badge.closed{background:rgba(39,174,96,0.2);color:#27ae60;}
.activity-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.04);}
.activity-item:last-child{border-bottom:none;}
.activity-dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0;}
.activity-dot.red{background:var(--red);}
.activity-dot.gold{background:var(--gold);}
.activity-dot.blue{background:var(--blue);}
.activity-dot.green{background:#27ae60;}
.activity-text{font-size:13px;color:rgba(255,255,255,0.6);line-height:1.5;}
.activity-time{font-size:11px;color:rgba(255,255,255,0.25);margin-top:3px;}

/* PORTAL LINK SHARE */
.link-share-box{background:rgba(200,168,75,0.08);border:2px dashed rgba(200,168,75,0.3);border-radius:6px;padding:30px;margin-bottom:24px;text-align:center;}
.link-share-box h3{font-family:var(--font-display);font-weight:700;font-size:20px;color:white;text-transform:uppercase;margin-bottom:8px;}
.link-share-box p{font-size:14px;color:rgba(255,255,255,0.5);margin-bottom:20px;}
.link-display{background:rgba(0,0,0,0.3);border:1px solid rgba(255,255,255,0.1);border-radius:4px;padding:14px 18px;display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;}
.link-url{font-family:var(--font-display);font-size:15px;color:var(--gold);flex:1;word-break:break-all;}
.btn-copy{background:var(--gold);color:var(--navy);padding:8px 16px;border-radius:3px;font-family:var(--font-display);font-weight:700;font-size:13px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;border:none;transition:all .3s;white-space:nowrap;}
.btn-copy:hover{background:var(--gold-light);}
.link-share-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px;}
.share-btn{padding:12px;border-radius:4px;border:none;cursor:pointer;font-family:var(--font-display);font-weight:700;font-size:13px;letter-spacing:1px;text-transform:uppercase;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:8px;}
.share-btn.wa{background:#25D366;color:white;}
.share-btn.wa:hover{background:#1eb857;}
.share-btn.fb{background:#1877F2;color:white;}
.share-btn.fb:hover{background:#1468d6;}
.share-btn.ig{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:white;}

/* PORTAL TABLE */
.portal-table{width:100%;border-collapse:collapse;}
.portal-table th{text-align:left;padding:12px 16px;font-family:var(--font-display);font-weight:600;font-size:12px;color:rgba(255,255,255,0.3);text-transform:uppercase;letter-spacing:2px;border-bottom:1px solid rgba(255,255,255,0.06);}
.portal-table td{padding:14px 16px;font-size:14px;color:rgba(255,255,255,0.7);border-bottom:1px solid rgba(255,255,255,0.04);}
.portal-table tr:hover td{background:rgba(255,255,255,0.02);}
.portal-table td .bold{color:white;font-weight:600;}
.portal-form-modal{display:none;position:fixed;inset:0;z-index:3500;background:rgba(0,0,0,0.72);align-items:center;justify-content:center;padding:24px;}
.portal-form-modal.active,.portal-form-modal:target{display:flex;}
.portal-form-card{width:min(560px,100%);background:#101933;border:1px solid rgba(255,255,255,0.12);border-radius:6px;padding:24px;box-shadow:0 30px 90px rgba(0,0,0,0.4);}
.portal-form-card h3{font-family:var(--font-display);font-weight:800;font-size:20px;color:white;text-transform:uppercase;margin-bottom:16px;}
.portal-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.portal-form-grid input,.portal-form-grid select,.portal-form-grid textarea{width:100%;background:rgba(0,0,0,0.28);border:1px solid rgba(255,255,255,0.12);border-radius:4px;color:white;padding:12px 14px;font-family:var(--font-body);font-size:14px;outline:none;}
.portal-form-grid select option{color:var(--text);background:white;}
.portal-form-grid textarea{grid-column:1/-1;min-height:90px;resize:vertical;}
.portal-form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px;}
.portal-form-status{min-height:18px;color:#ffb3b3;font-size:13px;margin-top:10px;text-align:right;}
.client-inline-form{display:grid;grid-template-columns:1.1fr 1fr 1fr 1.2fr 1fr auto;gap:10px;margin-bottom:18px;background:rgba(255,255,255,0.035);border:1px solid rgba(255,255,255,0.07);border-radius:4px;padding:16px;}
.client-inline-form input,.client-inline-form select{width:100%;background:rgba(0,0,0,0.24);border:1px solid rgba(255,255,255,0.12);border-radius:4px;color:white;padding:11px 12px;font-family:var(--font-body);font-size:14px;outline:none;}
.client-inline-form select option{color:var(--text);background:white;}
.client-inline-form button{white-space:nowrap;}
.portal-inline-select{background:rgba(0,0,0,0.24);border:1px solid rgba(255,255,255,0.12);border-radius:4px;color:white;padding:7px 8px;font-family:var(--font-body);font-size:13px;outline:none;min-width:110px;}
.portal-inline-select option{color:var(--text);background:white;}
.portal-row-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
.portal-action-link{color:var(--gold);font-weight:700;text-decoration:none;font-size:12px;text-transform:uppercase;letter-spacing:1px;}
.admin-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;}
.admin-tab{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.08);color:rgba(255,255,255,0.7);padding:10px 14px;border-radius:4px;font-family:var(--font-display);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:1px;cursor:pointer;}
.admin-tab.active{background:var(--red);color:white;border-color:var(--red);}
.admin-grid{display:grid;grid-template-columns:minmax(280px,320px) minmax(0,1fr);gap:18px;align-items:start;}
.admin-form{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.admin-form .full{grid-column:1/-1;}
.admin-form-status{grid-column:1/-1;min-height:18px;font-size:13px;color:rgba(255,255,255,0.65);line-height:1.4;}
.admin-form-status.ok{color:#7ee2a8;}
.admin-form-status.error{color:#ffb3b3;}
.admin-form label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:rgba(255,255,255,0.45);text-transform:uppercase;letter-spacing:1px;}
.admin-form input,.admin-form select,.admin-form textarea{width:100%;background:rgba(0,0,0,0.24);border:1px solid rgba(255,255,255,0.12);border-radius:4px;color:white;padding:11px 12px;font-family:var(--font-body);font-size:14px;outline:none;}
.admin-form textarea{min-height:100px;resize:vertical;}
.admin-form select option{color:var(--text);background:white;}
.tag-editor{display:flex;flex-wrap:wrap;gap:8px;padding:10px;background:rgba(0,0,0,0.18);border:1px solid rgba(255,255,255,0.08);border-radius:4px;}
.tag-pill{display:flex;align-items:center;gap:7px;background:rgba(196,160,74,0.16);color:var(--gold);padding:5px 9px;border-radius:20px;font-size:12px;font-weight:700;}
.tag-pill button{background:none;border:none;color:var(--gold);cursor:pointer;font-weight:900;}
.drop-zone{border:2px dashed rgba(196,160,74,0.35);border-radius:6px;padding:18px;text-align:center;color:rgba(255,255,255,0.55);cursor:pointer;background:rgba(196,160,74,0.05);}
.drop-zone.drag{background:rgba(196,160,74,0.12);border-color:var(--gold);}
.upload-progress{height:8px;background:rgba(255,255,255,0.08);border-radius:10px;overflow:hidden;margin-top:10px;}
.upload-progress span{display:block;height:100%;width:0;background:var(--gold);transition:width .25s;}
.image-preview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:10px;}
.image-preview{position:relative;border:1px solid rgba(255,255,255,0.1);border-radius:4px;overflow:hidden;cursor:grab;background:rgba(255,255,255,0.04);}
.image-preview img{width:100%;height:74px;object-fit:cover;display:block;}
.image-preview button{position:absolute;right:4px;top:4px;background:rgba(0,0,0,0.65);border:none;color:white;border-radius:3px;padding:2px 6px;cursor:pointer;}
.image-preview.main{outline:2px solid var(--gold);}
.image-preview .cover{display:none;position:absolute;left:4px;bottom:4px;background:var(--gold);color:var(--navy);font-size:10px;font-weight:800;padding:2px 5px;border-radius:2px;}
.image-preview.main .cover{display:block;}
.admin-preview-card{background:white;color:var(--text);border-radius:4px;overflow:hidden;}
.admin-preview-card img{width:100%;height:180px;object-fit:cover;background:#d8dce8;}
.admin-preview-card .body{padding:16px;}
.admin-preview-card h4{font-family:var(--font-display);font-size:18px;text-transform:uppercase;color:var(--navy);margin-bottom:6px;}
.admin-toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px;}
.admin-toolbar input,.admin-toolbar select{background:rgba(0,0,0,0.24);border:1px solid rgba(255,255,255,0.12);border-radius:4px;color:white;padding:10px 12px;font-family:var(--font-body);outline:none;}
.admin-toolbar select option{color:var(--text);background:white;}
.toast-stack{position:fixed;right:24px;bottom:24px;z-index:5000;display:grid;gap:10px;}
.toast{background:#101933;border-left:4px solid var(--gold);color:white;padding:12px 14px;border-radius:4px;box-shadow:0 14px 40px rgba(0,0,0,0.28);font-size:14px;animation:toastIn .2s ease-out;}
.toast.success{border-left-color:#1A6B44;}
.toast.error{border-left-color:var(--red);}
.toast.warning{border-left-color:var(--gold);color:#fff6d7;}
.skeleton-row{height:42px;border-radius:4px;background:linear-gradient(90deg,rgba(255,255,255,0.04),rgba(255,255,255,0.1),rgba(255,255,255,0.04));background-size:200% 100%;animation:pulse 1.1s infinite;margin:8px 0;}
@keyframes toastIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
@keyframes pulse{to{background-position:-200% 0;}}
.advisor-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:18px;}
.advisor-metric{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.07);border-radius:4px;padding:16px;}
.advisor-metric h4{font-family:var(--font-display);color:white;font-size:14px;text-transform:uppercase;margin-bottom:10px;}
.advisor-metric .num{font-family:var(--font-display);color:var(--gold);font-size:28px;font-weight:900;}
.advisor-metric div{overflow-wrap:anywhere;}
.side-panel{position:fixed;top:0;right:-420px;width:420px;max-width:100%;height:100vh;background:#101933;z-index:4200;border-left:1px solid rgba(255,255,255,0.12);padding:24px;transition:right .25s;overflow-y:auto;}
.side-panel.active{right:0;}
.side-panel h3{font-family:var(--font-display);color:white;text-transform:uppercase;margin-bottom:14px;}
.mini-client{padding:12px 0;border-bottom:1px solid rgba(255,255,255,0.07);color:rgba(255,255,255,0.72);}
.canvas-wrap{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.07);border-radius:4px;padding:16px;margin-bottom:18px;}
#panel-gestionar-web .portal-content{overflow-x:hidden;}
#panel-gestionar-web .portal-table{min-width:760px;}
.hero-editor-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:start;}
.hero-editor-card{background:rgba(255,255,255,0.035);border:1px solid rgba(255,255,255,0.08);border-radius:4px;padding:18px;margin-bottom:16px;}
.hero-editor-card h3{font-family:var(--font-display);text-transform:uppercase;color:white;font-size:15px;letter-spacing:1.5px;margin-bottom:14px;}
.hero-preview-box{position:sticky;top:18px;min-height:420px;border-radius:4px;overflow:hidden;background:#060E28;border:1px solid rgba(196,160,74,0.25);display:flex;align-items:center;padding:32px;}
.hero-preview-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.55);}
.hero-preview-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(6,14,40,.92),rgba(26,78,200,.5),rgba(139,30,47,.28));}
.hero-preview-content{position:relative;z-index:2;max-width:620px;}
.hero-preview-badge{display:inline-flex;color:var(--gold);font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:2px;text-transform:uppercase;border:1px solid rgba(196,160,74,.5);padding:6px 12px;background:rgba(196,160,74,.12);margin-bottom:18px;}
.hero-preview-title{font-family:var(--font-display);font-size:clamp(34px,4vw,58px);font-weight:900;line-height:.95;color:white;text-transform:uppercase;margin-bottom:12px;}
.hero-preview-title span{color:var(--gold);}
.hero-preview-sub{color:rgba(255,255,255,.72);font-family:var(--font-accent);font-style:italic;font-size:20px;margin-bottom:22px;}
.hero-preview-actions{display:flex;gap:10px;flex-wrap:wrap;}
.hero-preview-actions span{padding:10px 14px;border-radius:4px;font-family:var(--font-display);font-size:11px;font-weight:800;text-transform:uppercase;}
.hero-preview-actions .main{background:var(--red);color:white;}
.hero-preview-actions .secondary{border:1px solid var(--gold);color:var(--gold);}
.hero-preview-actions .wa{background:#25D366;color:white;}
.sections-manager{display:grid;gap:8px;}
.section-manager-row{display:grid;grid-template-columns:42px 1fr auto;gap:12px;align-items:center;background:rgba(255,255,255,0.035);border:1px solid rgba(255,255,255,0.08);border-radius:4px;padding:12px;}
.section-manager-handle{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:4px;background:rgba(255,255,255,0.06);color:var(--gold);font-weight:800;}
.section-manager-title{font-family:var(--font-display);font-weight:800;color:white;font-size:13px;text-transform:uppercase;letter-spacing:.8px;}
.section-manager-meta{font-size:12px;color:rgba(255,255,255,0.42);margin-top:3px;}
.section-manager-actions{display:flex;gap:6px;align-items:center;justify-content:flex-end;flex-wrap:wrap;}
.section-manager-actions button{width:34px;height:34px;border-radius:4px;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.06);color:white;cursor:pointer;}
.section-manager-actions button:hover{border-color:var(--gold);color:var(--gold);}
.section-switch{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,0.65);font-size:12px;font-weight:700;text-transform:uppercase;}
.section-switch input{width:16px;height:16px;accent-color:var(--gold);}
.offices-editor{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}
.office-editor-card{background:rgba(255,255,255,0.035);border:1px solid rgba(255,255,255,0.08);border-radius:4px;padding:16px;}
.office-editor-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,0.07);}
.office-editor-title{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:900;color:white;text-transform:uppercase;letter-spacing:1px;font-size:13px;}
.office-editor-number{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--gold);color:var(--navy);font-size:13px;}
.office-editor-actions{display:flex;gap:6px;}
.office-editor-actions button{border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.05);color:rgba(255,255,255,0.75);border-radius:4px;padding:7px 9px;font-size:11px;text-transform:uppercase;font-weight:800;cursor:pointer;}
.office-editor-actions button:hover{border-color:var(--gold);color:var(--gold);}
.office-editor-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.office-editor-grid label{margin:0;}
.office-editor-grid label.full{grid-column:1/-1;}
.office-editor-preview{margin-top:12px;padding:12px;border-radius:4px;background:rgba(196,160,74,0.08);border:1px solid rgba(196,160,74,0.18);color:rgba(255,255,255,0.72);font-size:13px;line-height:1.5;}
.office-editor-preview strong{display:block;color:white;font-family:var(--font-display);text-transform:uppercase;font-size:12px;letter-spacing:1px;margin-bottom:4px;}
.cities-editor{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}
.city-editor-card{background:rgba(255,255,255,0.035);border:1px solid rgba(255,255,255,0.08);border-radius:4px;padding:14px;}
.city-editor-row{display:grid;grid-template-columns:84px 1fr;gap:12px;align-items:start;}
.city-editor-thumb{width:80px;height:80px;border-radius:4px;overflow:hidden;position:relative;background:#07184A;border:1px solid rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center;color:white;text-align:center;font-size:10px;font-weight:800;text-transform:uppercase;}
.city-editor-thumb img{width:100%;height:100%;object-fit:cover;}
.city-editor-thumb button{position:absolute;top:5px;right:5px;width:22px;height:22px;border:0;border-radius:50%;background:rgba(139,30,47,.95);color:white;cursor:pointer;}
.city-editor-fields{display:grid;grid-template-columns:1fr;gap:8px;}
.city-editor-fields input{margin-top:4px;}
.city-upload-label{display:inline-flex;margin-top:8px;cursor:pointer;}
.city-editor-status{margin-top:8px;font-size:12px;color:rgba(255,255,255,.55);}
.testimonials-editor{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}
.testimonial-editor-card{background:rgba(255,255,255,0.035);border:1px solid rgba(255,255,255,0.08);border-radius:4px;padding:14px;}
.testimonial-editor-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px;}
.testimonial-editor-title{font-family:var(--font-display);font-weight:900;color:white;text-transform:uppercase;letter-spacing:1px;font-size:12px;}
.testimonial-editor-actions{display:flex;gap:6px;}
.testimonial-editor-actions button{border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.05);color:rgba(255,255,255,0.75);border-radius:4px;padding:7px 9px;font-size:11px;text-transform:uppercase;font-weight:800;cursor:pointer;}
.testimonial-editor-actions button:hover{border-color:var(--gold);color:var(--gold);}
.testimonial-editor-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.testimonial-editor-grid label{margin:0;}
.testimonial-editor-grid label.full{grid-column:1/-1;}
.testimonial-editor-grid input,.testimonial-editor-grid select,.testimonial-editor-grid textarea{width:100%;margin-top:6px;background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.12);border-radius:4px;color:white;padding:11px 12px;font-family:var(--font-body);font-size:14px;}
.testimonial-editor-grid textarea{min-height:96px;resize:vertical;}
.dynamic-content-editor{display:grid;gap:14px;}
.dynamic-editor-card{background:rgba(255,255,255,0.035);border:1px solid rgba(255,255,255,0.08);border-radius:4px;padding:16px;}
.dynamic-editor-card h4{font-family:var(--font-display);color:white;text-transform:uppercase;font-size:13px;letter-spacing:1.4px;margin-bottom:12px;}
.dynamic-editor-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
.dynamic-editor-grid label{margin:0;}
.dynamic-editor-grid label.full{grid-column:1/-1;}
.dynamic-editor-grid input,.dynamic-editor-grid textarea{width:100%;margin-top:6px;background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.12);border-radius:4px;color:white;padding:11px 12px;font-family:var(--font-body);font-size:14px;}
.dynamic-editor-grid textarea{min-height:96px;resize:vertical;}
.dynamic-editor-help{font-size:12px;color:rgba(255,255,255,.45);line-height:1.45;margin-top:6px;}
.office-editor-grid .color-field{display:grid;grid-template-columns:1fr 54px;gap:8px;align-items:end;}
.office-editor-grid .color-field input[type="color"]{height:42px;padding:4px;}
.office-editor-media{display:flex;gap:12px;align-items:flex-start;margin-top:12px;}
.office-editor-media .city-editor-thumb{flex:0 0 80px;}
.role-badge,.tx-badge{padding:4px 9px;border-radius:16px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1px;}
.role-superadmin{background:var(--gold);color:var(--navy);}
.role-admin{background:var(--blue);color:white;}
.role-supervisor{background:#1A6B44;color:white;}
.role-asesor{background:rgba(255,255,255,0.12);color:rgba(255,255,255,0.72);}
.tx-reservacion{background:var(--blue);color:white;}
.tx-apartado{background:var(--gold);color:var(--navy);}
.tx-venta{background:#1A6B44;color:white;}
.type-picker{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:12px;}
.type-picker button{padding:16px 10px;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.05);color:white;border-radius:4px;font-family:var(--font-display);font-weight:800;cursor:pointer;}
.type-picker button.active{background:var(--red);border-color:var(--gold);}
.modal-lite{display:none;position:fixed;inset:0;z-index:4400;background:rgba(0,0,0,0.72);align-items:center;justify-content:center;padding:24px;}
.modal-lite.active{display:flex;}
.modal-lite-card{width:min(460px,100%);background:#101933;border:1px solid rgba(255,255,255,0.12);border-radius:6px;padding:22px;}
.project-settings-panel{position:fixed;top:0;right:-560px;width:560px;max-width:100%;height:100vh;background:#101933;z-index:4500;border-left:1px solid rgba(196,160,74,0.28);padding:22px;transition:right .25s;overflow-y:auto;box-shadow:-30px 0 80px rgba(0,0,0,.34);}
.project-settings-panel.active{right:0;}
.project-settings-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.08);}
.project-settings-head h3{font-family:var(--font-display);color:white;text-transform:uppercase;font-size:18px;margin:0;}
.project-settings-head p{color:rgba(255,255,255,.48);font-size:13px;margin-top:4px;}
.settings-close{width:34px;height:34px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.05);color:white;border-radius:4px;cursor:pointer;}
.project-settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.project-settings-grid label{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.38);font-family:var(--font-display);font-weight:700;}
.project-settings-grid input,.project-settings-grid select,.project-settings-grid textarea{width:100%;margin-top:6px;background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.12);border-radius:4px;color:white;padding:12px;font-family:var(--font-body);font-size:14px;}
.project-settings-grid .full{grid-column:1/-1;}
.project-settings-section{margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08);}
.project-settings-section h4{font-family:var(--font-display);color:white;text-transform:uppercase;font-size:13px;letter-spacing:1.4px;margin-bottom:12px;}
.settings-images{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.settings-image{position:relative;height:82px;border-radius:4px;overflow:hidden;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);}
.settings-image img{width:100%;height:100%;object-fit:cover;}
.settings-image video{width:100%;height:100%;object-fit:cover;background:#050914;}
.settings-image button{position:absolute;top:6px;right:6px;width:24px;height:24px;border:0;border-radius:50%;background:rgba(139,30,47,.92);color:white;cursor:pointer;}
.settings-media-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;}
.settings-media-head h4{margin:0;}
.settings-media-count{font-family:var(--font-display);font-size:11px;font-weight:800;text-transform:uppercase;color:var(--gold);letter-spacing:1px;}
.settings-media-total{font-size:12px;color:rgba(255,255,255,.56);margin-bottom:10px;}
.settings-media-notice{display:none;margin:12px 0;padding:10px 12px;border-radius:4px;font-size:13px;line-height:1.45;border:1px solid transparent;white-space:pre-line;}
.settings-media-notice.active{display:block;}
.settings-media-notice.error{background:rgba(139,30,47,.18);border-color:rgba(139,30,47,.48);color:#ffd7dd;}
.settings-media-notice.success{background:rgba(26,107,68,.16);border-color:rgba(26,107,68,.45);color:#d9ffe9;}
.settings-media-empty{display:flex;align-items:center;justify-content:center;min-height:82px;padding:12px;border:1px dashed rgba(255,255,255,.14);border-radius:4px;color:rgba(255,255,255,.45);font-size:13px;}
.settings-tool-btn{width:34px;height:34px;border:1px solid rgba(196,160,74,.35);background:rgba(196,160,74,.12);color:var(--gold);border-radius:4px;cursor:pointer;font-size:16px;}
.settings-tool-btn:hover{background:var(--gold);color:var(--navy);}

/* PROJECT MODAL */
#project-modal{display:none;position:fixed;inset:0;z-index:3000;background:rgba(0,0,0,0.9);align-items:center;justify-content:center;padding:30px;}
#project-modal.active{display:flex;}
.modal-inner{background:white;border-radius:4px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;position:relative;}
.modal-close{position:absolute;top:20px;right:20px;z-index:10;background:white;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;border:none;box-shadow:0 2px 10px rgba(0,0,0,0.15);transition:all .3s;}
.modal-close:hover{background:var(--red);color:white;}
.modal-hero{height:320px;overflow:hidden;position:relative;}
.modal-hero img{width:100%;height:100%;object-fit:cover;}
.modal-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(6,14,40,0.92),transparent 50%);}
.modal-hero-info{position:absolute;bottom:0;left:0;right:0;padding:24px 30px;}
.modal-hero-info h2{font-family:var(--font-display);font-weight:900;font-size:38px;color:white;text-transform:uppercase;letter-spacing:-1px;}
.modal-hero-info .location{color:var(--gold);font-size:14px;text-transform:uppercase;letter-spacing:2px;}
.modal-body{padding:30px;}
.modal-specs{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;padding:20px;background:var(--off-white);border-radius:4px;}
.modal-spec{text-align:center;}
.modal-spec-val{font-family:var(--font-display);font-weight:800;font-size:22px;color:var(--navy);}
.modal-spec-lbl{font-size:12px;color:var(--gray);text-transform:uppercase;letter-spacing:1.5px;}
.modal-desc{font-size:15px;color:var(--gray);line-height:1.8;margin-bottom:24px;}
.modal-amenities{margin-bottom:24px;}
.modal-amenities h3{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--navy);text-transform:uppercase;margin-bottom:14px;}
.amenity-grid{display:flex;flex-wrap:wrap;gap:10px;}
.amenity{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--off-white);border-radius:3px;font-size:13px;color:var(--text);}
.amenity::before{content:'✓';color:var(--gold);font-weight:700;}
.modal-actions{display:flex;gap:12px;flex-wrap:wrap;}
.modal-gallery{margin:0 0 24px;}
.modal-gallery h3{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--navy);text-transform:uppercase;margin-bottom:14px;}
.modal-gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;}
.modal-gallery-grid img,.modal-gallery-grid video{width:100%;height:120px;object-fit:cover;border-radius:4px;background:var(--navy);}
.modal-gallery-grid img{cursor:pointer;}
#redex-lightbox{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,0.92);display:flex;align-items:center;justify-content:center;}
#lightbox-overlay{position:absolute;inset:0;z-index:0;}
#lightbox-img{position:relative;z-index:1;max-width:90vw;max-height:85vh;object-fit:contain;border-radius:8px;user-select:none;-webkit-user-drag:none;}
#lightbox-close{position:absolute;top:16px;right:20px;z-index:2;background:transparent;border:none;color:#fff;font-size:28px;cursor:pointer;line-height:1;}
#lightbox-prev,#lightbox-next{position:absolute;top:50%;transform:translateY(-50%);z-index:2;background:rgba(255,255,255,0.12);border:none;color:#fff;font-size:32px;width:52px;height:52px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;}
#lightbox-prev{left:16px;}
#lightbox-next{right:16px;}
#lightbox-prev:hover,#lightbox-next:hover{background:rgba(255,255,255,0.28);}
#lightbox-counter{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,0.7);font-size:14px;z-index:2;}

/* ANIMATIONS */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-left{opacity:0;transform:translateX(-30px);transition:opacity .7s ease,transform .7s ease;}
.reveal-left.visible{opacity:1;transform:translateX(0);}
.reveal-right{opacity:0;transform:translateX(30px);transition:opacity .7s ease,transform .7s ease;}
.reveal-right.visible{opacity:1;transform:translateX(0);}
.delay-1{transition-delay:.1s!important;}
.delay-2{transition-delay:.2s!important;}
.delay-3{transition-delay:.3s!important;}
.delay-4{transition-delay:.4s!important;}

/* MOBILE NAV */
.mobile-menu{display:none;position:fixed;inset:0;z-index:999;background:var(--navy);padding:100px 5% 5%;flex-direction:column;gap:6px;}
.mobile-menu.open{display:flex;}
.mobile-menu a{color:rgba(255,255,255,0.85);text-decoration:none;font-family:var(--font-display);font-weight:700;font-size:24px;letter-spacing:2px;text-transform:uppercase;padding:14px 0;border-bottom:1px solid rgba(255,255,255,0.06);}
.mobile-menu a:hover{color:var(--gold);}

@media(max-width:960px){
  body > nav{padding:0 4%;}
  .nav-links,.nav-cta{display:none;}
  .hamburger{display:flex;}
  .hero-content{padding:0 5%;}
  .hero-stats{gap:24px;}
  .about-grid,.force-grid{grid-template-columns:1fr;gap:40px;}
  .about-img-badge{left:10px;}
  .projects-grid{grid-template-columns:repeat(2,1fr);}
  .why-grid{grid-template-columns:repeat(2,1fr);}
  .about-features{grid-template-columns:1fr;}
  .advisors-grid{grid-template-columns:repeat(2,1fr);}
  .metrics-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px;}
  section{padding:70px 5%;}
  .portal-sidebar{width:230px;}
  .portal-kpis{grid-template-columns:repeat(2,1fr);}
  .portal-row{grid-template-columns:1fr;}
  .portal-content{padding:20px;}
  .portal-header{padding:16px 20px;}
  .client-inline-form{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:600px){
  .hero-search{flex-direction:column;}
  .hero-actions{flex-direction:column;align-items:flex-start;}
  .projects-grid,.why-grid,.about-features,.advisors-grid,.metrics-grid,.force-numbers{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .modal-specs{grid-template-columns:repeat(2,1fr);}
  .portal-sidebar{width:210px;}
  .link-share-row{grid-template-columns:1fr;}
  .contact-form{grid-template-columns:1fr;}
  .portal-form-grid{grid-template-columns:1fr;}
  .client-inline-form{grid-template-columns:1fr;}
  .admin-grid{grid-template-columns:1fr;}
  .advisor-cards{grid-template-columns:1fr;}
  .image-preview-grid{grid-template-columns:repeat(2,1fr);}
}

@media(max-width:768px){
  .ticker,.growing-ticker-wrap{
    width:100vw;
    max-width:100vw;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
    padding-left:0;
    padding-right:0;
    border-radius:0;
    box-shadow:none;
    position:relative;
    left:auto;
    right:auto;
  }
  .ticker-inner,.growing-ticker{
    width:max-content;
    max-width:none;
    margin:0;
    padding:0;
  }
  .ticker-item,.growing-ticker span{
    flex:0 0 auto;
  }
  #lightbox-prev,#lightbox-next{display:none;}
}

@media(max-width:760px){
  html,body{overflow-x:hidden;width:100%;max-width:100%;}
  body > nav,section,footer,.hero,.video-fullwidth,.growing-section,.maps-section,.projects-section,.why-section,.cities-section,.metrics-section,.advisors-section,.testimonials-section,.force-section,.cta-section{max-width:100%;overflow-x:hidden;}
  body > nav{height:74px;padding:0 18px;}
  .nav-inner{height:74px;width:100%;max-width:100%;}
  .nav-logo::before{font-size:22px;}
  .hamburger{width:40px;height:40px;align-items:center;justify-content:center;}
  .mobile-menu{padding:92px 24px 28px;max-width:100vw;overflow-x:hidden;}
  .mobile-menu a{font-size:18px;letter-spacing:1px;padding:13px 0;}
  .hero{height:auto;min-height:100svh;padding-top:96px;align-items:flex-start;}
  .hero-content{padding:0 22px 34px;width:100%;margin-top:18px;}
  .hero-badge{font-size:10px;letter-spacing:2px;max-width:100%;white-space:normal;text-align:center;}
  .hero h1{font-size:clamp(40px,14vw,64px);line-height:.96;letter-spacing:0;max-width:100%;}
  .hero-subtitle{font-size:clamp(18px,5vw,25px);line-height:1.35;max-width:100%;}
  .hero-subtitle br{display:none;}
  .hero-search{width:100%;max-width:none;padding:8px;gap:8px;}
  .hero-search select,.hero-search input{width:100%;padding:12px 10px;}
  .search-group{width:100%;border-right:none;border-bottom:1px solid rgba(255,255,255,0.08);padding:8px 10px;}
  .search-group:last-of-type{border-bottom:none;}
  .hero-search .btn-search{width:100%;justify-content:center;padding:15px;}
  .hero-actions{width:100%;gap:10px;margin-top:22px;}
  .hero-actions a{width:100%;justify-content:center;text-align:center;padding:14px 18px;}
  .hero-stats{grid-template-columns:repeat(2,1fr);display:grid;width:100%;gap:12px;margin-top:24px;}
  .stat-num{font-size:34px;}
  section{padding:56px 22px;}
  .section-title{font-size:clamp(32px,10vw,48px);letter-spacing:0;}
  .section-sub{max-width:100%;line-height:1.65;}
  .about-grid,.about-features,.force-grid,.force-numbers,.projects-grid,.why-grid,.advisors-grid,.metrics-grid,.footer-grid{grid-template-columns:1fr!important;}
  .about-feat{width:100%;align-items:flex-start;}
  .feat-text{min-width:0;flex:1;}
  .why-card{padding:30px 22px;}
  .why-num{font-size:60px;}
  .about-img-wrap img,.force-visual img{height:auto;max-height:420px;}
  .about-img-badge{position:relative;left:auto;bottom:auto;margin:-42px 16px 0;padding:18px 20px;}
  .project-card{min-width:0;}
  .card-footer{align-items:flex-start;gap:12px;flex-direction:column;}
  .btn-card{width:100%;justify-content:center;text-align:center;display:flex;}
  .testimonial-card{min-width:calc(100vw - 44px);padding:26px 22px;}
  .cities-scroll{padding:0 22px 20px;max-width:100vw;}
  .city-card{min-width:min(220px, calc(100vw - 44px));}
  .contact-form{grid-template-columns:1fr;}
  .contact-form input,.contact-form select,.contact-form textarea{min-width:0;}
  .contact-form button{width:100%;}
  .cta-buttons a{width:100%;justify-content:center;text-align:center;}
  .footer-bottom{align-items:flex-start;flex-direction:column;}
  .float-wa{width:50px;height:50px;right:18px;bottom:18px;}
  #portal-overlay.active:not(.login-required){display:flex;flex-direction:column;}
  .portal-sidebar{width:100%;height:auto;max-height:44svh;border-right:none;border-bottom:1px solid rgba(255,255,255,0.08);}
  .portal-logo{padding:14px 18px;}
  .portal-nav{display:flex;overflow-x:auto;overflow-y:hidden;padding:8px 10px;gap:6px;flex:none;}
  .portal-section-label{display:none;}
  .portal-nav-item{white-space:nowrap;border-left:none;border-bottom:3px solid transparent;padding:10px 12px;font-size:11px;gap:6px;}
  .portal-nav-item:hover,.portal-nav-item.active{border-left-color:transparent;border-bottom-color:var(--gold);}
  .portal-footer{padding:12px 18px;}
  .portal-user{margin-bottom:8px;}
  .portal-main{height:56svh;overflow-y:auto;}
  .portal-header{padding:15px 18px;align-items:flex-start;gap:12px;flex-direction:column;}
  .portal-header h1{font-size:18px;line-height:1.2;}
  .portal-header-actions{width:100%;flex-wrap:wrap;}
  .portal-header-actions .btn-portal-action{flex:1;min-width:140px;}
  .portal-content{padding:18px;}
  .portal-kpis{grid-template-columns:1fr 1fr;gap:10px;}
  .admin-admin-grid,.admin-mini-grid,.admin-podium{grid-template-columns:1fr;}
  .kpi-card{padding:16px;}
  .kpi-num{font-size:30px;}
  .portal-row,.admin-grid{grid-template-columns:1fr!important;}
  .portal-card{padding:16px;}
  .portal-table{min-width:680px;}
  .table-wrap{margin-left:-4px;margin-right:-4px;padding-bottom:8px;}
  .client-inline-form,.admin-form,.portal-form-grid{grid-template-columns:1fr!important;}
  .admin-form .full{grid-column:auto;}
  .link-share-row{grid-template-columns:1fr;}
  #projectLinksGrid{grid-template-columns:1fr!important;}
  .image-preview-grid{grid-template-columns:repeat(2,1fr);}
  .modal-inner,.portal-form-card,.modal-lite-card{max-height:88svh;overflow-y:auto;}
  .project-settings-grid{grid-template-columns:1fr;}
  .settings-images{grid-template-columns:repeat(2,1fr);}
  .hero-editor-grid{grid-template-columns:1fr;}
  .hero-preview-box{position:relative;min-height:360px;top:auto;}
  .offices-editor{grid-template-columns:1fr;}
  .cities-editor{grid-template-columns:1fr;}
  .testimonials-editor{grid-template-columns:1fr;}
  .testimonial-editor-grid{grid-template-columns:1fr;}
  .dynamic-editor-grid{grid-template-columns:1fr;}
  .office-editor-grid{grid-template-columns:1fr;}
  .section-manager-row{grid-template-columns:34px 1fr;}
  .section-manager-actions{grid-column:1 / -1;justify-content:flex-start;}
  .modal-hero{height:220px;}
  .modal-hero-info h2{font-size:26px;letter-spacing:0;}
  .modal-body{padding:20px;}
  .modal-specs{grid-template-columns:1fr 1fr;gap:10px;padding:14px;}
  #lightbox-prev,#lightbox-next{display:none;}
}

/* Tipografia y colores configurables desde el CMS */
:root {
  --font-display: 'Montserrat', sans-serif;
  --font-body: 'Barlow', sans-serif;
  --font-accent: 'Playfair Display', serif;
  --font-size-base: 16px;
  --font-weight-titles: 900;
  --letter-spacing-titles: -1px;
}

body {
  font-family: var(--font-body);
  font-size: var(--font-size-base);
}

.hero-title,
.section-title,
.portal-title,
.portal-logo,
.nav-logo,
.footer-logo,
.card-title,
.office-city,
.city-name,
.kpi-num,
h1,
h2,
h3,
h4 {
  font-family: var(--font-display);
}

.hero-title,
.section-title {
  font-weight: var(--font-weight-titles);
  letter-spacing: var(--letter-spacing-titles);
}

.hero-subtitle,
.section-accent,
em {
  font-family: var(--font-accent);
}

@media(min-width:1400px){
  .portal-content{
    max-width:1300px;
    margin:0 auto;
    width:100%;
  }
}
