/* QAR Base — main.css v5.0 */

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

/* ── VARIABLES ── */
:root{
  --bg:        #0d0c0b;
  --bg2:       #121110;
  --bg3:       #171614;
  --card:      #181715;
  --brd:       #272421;
  --brh:       #38342f;

  --gold:      #c6a054;
  --gold-d:    #a07e38;
  --gold-rgb:  198,160,84;
  --gold-dim:  rgba(198,160,84,.08);
  --gold-mid:  rgba(198,160,84,.18);

  --txt:       #e4e0d8;
  --txt2:      #9e9890;
  --txt3:      #5c574f;
  --wht:       #f5f2ec;

  --font:      'Plus Jakarta Sans', system-ui, sans-serif;
  --mono:      'DM Mono', ui-monospace, monospace;

  --r:         4px;
  --rm:        8px;
  --rl:        14px;
  --rxl:       20px;
  --pill:      999px;

  --hdr:       64px;
  --max:       1160px;
  --ease:      cubic-bezier(.16,1,.3,1);
  --dur:       .24s;
}

body{
  background:var(--bg);
  color:var(--txt);
  font-family:var(--font);
  line-height:1.6;
  overflow-x:hidden;
}

.w{width:100%;max-width:var(--max);margin-inline:auto;padding-inline:clamp(20px,5vw,64px)}
.sec{padding-block:clamp(80px,10vw,120px)}
a{color:inherit;text-decoration:none}

/* ── SCROLL REVEAL ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-d1{transition-delay:.1s}
.reveal-d2{transition-delay:.2s}
.reveal-d3{transition-delay:.3s}
.reveal-d4{transition-delay:.4s}

/* ════════════════════════
   HEADER
════════════════════════ */
#hdr{
  position:fixed;inset:0 0 auto;height:var(--hdr);z-index:900;
  border-bottom:1px solid transparent;
  transition:background var(--dur),border-color var(--dur);
}
#hdr.stuck{
  background:rgba(13,12,11,.88);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border-bottom-color:var(--brd);
}
.hdr-inner{height:100%;display:flex;align-items:center;gap:32px}

/* Logo */
.logo{display:flex;flex-direction:column;gap:1px;flex-shrink:0}
.logo-name{font-size:1.05rem;font-weight:800;letter-spacing:-.02em;color:var(--wht);display:flex;align-items:center;gap:4px}
.logo-name span{color:var(--gold)}
.logo-tag{font-size:.5rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--txt3);font-family:var(--mono)}

/* Nav */
.nav{margin-left:auto;display:flex;align-items:center;gap:2px;position:relative}
.nav a{font-size:.82rem;font-weight:500;color:var(--txt2);padding:7px 15px;border-radius:var(--pill);position:relative;z-index:1;transition:color var(--dur)}
.nav a:hover,.nav a.active{color:var(--wht)}
.nav-bg{position:absolute;border-radius:var(--pill);background:rgba(var(--gold-rgb),.07);border:1px solid rgba(var(--gold-rgb),.14);transition:all .28s var(--ease);pointer-events:none;z-index:0;opacity:0}
.hdr-btn{margin-left:12px;font-size:.8rem;font-weight:700;color:var(--gold);border:1px solid rgba(var(--gold-rgb),.35);padding:7px 18px;border-radius:var(--pill);transition:all var(--dur);white-space:nowrap}
.hdr-btn:hover{background:rgba(var(--gold-rgb),.1);border-color:rgba(var(--gold-rgb),.6)}

/* Burger */
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;padding:6px;margin-left:auto;cursor:pointer;background:none;border:none}
.burger span{display:block;width:20px;height:1.5px;background:var(--txt);border-radius:2px;transition:all var(--dur)}
.burger.on span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.on span:nth-child(2){opacity:0}
.burger.on span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:890;backdrop-filter:blur(4px)}
.nav-overlay.on{display:block}

