/* =====================================================================
   Plataforma Cercas · estilo industrial (ink + ámbar) · responsive
   ===================================================================== */
:root{
  --ink:#15181C; --ink2:#1d2127; --ink3:#262b32;
  --paper:#F4F5F2; --card:#FFFFFF;
  --amber:#E2952A; --amber-d:#C77E16; --amber-soft:#FBF1E1;
  --steel:#586269; --steel2:#8A949B; --line:#E2E4DF; --line-d:#33383F;
  --good:#2F8F5B; --radius:14px;
  --shadow:0 24px 60px -30px rgba(21,24,28,.5);
  --maxw:1180px;
  --f-disp:"Archivo",system-ui,sans-serif; --f-body:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--f-body);background:var(--paper);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
h1,h2,h3{font-family:var(--f-disp);line-height:1.05;letter-spacing:-.02em}
section{padding:84px 24px}
.kicker{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--steel2)}
.kicker.amber{color:var(--amber-d)}
.kicker.center{display:block;text-align:center}
h2{font-size:clamp(26px,4vw,42px);font-weight:800;margin:10px 0 16px}
.center{text-align:center}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--f-disp);font-weight:700;font-size:15px;
  letter-spacing:.02em;padding:14px 26px;border-radius:8px;text-decoration:none;cursor:pointer;border:none;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease}
