/* ============================================================
   TécniKas — mobile-first, opinionated, not-AI-generated
   ============================================================ */

/* --- Reset & base --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
    font-family:'DM Sans',system-ui,sans-serif;
    color:#1a1a1a;
    background:#fafaf7;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
address{font-style:normal}

/* --- Typography --- */
h1,h2,h3{font-family:'Fraunces',Georgia,serif;font-weight:700;line-height:1.15}
h1{font-size:clamp(2rem,6vw,3.6rem);letter-spacing:-.02em}
h2{font-size:clamp(1.6rem,4vw,2.6rem);letter-spacing:-.01em}
h3{font-size:1.15rem;font-weight:600}
h1 em,h2 em,.nav__logo em,.footer__logo em{
    font-style:normal;
    color:#d35400;
}
p{max-width:56ch}

/* --- Layout --- */
.contenedor{
    width:min(92%,1120px);
    margin:0 auto;
}

/* --- Buttons --- */
.btn{
    display:inline-flex;align-items:center;gap:.5rem;
    padding:.75rem 1.5rem;
    border-radius:6px;
    font-weight:500;font-size:.95rem;
    transition:transform .15s,box-shadow .15s;
    cursor:pointer;border:none;
}
.btn:active{transform:scale(.97)}
.btn--whatsapp{background:#25d366;color:#fff}
.btn--whatsapp:hover{box-shadow:0 4px 18px rgba(37,211,102,.35)}
.btn--outline{border:2px solid #1a1a1a;background:transparent;color:#1a1a1a}
.btn--outline:hover{background:#1a1a1a;color:#fff}
.btn--grande{padding:1rem 2rem;font-size:1.05rem}

/* ============================================================
   NAV
   ============================================================ */
.nav{
    position:fixed;top:0;left:0;right:0;z-index:100;
    background:rgba(250,250,247,.92);
    backdrop-filter:blur(10px);
    border-bottom:1px solid rgba(0,0,0,.06);
}
.nav__inner{
    display:flex;align-items:center;justify-content:space-between;
    width:min(92%,1120px);margin:0 auto;
    height:56px;
}
.nav__logo{font-family:'Fraunces',Georgia,serif;font-size:1.25rem;font-weight:700}
.nav__links{
    display:none;
    position:fixed;top:56px;left:0;right:0;bottom:0;
    background:rgba(250,250,247,.98);
    flex-direction:column;align-items:center;justify-content:center;gap:2rem;
    font-size:1.2rem;
}
.nav__links.open{display:flex}
.nav__links a{transition:color .15s}
.nav__links a:hover{color:#d35400}
.nav__cta{
    background:#d35400;color:#fff !important;
    padding:.5rem 1.2rem;border-radius:6px;
    font-weight:600;font-size:1rem !important;
    letter-spacing:.02em;
}
.nav__burger{
    display:flex;flex-direction:column;gap:5px;
    background:none;border:none;cursor:pointer;padding:4px;
}
.nav__burger span{
    width:24px;height:2px;background:#1a1a1a;
    transition:transform .2s,opacity .2s;
    border-radius:2px;
}
.nav__burger.open span:first-child{transform:translateY(3.5px) rotate(45deg)}
.nav__burger.open span:last-child{transform:translateY(-3.5px) rotate(-45deg)}

@media(min-width:768px){
    .nav__links{
        display:flex;position:static;
        flex-direction:row;gap:1.8rem;
        background:none;font-size:.9rem;
    }
    .nav__burger{display:none}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
    position:relative;
    min-height:100svh;
    display:flex;align-items:flex-end;
    padding:0 0 3rem;
    background:
        linear-gradient(135deg, rgba(40,30,20,.15) 0%, transparent 50%),
        url('../images/hero.jpg') center/cover no-repeat;
    background-color:#3a3028;
    overflow:hidden;
}
.hero__overlay{
    position:absolute;inset:0;
    background:linear-gradient(
        to top,
        rgba(26,26,26,.88) 0%,
        rgba(26,26,26,.5) 40%,
        rgba(26,26,26,.15) 100%
    );
}
.hero__content{
    position:relative;z-index:2;
    width:min(92%,1120px);margin:0 auto;
    color:#fff;
}
.hero__eyebrow{
    font-size:.85rem;
    text-transform:uppercase;
    letter-spacing:.15em;
    opacity:.7;
    margin-bottom:.75rem;
}
.hero h1{margin-bottom:1rem;color:#fff}
.hero__sub{
    font-size:1.05rem;
    opacity:.85;
    margin-bottom:1.5rem;
    max-width:48ch;
}
.hero__actions{display:flex;flex-wrap:wrap;gap:.75rem}
.hero .btn--outline{border-color:rgba(255,255,255,.5);color:#fff}
.hero .btn--outline:hover{background:rgba(255,255,255,.15);border-color:#fff}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.strip{
    background:#1a1a1a;color:#fff;
    padding:1rem 0;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
}
.strip__inner{
    display:flex;gap:2rem;
    width:max-content;
    padding:0 1rem;
    margin:0 auto;
}
.strip__item{
    white-space:nowrap;
    font-size:.9rem;
    opacity:.8;
}
.strip__item strong{
    color:#d35400;
    font-size:1.1rem;
    margin-right:.25rem;
}
@media(min-width:768px){
    .strip__inner{
        width:min(92%,1120px);
        justify-content:space-between;
    }
}

/* ============================================================
   SERVICIOS
   ============================================================ */
.servicios{padding:4rem 0 3rem}
.titulo{margin-bottom:.5rem}
.titulo__sub{color:#555;margin-bottom:2rem}

.servicios__grid{
    display:grid;
    grid-template-columns:1fr;
    gap:1rem;
}
.tarjeta{
    background:#fff;
    border:1px solid rgba(0,0,0,.07);
    border-radius:10px;
    padding:1.5rem;
    transition:box-shadow .2s;
}
.tarjeta:hover{box-shadow:0 6px 24px rgba(0,0,0,.07)}
.tarjeta__icono{
    color:#d35400;
    margin-bottom:.75rem;
}
.tarjeta h3{margin-bottom:.4rem}
.tarjeta p{font-size:.92rem;color:#444}
.tarjeta--grande{
    border-left:4px solid #d35400;
}

@media(min-width:600px){
    .servicios__grid{
        grid-template-columns:1fr 1fr;
    }
    .tarjeta--grande{
        grid-column:1 / -1;
    }
}
@media(min-width:900px){
    .servicios__grid{
        grid-template-columns:repeat(3,1fr);
    }
    .tarjeta--grande{
        grid-column:1 / 2;
        grid-row:1 / 3;
        display:flex;flex-direction:column;justify-content:center;
    }
}

.servicios__nota{
    margin-top:1.5rem;
    font-size:.9rem;
    color:#777;
}

/* ============================================================
   PROCESO
   ============================================================ */
.proceso{
    padding:4rem 0;
    background:#f0ede6;
}
.proceso__lista{
    margin-top:2rem;
    display:flex;flex-direction:column;gap:1.5rem;
    counter-reset:none;
}
.proceso__paso{
    display:flex;gap:1rem;align-items:flex-start;
}
.proceso__num{
    flex-shrink:0;
    width:40px;height:40px;
    display:grid;place-items:center;
    background:#d35400;color:#fff;
    font-family:'Fraunces',Georgia,serif;
    font-weight:700;font-size:1.1rem;
    border-radius:50%;
}
.proceso__paso h3{margin-bottom:.2rem}
.proceso__paso p{font-size:.92rem;color:#555}

@media(min-width:768px){
    .proceso__lista{
        flex-direction:row;
        gap:0;
    }
    .proceso__paso{
        flex:1;
        flex-direction:column;
        align-items:center;
        text-align:center;
        padding:0 1rem;
        position:relative;
    }
    .proceso__paso:not(:last-child)::after{
        content:'';
        position:absolute;
        top:20px;
        left:calc(50% + 28px);
        width:calc(100% - 56px);
        height:2px;
        background:#d35400;
        opacity:.3;
    }
    .proceso__num{margin-bottom:.75rem}
}

/* ============================================================
   TARIFAS
   ============================================================ */
.tarifas{padding:4rem 0}
.tarifas__tabla{
    margin-top:1.5rem;
    border:1px solid rgba(0,0,0,.08);
    border-radius:10px;
    overflow:hidden;
    background:#fff;
}
.tarifas__fila{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:.5rem;
    padding:1rem 1.25rem;
    font-size:.92rem;
    border-bottom:1px solid rgba(0,0,0,.05);
}
.tarifas__fila:last-child{border-bottom:none}
.tarifas__fila span:nth-child(2){display:none}
.tarifas__fila span:last-child{text-align:right;font-weight:600;color:#d35400}
.tarifas__fila--cabecera{
    background:#1a1a1a;color:#fff;
    font-weight:600;font-size:.82rem;
    text-transform:uppercase;letter-spacing:.06em;
}
.tarifas__fila--cabecera span:last-child{color:#fff}

@media(min-width:768px){
    .tarifas__fila{grid-template-columns:1fr 2fr 1fr}
    .tarifas__fila span:nth-child(2){display:block;color:#666}
}

.tarifas__nota{
    margin-top:1rem;
    font-size:.82rem;
    color:#888;
}

/* ============================================================
   ZONA
   ============================================================ */
.zona{
    padding:4rem 0;
    background:#f0ede6;
}
.zona__grid{
    display:flex;flex-direction:column;gap:2rem;
}
.zona__texto p{color:#555;margin-bottom:1rem}
.zona__texto address{
    margin-top:1.5rem;
    line-height:1.8;
}
.zona__texto a{color:#d35400;text-decoration:underline;text-underline-offset:2px}
.zona__mapa{
    border-radius:10px;overflow:hidden;
    aspect-ratio:16/10;
    border:1px solid rgba(0,0,0,.07);
}
.zona__mapa iframe{width:100%;height:100%;border:0}

@media(min-width:768px){
    .zona__grid{
        flex-direction:row;
        align-items:start;
    }
    .zona__texto{flex:1}
    .zona__mapa{flex:1;aspect-ratio:4/3}
}

/* ============================================================
   CTA
   ============================================================ */
.cta{
    padding:4rem 0;
    text-align:center;
}
.cta h2{margin-bottom:.5rem}
.cta p{color:#555;margin:0 auto 1.5rem;max-width:42ch}
.cta__botones{
    display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
    padding:2rem 0;
    border-top:1px solid rgba(0,0,0,.07);
}
.footer__inner{
    display:flex;flex-direction:column;align-items:center;gap:.5rem;
    text-align:center;
    font-size:.85rem;color:#888;
}
.footer__inner a{text-decoration:underline;text-underline-offset:2px}
.footer__inner a:hover{color:#d35400}
.footer__logo{font-family:'Fraunces',Georgia,serif;font-size:1.1rem;font-weight:700;color:#1a1a1a}

@media(min-width:768px){
    .footer__inner{flex-direction:row;justify-content:space-between}
}

/* ============================================================
   Utility: scrollbar hide for strip
   ============================================================ */
.strip::-webkit-scrollbar{display:none}
.strip{-ms-overflow-style:none;scrollbar-width:none}