/* ════════════════════════
   HERO — split 55/45
════════════════════════ */
#hero{
  min-height:100dvh;
  display:grid;
  grid-template-columns:55fr 45fr;
  position:relative;overflow:hidden;
  background:var(--bg);
}
#hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 80% at 70% 50%,rgba(var(--gold-rgb),.055) 0%,transparent 65%),
    radial-gradient(ellipse 40% 60% at 20% 80%,rgba(var(--gold-rgb),.03) 0%,transparent 60%);
  pointer-events:none;
}
#hero::after{
  content:'';position:absolute;inset:0;
  background-image:linear-gradient(var(--brd) 1px,transparent 1px),linear-gradient(90deg,var(--brd) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 90% 90% at 70% 50%,black 0%,transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 90% 90% at 70% 50%,black 0%,transparent 70%);
  opacity:.3;pointer-events:none;
}
.hero-left{
  display:flex;flex-direction:column;justify-content:center;
  padding-top:var(--hdr);
  padding-left:clamp(20px,6vw,100px);
  padding-right:clamp(20px,3vw,48px);
  padding-bottom:clamp(60px,8vh,100px);
  position:relative;z-index:2;
}
.hero-right{
  display:flex;align-items:center;justify-content:center;
  position:relative;z-index:2;
  padding:var(--hdr) clamp(20px,4vw,64px) clamp(60px,8vh,100px);
  overflow:hidden;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.72rem;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold);
  font-family:var(--mono);margin-bottom:28px;
}
.eyebrow::before{content:'';width:24px;height:1px;background:var(--gold);opacity:.7}
.hero-h1{
  font-size:clamp(2.6rem,5.5vw,4.2rem);
  font-weight:800;line-height:1.02;letter-spacing:-.04em;
  color:var(--wht);margin-bottom:24px;
}
.hero-h1 em{
  font-style:normal;
  color:transparent;
  -webkit-text-stroke:1.5px var(--gold);
}
.hero-p{font-size:.97rem;color:var(--txt2);line-height:1.85;max-width:440px;margin-bottom:42px}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.hero-stats{display:flex;gap:0;margin-top:52px;padding-top:28px;border-top:1px solid var(--brd)}
.stat{padding-right:32px;margin-right:32px;border-right:1px solid var(--brd)}
.stat:last-child{border-right:none;margin-right:0;padding-right:0}
.stat-n{font-size:1.6rem;font-weight:800;color:var(--wht);line-height:1;letter-spacing:-.03em}
.stat-n sup{font-size:.7em;color:var(--gold)}
.stat-l{font-size:.65rem;color:var(--txt3);margin-top:5px;text-transform:uppercase;letter-spacing:.1em;font-family:var(--mono)}
.hero-visual{width:100%;max-width:420px}
.hero-visual svg{width:100%;height:auto}