.btn:hover{transform:translateY(-2px)}
.btn-sm{padding:9px 16px;font-size:13px}
.btn-block{width:100%;justify-content:center;font-size:16px;padding:16px}
.btn-amber{background:linear-gradient(180deg,var(--amber),var(--amber-d));color:#fff;box-shadow:0 12px 26px -10px rgba(199,126,22,.7)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-ghost-dark{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  gap:20px;padding:14px 28px;background:rgba(21,24,28,.86);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line-d)}
.logo{display:flex;align-items:center;gap:10px;color:#fff;font-family:var(--f-disp);font-weight:900;font-size:19px;text-decoration:none;letter-spacing:-.02em}
.logo-mark{width:22px;height:22px;background:
   repeating-linear-gradient(45deg,var(--amber) 0 3px,transparent 3px 7px),
   repeating-linear-gradient(-45deg,var(--amber) 0 3px,transparent 3px 7px);
   border:1.5px solid var(--amber);border-radius:5px;opacity:.95}
.nav-links{display:flex;gap:26px}
.nav-links a{color:#c7ccd1;text-decoration:none;font-size:14px;font-weight:500}
.nav-links a:hover{color:#fff}
.nav-right{display:flex;align-items:center;gap:14px}
.lang-toggle{color:#fff;text-decoration:none;font-size:12px;font-weight:700;letter-spacing:.1em;border:1px solid var(--line-d);padding:7px 11px;border-radius:6px}
.lang-toggle span{color:var(--amber)}

/* ---------- HERO ---------- */
.hero{position:relative;background:radial-gradient(120% 120% at 80% 0%,#222831 0%,var(--ink) 55%);
  color:#fff;padding:0;overflow:hidden;min-height:88vh;display:flex;align-items:center}
.hero-mesh{position:absolute;inset:0;opacity:.18;
  background-image:repeating-linear-gradient(45deg,#fff 0 1px,transparent 1px 26px),
                   repeating-linear-gradient(-45deg,#fff 0 1px,transparent 1px 26px);
  background-size:37px 37px;animation:meshPan 30s linear infinite;mask-image:linear-gradient(180deg,#000,transparent 90%)}
@keyframes meshPan{to{background-position:370px 0,-370px 0}}
.hero-glow{position:absolute;top:-30%;right:-10%;width:60vw;height:60vw;border-radius:50%;
  background:radial-gradient(circle,rgba(226,149,42,.30),transparent 60%);filter:blur(20px);animation:floaty 9s ease-in-out infinite alternate}
@keyframes floaty{to{transform:translateY(40px) scale(1.05)}}
.hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;width:100%;padding:120px 24px 90px;
  display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
.hero .kicker{color:#f0c886}
.hero-title{font-size:clamp(36px,6vw,68px);font-weight:900;margin:16px 0 18px;
  background:linear-gradient(180deg,#fff,#cdd3d9);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{font-size:clamp(16px,2vw,19px);color:#c0c6cc;max-width:54ch}
.hero-cta{display:flex;gap:14px;margin:30px 0 36px;flex-wrap:wrap}
.hero-stats{display:flex;gap:34px;border-top:1px solid var(--line-d);padding-top:24px}
.hero-stats b{font-family:var(--f-disp);font-size:30px;font-weight:900;color:var(--amber);display:block;line-height:1}
.hero-stats span{font-size:12.5px;color:#9aa3aa}
/* hero photo */
.hero-photo{position:relative}
.photo-frame{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid rgba(255,255,255,.14);
  box-shadow:var(--shadow);aspect-ratio:4/5;background:#0e1115}
.photo-frame img{width:100%;height:100%;object-fit:cover}
.photo-frame img.ph,.g-item img.ph{display:block;width:100%;height:100%;background:
   repeating-linear-gradient(45deg,#202833 0 14px,#1a212a 14px 28px)}
.photo-frame img.ph::after{content:""}
.photo-tag{position:absolute;left:10px;bottom:10px;font-size:11px;font-weight:600;color:#cbd2d8;
  background:rgba(0,0,0,.55);padding:5px 9px;border-radius:6px;font-family:var(--f-body);backdrop-filter:blur(4px)}
.hero-badge{position:absolute;left:-18px;bottom:30px;background:#fff;color:var(--ink);border-radius:12px;
  padding:12px 16px;box-shadow:var(--shadow);display:flex;align-items:center;gap:10px}
.hero-badge b{font-family:var(--f-disp);font-size:26px;color:var(--amber-d)}
.hero-badge span{font-size:12px;font-weight:600;max-width:9ch;line-height:1.2}
.scroll-cue{position:absolute;left:50%;bottom:24px;width:24px;height:38px;border:2px solid rgba(255,255,255,.4);border-radius:14px;z-index:2}
.scroll-cue::after{content:"";position:absolute;left:50%;top:7px;width:4px;height:7px;border-radius:3px;background:var(--amber);transform:translateX(-50%);animation:cue 1.4s ease-in-out infinite}
@keyframes cue{50%{transform:translate(-50%,12px);opacity:.4}}

/* ---------- marquee ---------- */
.marquee{background:var(--amber);color:var(--ink);overflow:hidden;padding:13px 0;border-top:3px solid var(--ink);border-bottom:3px solid var(--ink)}
.marquee-track{display:inline-flex;align-items:center;gap:22px;white-space:nowrap;animation:scroll 28s linear infinite;font-family:var(--f-disp);font-weight:800;letter-spacing:.06em;font-size:14px}
.marquee .dot{opacity:.5}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- about ---------- */
.about{background:var(--card)}
.about-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:center}
.photo-frame.tall{aspect-ratio:3/4;border:1px solid var(--line)}
.about-copy p{color:var(--steel);margin-bottom:18px;font-size:16.5px}
.ticks{list-style:none;margin:0 0 26px;display:flex;flex-direction:column;gap:12px}
.ticks li{position:relative;padding-left:34px;font-weight:500}
.ticks li::before{content:"✓";position:absolute;left:0;top:-1px;width:22px;height:22px;border-radius:50%;
  background:var(--amber-soft);color:var(--amber-d);font-weight:800;font-size:13px;display:grid;place-items:center}

/* ---------- video ---------- */
.video{background:var(--paper);text-align:center}
.video-frame{max-width:920px;margin:26px auto 12px;aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);border:1px solid var(--line);background:#000}
.video-frame iframe{width:100%;height:100%;border:0}
.video-note{color:var(--steel2);font-size:13px}

/* ---------- gallery ---------- */
.gallery{max-width:var(--maxw);margin:0 auto}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:26px}
.g-item{position:relative;aspect-ratio:4/3;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:#0e1115}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.g-item:hover img{transform:scale(1.07)}

/* ---------- BOOK ---------- */
.book{background:linear-gradient(180deg,var(--ink),#0f1318);color:#fff}
.book-head{max-width:760px;margin:0 auto 40px;text-align:center}
.book-head p{color:#aab1b8;margin-top:6px}
.book-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:380px 1fr;gap:28px;align-items:start}

/* calendar */
.cal-card{background:#fff;color:var(--ink);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);position:sticky;top:84px}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.cal-head strong{font-family:var(--f-disp);font-size:17px}
.cal-head button{width:34px;height:34px;border:1px solid var(--line);background:#fff;border-radius:8px;font-size:20px;cursor:pointer;color:var(--ink);line-height:1}
.cal-head button:hover{background:var(--paper)}
.cal-dow,.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-dow span{text-align:center;font-size:11px;font-weight:700;color:var(--steel2);padding:4px 0}
.cal-grid{margin-top:6px}
.cal-cell{aspect-ratio:1;border:1px solid transparent;border-radius:9px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-size:14px;font-weight:600;cursor:pointer;position:relative;background:var(--paper);color:var(--ink)}
.cal-cell .dotleft{position:absolute;bottom:5px;width:5px;height:5px;border-radius:50%;background:var(--good)}
.cal-cell.empty{background:transparent;cursor:default}
.cal-cell.disabled{color:#c5cad0;background:#fafbf9;cursor:not-allowed}
.cal-cell.full{color:#c97b7b;background:#fbeeee;cursor:not-allowed}
.cal-cell.full .dotleft{background:#d98c8c}
.cal-cell.sel{background:var(--amber);color:#fff;border-color:var(--amber-d)}
.cal-cell.sel .dotleft{background:#fff}
.cal-cell:not(.disabled):not(.full):not(.empty):hover{border-color:var(--amber);background:var(--amber-soft)}
.cal-legend{display:flex;gap:18px;margin-top:14px;font-size:12px;color:var(--steel)}
.cal-legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:6px;vertical-align:middle}
.lg-free{background:var(--good)} .lg-full{background:#d98c8c}

/* form */
.req-form{background:#fff;color:var(--ink);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.field{margin-bottom:16px}
.field>label{display:block;font-size:13px;font-weight:600;color:var(--steel);margin-bottom:7px}
.field input,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:9px;padding:12px 13px;font:inherit;font-size:15px;color:var(--ink);background:#fcfcfb;transition:border .15s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--amber);background:#fff}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.seg{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.seg-opt{position:relative;cursor:pointer}
.seg-opt input{position:absolute;opacity:0}
.seg-opt span{display:block;text-align:center;padding:12px;border:1.5px solid var(--line);border-radius:9px;font-weight:600;font-size:14px;transition:.15s}
.seg-opt input:checked+span{background:var(--ink);color:#fff;border-color:var(--ink)}
.slots{display:flex;flex-wrap:wrap;gap:8px;min-height:46px}
.slots-hint{color:var(--steel2);font-size:14px;align-self:center}
.slot{padding:9px 14px;border:1.5px solid var(--line);border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;background:#fff;font-family:var(--f-body)}
.slot:hover{border-color:var(--amber)}
.slot.sel{background:var(--amber);border-color:var(--amber-d);color:#fff}
.slot.taken{color:#c5cad0;background:#fafbf9;cursor:not-allowed;text-decoration:line-through}
.file-drop{display:flex;align-items:center;gap:14px;border:1.5px dashed var(--line);border-radius:10px;padding:14px;cursor:pointer;position:relative;transition:.15s}
.file-drop:hover{border-color:var(--amber);background:var(--amber-soft)}
.file-ico{width:40px;height:40px;border-radius:8px;background:var(--ink);color:#fff;display:grid;place-items:center;font-size:24px;flex:0 0 40px}
.file-txt{font-size:13px;color:var(--steel)}
.file-txt small{color:var(--steel2)}
#filePrev{display:none;width:54px;height:54px;border-radius:8px;object-fit:cover;margin-left:auto}
#filePrev.show{display:block}
.form-msg{font-size:14px;margin-top:10px;font-weight:600}
.form-msg.err{color:#c0392b}
.btn[disabled]{opacity:.6;cursor:wait;transform:none}

.ok-box{text-align:center;padding:18px 6px}
.ok-check{width:64px;height:64px;border-radius:50%;background:var(--good);color:#fff;font-size:34px;display:grid;place-items:center;margin:0 auto 14px}
.ok-box h3{font-size:24px;margin-bottom:6px}
.ok-box p{color:var(--steel);font-size:15px}
.ok-ref{font-family:var(--f-disp);font-weight:800;font-size:22px;letter-spacing:.05em;color:var(--amber-d);background:var(--amber-soft);border-radius:10px;padding:12px;margin:14px 0}

/* ---------- contact ---------- */
.contact{background:var(--card)}
.contact-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.contact-item{margin:14px 0}
.contact-item b{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--steel2)}
.contact-item p{font-size:17px;font-weight:500}
.contact .btn{margin-top:18px}
.map-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;
  background:linear-gradient(135deg,var(--ink),#222831);color:#fff;border-radius:var(--radius);min-height:280px;
  text-decoration:none;box-shadow:var(--shadow);position:relative;overflow:hidden}
.map-card::before{content:"";position:absolute;inset:0;opacity:.12;
  background-image:repeating-linear-gradient(45deg,#fff 0 1px,transparent 1px 24px),repeating-linear-gradient(-45deg,#fff 0 1px,transparent 1px 24px)}
.map-pin{font-size:48px;position:relative}
.map-card span{position:relative;font-weight:600}.map-card small{position:relative;color:var(--amber)}

/* ---------- footer ---------- */
.foot{background:var(--ink);color:#9aa3aa;text-align:center;padding:26px;display:flex;flex-direction:column;gap:6px;font-size:13px}
.foot-by b{color:var(--amber)}
.wa-float{position:fixed;right:18px;bottom:18px;z-index:60;width:56px;height:56px;border-radius:50%;background:#25D366;
  display:grid;place-items:center;font-size:26px;box-shadow:0 12px 26px -8px rgba(0,0,0,.5);text-decoration:none}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .hero-inner{grid-template-columns:1fr;gap:36px;padding-top:90px}
  .hero-photo{max-width:420px}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:30px}
  .about-media{max-width:440px}
  .book-grid{grid-template-columns:1fr}
  .cal-card{position:static}
  .nav-links{display:none}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
  section{padding:60px 18px}
  .hero-stats{gap:20px;flex-wrap:wrap}
  .row2{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr;gap:10px}
  .hero-badge{left:8px}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important}}

/* ============ Border Fence TX · personalización ============ */
/* logo en nav */
.logo{gap:10px}
.logo-img{width:38px;height:38px;border-radius:9px;overflow:hidden;flex:0 0 38px;
  background:#000;border:1px solid rgba(226,149,42,.45);display:grid;place-items:center}
.logo-img img{width:100%;height:100%;object-fit:contain}
.logo-img.noimg{background:
   repeating-linear-gradient(45deg,var(--amber) 0 3px,transparent 3px 7px),
   repeating-linear-gradient(-45deg,var(--amber) 0 3px,transparent 3px 7px)}
.logo-img.noimg img{display:none}
.logo-word{font-family:var(--f-disp);font-weight:900;font-size:17px;color:#fff;letter-spacing:-.02em}
.logo-word i{color:var(--amber);font-style:normal}
.logo-img.sm{width:30px;height:30px;flex:0 0 30px;border-radius:7px}

/* instagram en nav */
.ig-link{display:grid;place-items:center;width:38px;height:38px;border-radius:9px;color:#fff;
  border:1px solid var(--line-d);text-decoration:none;transition:.15s}
.ig-link:hover{background:linear-gradient(45deg,#f09433,#e6683c,#bc1888);border-color:transparent}

/* hero points (honestos, sin cifras inventadas) */
.hero-points{display:flex;flex-wrap:wrap;gap:14px 26px;border-top:1px solid var(--line-d);padding-top:22px}
.hero-points div{display:flex;align-items:center;gap:9px;font-weight:600;font-size:15px;color:#e7eaed}
.hp-ico{width:24px;height:24px;border-radius:50%;background:rgba(226,149,42,.16);color:var(--amber);
  display:grid;place-items:center;font-size:13px;flex:0 0 24px}

/* etiquetas de servicio siempre visibles */
.g-item{cursor:default}
.g-label{position:absolute;left:0;right:0;bottom:0;padding:26px 14px 12px;color:#fff;font-family:var(--f-disp);
  font-weight:800;font-size:16px;letter-spacing:.01em;
  background:linear-gradient(180deg,transparent,rgba(10,12,15,.86));z-index:2}
.g-item::after{content:"";position:absolute;left:12px;bottom:40px;width:26px;height:3px;background:var(--amber);z-index:3;opacity:0;transition:.3s}
.g-item:hover::after{opacity:1}

/* contacto */
.contact-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.c-link{color:var(--amber-d);text-decoration:none;font-weight:600}
.btn-ig{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#bc1888);color:#fff}

/* footer brand */
.foot-brand{display:flex;align-items:center;gap:10px;justify-content:center;margin-bottom:2px}
.foot-brand b{color:#fff;font-family:var(--f-disp)}

/* botón flotante de llamada */
.call-float{position:fixed;right:18px;bottom:18px;z-index:60;width:58px;height:58px;border-radius:50%;
  background:linear-gradient(180deg,var(--amber),var(--amber-d));display:grid;place-items:center;font-size:26px;
  box-shadow:0 14px 30px -8px rgba(199,126,22,.7);text-decoration:none;animation:ring 2.6s ease-in-out infinite}
.call-float span{filter:grayscale(0)}
@keyframes ring{0%,100%{transform:rotate(0)}3%{transform:rotate(12deg)}6%{transform:rotate(-12deg)}9%{transform:rotate(8deg)}12%{transform:rotate(0)}}

@media (max-width:560px){ .logo-word{font-size:16px} .logo-img{width:38px;height:38px;flex-basis:38px} }