/* ════════════════════════
   BUTTONS
════════════════════════ */
.btn-p{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--gold);color:#0d0c0b;
  font-size:.85rem;font-weight:800;font-family:var(--font);
  padding:.72rem 1.8rem;border-radius:var(--pill);
  border:1.5px solid var(--gold);
  transition:all var(--dur);letter-spacing:-.01em;cursor:pointer;
}
.btn-p:hover{background:var(--gold-d);border-color:var(--gold-d);transform:translateY(-2px);box-shadow:0 10px 30px rgba(var(--gold-rgb),.3);color:#0d0c0b}
.btn-p:active{transform:translateY(0) scale(.98)}
.btn-o{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.85rem;font-weight:600;font-family:var(--font);
  color:var(--txt2);padding:.72rem 1.4rem;border-radius:var(--pill);
  border:1.5px solid var(--brh);
  transition:all var(--dur);cursor:pointer;background:none;
}
.btn-o:hover{border-color:rgba(var(--gold-rgb),.4);color:var(--wht)}
.btn-o:active{transform:scale(.98)}

/* ════════════════════════
   NOSOTROS
════════════════════════ */
#nosotros{background:var(--bg2);border-top:1px solid var(--brd)}
.nos-inner{display:grid;grid-template-columns:40fr 60fr;gap:clamp(48px,8vw,96px);align-items:start}
.sec-index{font-family:var(--mono);font-size:.65rem;letter-spacing:.18em;color:var(--txt3);text-transform:uppercase;margin-bottom:20px}
.sec-title{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;line-height:1.06;letter-spacing:-.035em;color:var(--wht);margin-bottom:20px}
.sec-title em{font-style:normal;color:var(--gold)}
.sec-sub{font-size:.93rem;color:var(--txt2);line-height:1.85;margin-bottom:28px;max-width:480px}
.nos-rule{width:36px;height:1.5px;background:var(--gold);margin-bottom:28px;opacity:.7}
.nos-pull{border-left:1.5px solid rgba(var(--gold-rgb),.3);padding:16px 20px;background:rgba(var(--gold-rgb),.04);border-radius:0 var(--rm) var(--rm) 0;margin-top:8px}
.nos-pull p{font-size:.85rem;color:var(--txt2);line-height:1.7}
.check-list{display:flex;flex-direction:column;gap:0}
.check-item{
  display:grid;grid-template-columns:32px 1fr;gap:14px;align-items:center;
  padding:16px 0;border-bottom:1px solid var(--brd);
  font-size:.875rem;color:var(--txt2);
  transition:color var(--dur),padding-left var(--dur);cursor:default;
}
.check-item:first-child{border-top:1px solid var(--brd)}
.check-item:hover{color:var(--txt);padding-left:4px}
.check-ico{width:30px;height:30px;border-radius:50%;background:rgba(var(--gold-rgb),.1);border:1px solid rgba(var(--gold-rgb),.18);display:grid;place-items:center;flex-shrink:0;transition:background var(--dur)}
.check-item:hover .check-ico{background:rgba(var(--gold-rgb),.2)}
.check-ico svg{width:13px;height:13px;stroke:var(--gold);stroke-width:2.5;fill:none}

/* ════════════════════════
   SERVICIOS
════════════════════════ */
#servicios{border-top:1px solid var(--brd)}
.svc-header{display:grid;grid-template-columns:1fr auto;align-items:end;margin-bottom:56px}
.svc-list{display:grid;grid-template-columns:1fr;gap:1px;border:1px solid var(--brd);border-radius:var(--rl);overflow:hidden;background:var(--brd)}
.svc-item{
  display:grid;grid-template-columns:80px 1fr 1fr;align-items:center;
  background:var(--card);padding:clamp(24px,3vw,32px) clamp(20px,3vw,32px);
  transition:background var(--dur);position:relative;overflow:hidden;
}
.svc-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:rgba(var(--gold-rgb),.06);transition:width .4s var(--ease)}
.svc-item:hover{background:var(--bg3)}
.svc-item:hover::before{width:100%}
.svc-num{font-family:var(--mono);font-size:.65rem;color:var(--txt3);letter-spacing:.1em;padding-right:24px;border-right:1px solid var(--brd);position:relative;z-index:1}
.svc-main{padding:0 clamp(20px,3vw,36px);position:relative;z-index:1}
.svc-name{font-size:.97rem;font-weight:700;color:var(--wht);margin-bottom:6px}
.svc-desc{font-size:.82rem;color:var(--txt2);line-height:1.65}
.svc-tags{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end;position:relative;z-index:1}
.svc-tag{font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--txt3);border:1px solid var(--brd);padding:3px 9px;border-radius:var(--pill);font-family:var(--mono);transition:color var(--dur),border-color var(--dur)}
.svc-item:hover .svc-tag{color:var(--gold);border-color:rgba(var(--gold-rgb),.3)}

/* ════════════════════════
   PLANES
════════════════════════ */
#planes{background:var(--bg2);border-top:1px solid var(--brd)}
.plans-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:860px;margin-inline:auto;margin-top:56px}
.plan{border-radius:var(--rxl);padding:clamp(28px,4vw,42px);border:1px solid var(--brd);background:var(--card);position:relative;overflow:hidden}
.plan.featured{background:#100e0b;border-color:rgba(var(--gold-rgb),.01)}
@property --a{syntax:'<angle>';initial-value:0deg;inherits:false}
@keyframes spin{to{--a:360deg}}
.plan-ring{position:absolute;inset:0;border-radius:var(--rxl);background:conic-gradient(from var(--a,0deg),transparent 55%,rgba(var(--gold-rgb),.55) 68%,transparent 80%);animation:spin 5s linear infinite;z-index:0;pointer-events:none}
.plan-ring-mask{position:absolute;inset:1px;border-radius:calc(var(--rxl) - 1px);background:#100e0b;z-index:1}
.plan>*{position:relative;z-index:2}
.plan-badge{display:inline-block;background:var(--gold);color:#0d0c0b;font-size:.65rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:4px 12px;border-radius:var(--pill);margin-bottom:18px;font-family:var(--mono)}
.plan-name{font-size:1.15rem;font-weight:700;color:var(--wht);margin-bottom:4px}
.plan-sep{height:1px;background:var(--brd);margin:18px 0}
.plan-price{font-size:2.4rem;font-weight:800;color:var(--gold);line-height:1;letter-spacing:-.04em;display:flex;align-items:baseline;gap:6px;margin-bottom:3px}
.plan-price small{font-size:.8rem;font-weight:500;color:var(--txt2);letter-spacing:0}
.plan-unit{font-size:.75rem;color:var(--txt3);margin-bottom:26px;font-family:var(--mono)}
.plan-items{display:flex;flex-direction:column;gap:11px;margin-bottom:28px}
.plan-item{display:flex;align-items:flex-start;gap:10px;font-size:.84rem;color:var(--txt2)}
.plan-check{width:18px;height:18px;border-radius:50%;background:rgba(var(--gold-rgb),.12);display:grid;place-items:center;flex-shrink:0;margin-top:1px}
.plan-check svg{width:9px;height:9px;stroke:var(--gold);stroke-width:3;fill:none}

/* ════════════════════════
   CTA STRIP
════════════════════════ */
.cta-strip{border-top:1px solid rgba(var(--gold-rgb),.15);border-bottom:1px solid rgba(var(--gold-rgb),.15);padding:52px 0;background:rgba(var(--gold-rgb),.04)}
.cta-inner{display:grid;grid-template-columns:1fr auto;align-items:center;gap:32px}
.cta-strip h3{font-size:clamp(1.2rem,2.5vw,1.65rem);font-weight:800;color:var(--wht);letter-spacing:-.025em;margin-bottom:6px}
.cta-strip p{font-size:.88rem;color:var(--txt2)}

/* ════════════════════════
   COMPARATIVA
════════════════════════ */
#comparativa{border-top:1px solid var(--brd)}
.cmp-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:52px}
.cmp-col{border-radius:var(--rl);padding:clamp(24px,3.5vw,36px);border:1px solid var(--brd)}
.cmp-col.bad{background:rgba(224,92,92,.03);border-color:rgba(224,92,92,.18)}
.cmp-col.good{background:rgba(var(--gold-rgb),.04);border-color:rgba(var(--gold-rgb),.22)}
.cmp-head{font-size:.68rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;font-family:var(--mono);margin-bottom:22px;display:flex;align-items:center;gap:8px}
.cmp-col.bad .cmp-head{color:#e05c5c}
.cmp-col.good .cmp-head{color:var(--gold)}
.cmp-dot-bad{width:6px;height:6px;border-radius:50%;background:#e05c5c;flex-shrink:0}
.cmp-dot-good{width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0}
.cmp-items{display:flex;flex-direction:column;gap:14px}
.cmp-row{display:flex;align-items:flex-start;gap:12px;font-size:.85rem;color:var(--txt2);line-height:1.6}
.cmp-mark{width:20px;height:20px;border-radius:4px;display:grid;place-items:center;flex-shrink:0;margin-top:1px}
.bad-mark{background:rgba(224,92,92,.12)}
.bad-mark svg{stroke:#e05c5c;stroke-width:2.5;fill:none;width:10px;height:10px}
.good-mark{background:rgba(var(--gold-rgb),.12)}
.good-mark svg{stroke:var(--gold);stroke-width:2.5;fill:none;width:14px;height:14px}

/* ════════════════════════
   CONTACTO
════════════════════════ */
#contacto{background:var(--bg2);border-top:1px solid var(--brd)}
.con-grid{display:grid;grid-template-columns:44fr 56fr;gap:clamp(48px,7vw,80px);align-items:start}
.con-links{display:flex;flex-direction:column;gap:8px;margin-top:24px;list-style:none}
.con-link{display:flex;align-items:center;gap:14px;font-size:.875rem;color:var(--txt2);padding:12px 16px;background:var(--card);border:1px solid var(--brd);border-radius:var(--rm);transition:all var(--dur)}
.con-link:hover{border-color:rgba(var(--gold-rgb),.3);color:var(--wht);transform:translateX(4px)}
.con-ico{width:34px;height:34px;flex-shrink:0;background:rgba(var(--gold-rgb),.1);border-radius:var(--r);display:grid;place-items:center}
.con-ico svg{width:15px;height:15px;stroke:var(--gold);stroke-width:1.8;fill:none}
.form-box{background:var(--card);border:1px solid var(--brd);border-radius:var(--rxl);padding:clamp(24px,4vw,40px);position:relative;overflow:hidden}
.form-box::after{content:'';position:absolute;bottom:-60px;right:-60px;width:200px;height:200px;background:radial-gradient(circle,rgba(var(--gold-rgb),.07),transparent 65%);pointer-events:none}
.form-box form{display:flex;flex-direction:column;gap:14px}
.form-field{display:flex;flex-direction:column;gap:7px}
.form-label{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--txt3);font-family:var(--mono)}
.form-input,.form-textarea,.wpcf7-text,.wpcf7-email,.wpcf7-tel,.wpcf7-textarea{
  width:100%;background:var(--bg2);border:1px solid var(--brd);border-radius:var(--rm);
  color:var(--txt);font-family:var(--font);font-size:.875rem;
  padding:.65rem .95rem;outline:none;
  transition:border-color var(--dur),box-shadow var(--dur);
  appearance:none;
}
.form-input::placeholder,.form-textarea::placeholder,
.wpcf7-text::placeholder,.wpcf7-email::placeholder,
.wpcf7-tel::placeholder,.wpcf7-textarea::placeholder{color:var(--txt3)}
.form-input:focus,.form-textarea:focus,
.wpcf7-text:focus,.wpcf7-email:focus,
.wpcf7-tel:focus,.wpcf7-textarea:focus{
  border-color:rgba(var(--gold-rgb),.5);
  box-shadow:0 0 0 3px rgba(var(--gold-rgb),.07);
}
.form-textarea,.wpcf7-textarea{min-height:108px;resize:vertical}
.wpcf7-submit,.form-box input[type="submit"]{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--gold);color:#0d0c0b;
  font-size:.85rem;font-weight:800;font-family:var(--font);
  padding:.72rem 1.8rem;border-radius:var(--pill);
  border:1.5px solid var(--gold);
  cursor:pointer;transition:all var(--dur);
}
.wpcf7-submit:hover,.form-box input[type="submit"]:hover{
  background:var(--gold-d);border-color:var(--gold-d);
  transform:translateY(-2px);box-shadow:0 10px 30px rgba(var(--gold-rgb),.3);
}
.wpcf7-not-valid-tip{color:#e05c5c;font-size:.75rem;margin-top:3px}
.wpcf7-response-output{margin-top:10px!important;border-radius:var(--rm)!important;padding:10px 14px!important;font-size:.8rem!important}

/* ════════════════════════
   FOOTER
════════════════════════ */
#footer{border-top:1px solid var(--brd);padding-block:clamp(52px,7vw,72px) clamp(20px,3vw,28px)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:clamp(24px,5vw,64px);margin-bottom:clamp(40px,5vw,52px)}
.footer-blurb{font-size:.82rem;color:var(--txt3);margin-top:10px;max-width:220px;line-height:1.7}
.footer-col-h{font-size:.63rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--txt3);font-family:var(--mono);margin-bottom:14px}
.footer-col a,.footer-col span{display:block;font-size:.82rem;color:var(--txt3);margin-bottom:9px;transition:color var(--dur)}
.footer-col a:hover{color:var(--txt)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid var(--brd);flex-wrap:wrap;gap:8px}
.footer-copy,.footer-credit{font-size:.72rem;color:var(--txt3)}
.footer-credit a{color:var(--gold)}

/* ════════════════════════
   PAGE INTERIOR
════════════════════════ */
.page-content{padding-top:calc(var(--hdr) + clamp(40px,5vw,64px));padding-bottom:clamp(60px,8vw,100px)}

/* ════════════════════════
   RESPONSIVE
════════════════════════ */
@media(max-width:1024px){
  #hero{grid-template-columns:1fr}
  .hero-right{display:none}
  .hero-left{padding-top:calc(var(--hdr) + 40px);padding-right:clamp(20px,5vw,64px);min-height:100dvh}
  .hero-h1{font-size:clamp(2.4rem,7vw,3.6rem)}
}
@media(max-width:768px){
  .nav{
    position:fixed;top:0;right:-100%;width:min(280px,84vw);height:100dvh;
    background:var(--bg2);border-left:1px solid var(--brd);
    padding:calc(var(--hdr) + 28px) 24px 28px;
    transition:right .3s var(--ease);z-index:895;
    flex-direction:column;align-items:flex-start;gap:4px;margin-left:0;
  }
  .nav.open{right:0}
  .nav a{font-size:.95rem;color:var(--txt);padding:9px 14px}
  .nav-bg{display:none}
  .hdr-btn{display:none}
  .burger{display:flex}
  .nos-inner,
  .con-grid,
  .cmp-grid{grid-template-columns:1fr}
  .svc-item{grid-template-columns:56px 1fr}
  .svc-tags{display:none}
  .plans-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;text-align:center}
  .cta-inner{grid-template-columns:1fr;gap:20px}
  .svc-header{grid-template-columns:1fr}
  .svc-header .btn-o{display:none}
  .hero-stats{flex-wrap:wrap;gap:20px}
  .stat{border-right:none;padding-right:0;margin-right:0}
  .cta-strip .btn-p{width:100%;justify-content:center}
}
