:root{
    --bg:#f5ead8;
    --bg-soft:#fff8ec;
    --bg-card:#fffaf1;
    --coffee:#3f2b1f;
    --coffee-2:#6d4b34;
    --muted:#8d735e;
    --gold:#c4922f;
    --gold-2:#e0b75a;
    --line:rgba(128,91,44,.20);
    --shadow:0 24px 70px rgba(77,48,24,.12);
    --radius:24px;
    --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    font-family:Manrope,Arial,sans-serif;
    background:linear-gradient(180deg,var(--bg-soft),var(--bg));
    color:var(--coffee);
    overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,textarea,select{font:inherit}
.section-container{width:min(var(--max),calc(100% - 36px));margin-inline:auto}
.section-block{padding:84px 0}
.eyebrow{display:inline-flex;align-items:center;gap:10px;color:var(--gold);font-weight:800;letter-spacing:.12em;text-transform:uppercase;font-size:.78rem}
.eyebrow:before{content:"";width:34px;height:1px;background:linear-gradient(90deg,var(--gold),transparent)}
.btn-primary,.btn-secondary,.btn-small,.nav-whatsapp,.cart-pill{
    border:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:800;border-radius:999px;transition:.22s ease;
}
.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#25170e;padding:14px 22px;box-shadow:0 14px 34px rgba(196,146,47,.25)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(196,146,47,.32)}
.btn-secondary{background:rgba(255,255,255,.58);border:1px solid var(--line);color:var(--coffee);padding:13px 20px}
.btn-secondary:hover{background:#fff;transform:translateY(-2px)}
.btn-small{background:var(--coffee);color:#fff8ec;padding:10px 15px;font-size:.9rem}
.btn-small:hover{background:var(--gold);color:#211409}
.text-link{font-weight:900;color:var(--gold);border-bottom:1px solid rgba(196,146,47,.4)}
.full{width:100%}
.site-navbar{position:sticky;top:0;z-index:50;background:rgba(255,248,236,.88);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}
.nav-shell{width:min(1240px,calc(100% - 26px));margin:auto;display:flex;align-items:center;justify-content:space-between;min-height:86px;gap:20px}
.brand-card{width:142px;background:rgba(255,255,255,.68);border:1px solid rgba(196,146,47,.22);border-radius:22px;padding:9px 12px;box-shadow:0 14px 30px rgba(72,44,23,.08)}
.brand-card img{width:100%;height:auto}
.desktop-nav{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.42);border:1px solid var(--line);border-radius:999px;padding:8px}
.desktop-nav a{padding:10px 16px;border-radius:999px;color:var(--coffee-2);font-weight:800;font-size:.93rem}
.desktop-nav a.active,.desktop-nav a:hover{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#27180d}
.nav-actions{display:flex;align-items:center;gap:10px}
.nav-whatsapp{background:#ffffffa8;border:1px solid var(--line);padding:11px 16px;color:var(--coffee)}
.cart-pill{background:var(--coffee);color:#fff7e8;padding:11px 14px}.cart-pill span{background:var(--gold);color:#25170e;border-radius:999px;min-width:24px;height:24px;display:grid;place-items:center;font-size:.78rem}
.menu-toggle{display:none;width:44px;height:44px;border-radius:14px;border:1px solid var(--line);background:#fff7e8;align-items:center;justify-content:center;flex-direction:column;gap:5px}.menu-toggle span{width:20px;height:2px;background:var(--coffee);display:block}
.mobile-panel{display:none;border-top:1px solid var(--line);padding:12px 18px 18px;background:rgba(255,248,236,.98)}.mobile-panel a{display:block;padding:13px 8px;font-weight:900;border-bottom:1px solid var(--line)}
.hero-section{position:relative;min-height:670px;display:grid;align-items:center;overflow:hidden}.hero-bg{position:absolute;inset:0;background:url('../img/banner/hero-optica-mira.webp') center/cover no-repeat}.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,248,236,.20),rgba(255,248,236,.02) 55%,rgba(255,248,236,.0))}.hero-content{position:relative;z-index:2}.hero-copy{max-width:560px;padding-top:100px}.hero-copy h1{font-family:'Playfair Display',serif;font-size:clamp(2.7rem,6vw,5.6rem);line-height:.92;margin:18px 0;color:var(--coffee);letter-spacing:-.05em}.hero-copy p{font-size:1.08rem;line-height:1.8;color:var(--coffee-2);max-width:520px}.hero-buttons{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.trust-strip{margin-top:-42px;position:relative;z-index:5;background:rgba(255,250,241,.92);backdrop-filter:blur(12px);border:1px solid rgba(196,146,47,.25);box-shadow:var(--shadow);border-radius:var(--radius);display:grid;grid-template-columns:repeat(4,1fr);overflow:hidden}.trust-strip div{padding:24px;border-right:1px solid var(--line)}.trust-strip div:last-child{border-right:0}.trust-strip strong{display:block;font-size:1rem}.trust-strip span{display:block;color:var(--muted);font-size:.9rem;margin-top:5px}
.section-heading{max-width:680px;margin-bottom:34px}.section-heading.horizontal{max-width:none;display:flex;align-items:end;justify-content:space-between;gap:20px}.section-heading h2,.page-hero h1,.cta-panel h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.5rem);line-height:1.03;margin:12px 0;color:var(--coffee);letter-spacing:-.03em}.section-heading p,.page-hero p,.cta-panel p{color:var(--muted);line-height:1.8;font-size:1.02rem}
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.service-card,.product-card,.contact-card,.success-box,.empty-cart,.checkout-form,.checkout-summary,.cart-summary,.cart-table-wrap,.product-detail-card,.info-panel{background:rgba(255,250,241,.82);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 18px 54px rgba(90,55,25,.08)}.service-card{padding:28px}.service-icon{display:grid;place-items:center;width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,rgba(196,146,47,.18),rgba(224,183,90,.08));color:var(--gold);font-size:1.7rem;margin-bottom:18px}.service-card h3{margin:0 0 10px;font-size:1.12rem}.service-card p{margin:0;color:var(--muted);line-height:1.65}
.featured-products{background:linear-gradient(180deg,rgba(255,248,236,.0),rgba(255,255,255,.38))}.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.product-card{overflow:hidden;display:flex;flex-direction:column}.product-image{height:210px;background:linear-gradient(145deg,#fff8ec,#ead8bd);display:grid;place-items:center;padding:22px}.product-image img{width:100%;height:100%;object-fit:contain}.product-info{padding:20px;display:flex;flex:1;flex-direction:column}.product-category{color:var(--gold);font-size:.77rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em}.product-info h3{margin:8px 0 10px;font-size:1.08rem}.product-info p{margin:0 0 18px;color:var(--muted);line-height:1.58;font-size:.92rem}.product-bottom{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:12px}.price-box span{display:block;color:var(--muted);text-decoration:line-through;font-size:.82rem}.price-box strong{font-size:1.15rem;color:var(--coffee)}
.cta-panel{padding:46px;background:linear-gradient(135deg,#fff8ec,#ead8bd);border:1px solid rgba(196,146,47,.25);border-radius:32px;display:flex;align-items:center;justify-content:space-between;gap:28px;margin-bottom:80px;box-shadow:var(--shadow)}
.inner-page{padding-bottom:80px}.page-hero{padding:70px 0 30px}.page-hero.compact{padding-top:54px}.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:26px}.filter-chip{border:1px solid var(--line);background:#fffaf1;color:var(--coffee-2);padding:10px 14px;border-radius:999px;font-weight:800}.filter-chip.active,.filter-chip:hover{background:var(--gold);color:#25170e}.contact-layout,.checkout-layout,.cart-panel,.product-detail-layout{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:start}.contact-card,.info-panel{padding:28px}.contact-list{display:grid;gap:14px;margin:22px 0}.contact-list div{padding:16px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.46)}.contact-list strong{display:block}.contact-list span{color:var(--muted)}
.cart-panel{grid-template-columns:1fr 340px}.cart-table-wrap{overflow:auto}.cart-table{width:100%;border-collapse:collapse;min-width:720px}.cart-table th,.cart-table td{padding:18px;border-bottom:1px solid var(--line);text-align:left}.cart-table th{font-size:.82rem;text-transform:uppercase;color:var(--gold);letter-spacing:.08em}.cart-product{display:flex;align-items:center;gap:14px}.cart-product img{width:72px;height:72px;object-fit:contain;border-radius:16px;background:#f4e6cd}.cart-product span{display:block;color:var(--muted);font-size:.88rem}.cart-table input{width:80px;padding:10px;border:1px solid var(--line);border-radius:12px;background:#fff}.cart-actions{display:flex;gap:12px;padding:18px}.link-button{background:none;border:0;color:var(--muted);font-weight:900;cursor:pointer}.cart-summary,.checkout-summary{padding:24px}.cart-summary div,.summary-item,.summary-total{display:flex;justify-content:space-between;gap:14px;border-bottom:1px solid var(--line);padding:13px 0}.cart-summary p,.checkout-summary p{color:var(--muted);line-height:1.65}.summary-total{font-size:1.12rem}.checkout-form{padding:26px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.checkout-form label{display:grid;gap:8px;margin-bottom:16px;color:var(--coffee);font-weight:900}.checkout-form input,.checkout-form select,.checkout-form textarea{border:1px solid var(--line);background:#fffaf1;border-radius:16px;padding:14px 15px;color:var(--coffee);outline:none}.checkout-form input:focus,.checkout-form textarea:focus,.checkout-form select:focus{border-color:var(--gold);box-shadow:0 0 0 4px rgba(196,146,47,.12)}.checkout-form small{color:var(--muted);font-weight:600}.error-box,.success-box{padding:22px;border-radius:20px}.error-box{background:#fff0e9;border:1px solid rgba(155,55,25,.24);color:#7b2d17}.success-box{padding:34px}.empty-cart{padding:34px;grid-column:1/-1}.product-detail-layout{grid-template-columns:.9fr 1.1fr}.product-detail-card{padding:26px}.product-detail-card img{width:100%;height:410px;object-fit:contain;background:linear-gradient(145deg,#fff8ec,#ead8bd);border-radius:22px}.product-detail-info h1{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.7rem);line-height:1;margin:8px 0 14px}.product-detail-info p{color:var(--muted);line-height:1.8}.detail-price{font-size:1.6rem;font-weight:900;margin:22px 0;color:var(--gold)}.qty-row{display:flex;gap:12px;align-items:center;margin:22px 0}.qty-row input{width:94px;padding:13px;border:1px solid var(--line);border-radius:14px;background:#fffaf1}.note-box{margin-top:18px;padding:16px;background:rgba(196,146,47,.08);border:1px solid rgba(196,146,47,.18);border-radius:18px;color:var(--coffee-2)}
.footer{background:#4b321f;color:#fff8ec;margin-top:60px}.footer-main{width:min(var(--max),calc(100% - 36px));margin:auto;display:grid;grid-template-columns:1.2fr repeat(3,1fr);gap:32px;padding:56px 0}.footer-logo{width:150px;background:#fffaf1;border-radius:22px;padding:10px;margin-bottom:16px}.footer p,.footer a{color:#f4ddba}.footer h3{color:var(--gold-2);margin:0 0 14px}.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:8px}.footer-bottom{border-top:1px solid rgba(255,255,255,.15);padding:18px 0;text-align:center;color:#f4ddba}.footer-bottom a{color:var(--gold-2);font-weight:900}.floating-whatsapp{position:fixed;right:18px;bottom:18px;z-index:60;background:#25d366;color:#fff;border-radius:999px;padding:14px 18px;font-weight:900;box-shadow:0 16px 36px rgba(0,0,0,.18)}
/* Compatibilidad con páginas internas */
.shop-layout{display:grid;grid-template-columns:260px 1fr;gap:24px;align-items:start}.shop-sidebar{position:sticky;top:110px;background:rgba(255,250,241,.86);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:0 18px 54px rgba(90,55,25,.08)}.shop-sidebar h2{font-size:1.1rem;margin:0 0 14px}.shop-sidebar a{display:block;padding:12px 14px;border-radius:14px;color:var(--coffee-2);font-weight:900}.shop-sidebar a.active,.shop-sidebar a:hover{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#25170e}.shop-grid{align-items:stretch}.product-detail{display:grid;grid-template-columns:.95fr 1.05fr;gap:28px;align-items:center;padding:72px 0}.product-detail-image,.product-detail-copy{background:rgba(255,250,241,.86);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 18px 54px rgba(90,55,25,.08)}.product-detail-image{padding:26px}.product-detail-image img{height:460px;width:100%;object-fit:contain;background:linear-gradient(145deg,#fff8ec,#ead8bd);border-radius:20px}.product-detail-copy{padding:34px}.product-detail-copy h1{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.6rem);line-height:1.02;margin:12px 0}.detail-price span{display:block;color:var(--muted);text-decoration:line-through;font-size:1rem}.detail-form{display:flex;align-items:end;gap:14px;flex-wrap:wrap;margin:24px 0}.detail-form label{font-weight:900;color:var(--coffee);display:grid;gap:8px}.detail-form input{width:96px;border:1px solid var(--line);background:#fffaf1;border-radius:15px;padding:13px}.notice{background:rgba(196,146,47,.10);border:1px solid rgba(196,146,47,.18);padding:16px;border-radius:18px}.contact-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:24px}.map-card{min-height:430px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:0 18px 54px rgba(90,55,25,.08)}.map-card iframe{width:100%;height:100%;min-height:430px;border:0}.site-footer{position:relative;background:linear-gradient(135deg,#5b3a23,#3e2818);color:#fff8ec;margin-top:70px;overflow:hidden}.footer-glow{position:absolute;inset:auto -10% -55% auto;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(224,183,90,.32),transparent 70%)}.footer-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.25fr repeat(3,1fr);gap:32px;padding:56px 0}.footer-logo-card{width:155px;background:#fffaf1;border-radius:22px;padding:10px;margin-bottom:16px}.footer-brand p,.footer-col p,.footer-col a{color:#f3dfc0;line-height:1.7}.footer-col{display:grid;align-content:start;gap:8px}.footer-col h3{color:var(--gold-2);margin:0 0 8px}.footer-cta{display:inline-flex;margin-top:10px;background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#25170e;padding:12px 18px;border-radius:999px;font-weight:900}.footer-bottom{position:relative;z-index:1;border-top:1px solid rgba(255,255,255,.14);display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;width:min(var(--max),calc(100% - 36px));margin:auto;padding:18px 0;color:#f3dfc0}.footer-bottom a{color:var(--gold-2);font-weight:900}.checkout-summary h2,.cart-summary h2{margin-top:0}
@media (max-width:820px){.shop-layout,.product-detail,.contact-grid{grid-template-columns:1fr}.shop-sidebar{position:static}.product-detail{padding-top:36px}.footer-grid{grid-template-columns:1fr 1fr}.footer-bottom{display:grid;text-align:left}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}.product-detail-copy{padding:24px}.product-detail-image img{height:320px}.map-card,.map-card iframe{min-height:320px}}
/* =========================================================
   NAVBAR WHATSAPP ICON
========================================================= */

.nav-whatsapp-icon {
    width: 44px;
    height: 38px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.nav-whatsapp-icon svg {
    width: 20px;
    height: 20px;
    fill: #5a321f;
    transition: transform .25s ease, fill .25s ease;
}

.nav-whatsapp-icon:hover svg {
    transform: scale(1.08);
    fill: #b8872f;
}


/* =========================================================
   SERVICES PAGE PREMIUM
========================================================= */

.services-page {
    background:
        radial-gradient(circle at top left, rgba(212, 175, 55, .14), transparent 34%),
        linear-gradient(180deg, #fbf4e6 0%, #f7ead7 100%);
    color: #3b2317;
}

.services-hero {
    padding: 78px 0 48px;
}

.services-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, .65fr);
    gap: 42px;
    align-items: stretch;
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .22em;
    color: #b8872f;
    font-weight: 800;
    margin-bottom: 14px;
}

.eyebrow::before {
    content: "";
    width: 28px;
    height: 1px;
    background: linear-gradient(90deg, #b8872f, transparent);
}

.services-hero h1 {
    max-width: 900px;
    margin: 0;
    color: #3b2317;
    font-family: Georgia, 'Times New Roman', serif;
    font-size: clamp(38px, 5vw, 68px);
    line-height: .95;
    letter-spacing: -2.4px;
}

.services-hero p {
    max-width: 780px;
    margin: 22px 0 0;
    color: #735340;
    font-size: 16px;
    line-height: 1.8;
}

.services-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 30px;
}

.btn-primary,
.btn-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 22px;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 800;
    text-decoration: none;
    transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
}

.btn-primary {
    color: #3b2317;
    background: linear-gradient(135deg, #d9ad42, #f4d27a);
    box-shadow: 0 16px 34px rgba(154, 105, 34, .24);
}

.btn-outline {
    color: #5a321f;
    background: rgba(255, 255, 255, .36);
    border: 1px solid rgba(184, 135, 47, .35);
}

.btn-primary:hover,
.btn-outline:hover {
    transform: translateY(-2px);
}

.services-highlight-card {
    position: relative;
    overflow: hidden;
    min-height: 310px;
    padding: 34px;
    border-radius: 32px;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, .68), rgba(244, 210, 122, .20)),
        url("../img/banner/hero-optica-mira.png") center right / cover no-repeat;
    border: 1px solid rgba(184, 135, 47, .30);
    box-shadow: 0 26px 60px rgba(88, 51, 28, .12);
}

.services-highlight-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(251, 244, 230, .94), rgba(251, 244, 230, .54), rgba(251, 244, 230, .12));
}

.services-highlight-card > * {
    position: relative;
    z-index: 1;
}

.services-highlight-card span {
    display: inline-block;
    color: #b8872f;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .16em;
    font-weight: 900;
    margin-bottom: 16px;
}

.services-highlight-card h2 {
    max-width: 320px;
    margin: 0;
    color: #3b2317;
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 40px;
    line-height: 1;
}

.services-highlight-card p {
    max-width: 330px;
    margin-top: 18px;
    color: #624431;
}

.services-list-section {
    padding: 34px 0 78px;
}

.section-heading {
    max-width: 720px;
    margin-bottom: 32px;
}

.section-heading h2 {
    margin: 0;
    color: #3b2317;
    font-family: Georgia, 'Times New Roman', serif;
    font-size: clamp(32px, 4vw, 52px);
    line-height: 1.05;
    letter-spacing: -1.6px;
}

.services-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
}

.service-card {
    position: relative;
    overflow: hidden;
    min-height: 245px;
    padding: 28px;
    border-radius: 28px;
    background: rgba(255, 255, 255, .48);
    border: 1px solid rgba(184, 135, 47, .20);
    box-shadow: 0 20px 45px rgba(93, 61, 39, .08);
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.service-card::after {
    content: "";
    position: absolute;
    width: 170px;
    height: 170px;
    right: -72px;
    top: -72px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(212, 175, 55, .18), transparent 68%);
}

.service-card:hover {
    transform: translateY(-6px);
    border-color: rgba(184, 135, 47, .46);
    box-shadow: 0 28px 65px rgba(93, 61, 39, .13);
}

.service-card.featured {
    background: linear-gradient(145deg, #5a321f, #7a472c);
    color: #fff7e9;
}

.service-card.featured h3,
.service-card.featured p,
.service-card.featured .service-number {
    color: #fff7e9;
}

.service-card.featured .service-icon {
    background: linear-gradient(135deg, #d9ad42, #f4d27a);
    color: #3b2317;
}

.service-number {
    display: inline-block;
    color: #b8872f;
    font-size: 12px;
    letter-spacing: .14em;
    font-weight: 900;
    margin-bottom: 20px;
}

.service-icon {
    width: 48px;
    height: 48px;
    margin-bottom: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 18px;
    color: #b8872f;
    background: rgba(212, 175, 55, .13);
    border: 1px solid rgba(184, 135, 47, .24);
    font-size: 24px;
    font-weight: 900;
}

.service-card h3 {
    margin: 0 0 12px;
    color: #3b2317;
    font-size: 21px;
    line-height: 1.2;
}

.service-card p {
    margin: 0;
    color: #735340;
    font-size: 14px;
    line-height: 1.75;
}

.services-cta {
    padding: 0 0 86px;
}

.services-cta-box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
    padding: 36px;
    border-radius: 34px;
    background:
        linear-gradient(135deg, rgba(90, 50, 31, .96), rgba(117, 70, 43, .95)),
        radial-gradient(circle at top right, rgba(244, 210, 122, .28), transparent 36%);
    color: #fff7e9;
    box-shadow: 0 30px 70px rgba(90, 50, 31, .22);
}

.services-cta-box h2 {
    margin: 0;
    font-family: Georgia, 'Times New Roman', serif;
    font-size: clamp(28px, 4vw, 46px);
    line-height: 1.05;
}

.services-cta-box p {
    max-width: 760px;
    margin: 14px 0 0;
    color: rgba(255, 247, 233, .82);
    line-height: 1.7;
}


/* =========================================================
   FOOTER PREMIUM
========================================================= */

.site-footer {
    position: relative;
    overflow: hidden;
    padding-top: 58px;
    background:
        radial-gradient(circle at 14% 0%, rgba(244, 210, 122, .22), transparent 32%),
        linear-gradient(135deg, #4a2919 0%, #5a321f 48%, #3a2015 100%);
    color: #fff7e9;
    border-top: 1px solid rgba(244, 210, 122, .28);
}

.footer-glow {
    position: absolute;
    width: 420px;
    height: 420px;
    right: -160px;
    top: -180px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(244, 210, 122, .24), transparent 68%);
    pointer-events: none;
}

.footer-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1.4fr .85fr .85fr 1.05fr;
    gap: 44px;
    align-items: start;
}

.footer-brand p {
    max-width: 300px;
    margin: 18px 0 22px;
    color: rgba(255, 247, 233, .82);
    font-size: 14px;
    line-height: 1.7;
}

.footer-logo-card {
    width: 122px;
    height: 122px;
    padding: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 24px;
    background: #fff8ea;
    border: 1px solid rgba(244, 210, 122, .44);
    box-shadow: 0 20px 45px rgba(0, 0, 0, .18);
}

.footer-logo-card img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.footer-whatsapp {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 18px;
    border-radius: 999px;
    color: #3b2317;
    background: linear-gradient(135deg, #d9ad42, #f4d27a);
    font-size: 13px;
    font-weight: 900;
    text-decoration: none;
    box-shadow: 0 14px 28px rgba(0, 0, 0, .18);
}

.footer-column h3 {
    margin: 4px 0 18px;
    color: #f4d27a;
    font-size: 16px;
}

.footer-column a {
    display: block;
    margin-bottom: 12px;
    color: rgba(255, 247, 233, .84);
    font-size: 14px;
    text-decoration: none;
    transition: color .25s ease, transform .25s ease;
}

.footer-column a:hover {
    color: #f4d27a;
    transform: translateX(4px);
}

.footer-contact p {
    margin: 0 0 18px;
    color: rgba(255, 247, 233, .82);
    font-size: 14px;
    line-height: 1.6;
}

.footer-contact strong {
    display: block;
    color: #f4d27a;
    margin-bottom: 3px;
}

.footer-bottom {
    position: relative;
    z-index: 1;
    margin-top: 46px;
    padding: 22px 0;
    border-top: 1px solid rgba(244, 210, 122, .20);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    color: rgba(255, 247, 233, .72);
    font-size: 13px;
}

.footer-bottom a {
    color: #f4d27a;
    text-decoration: none;
    font-weight: 800;
}


/* =========================================================
   RESPONSIVE
========================================================= */

@media (max-width: 980px) {
    .services-hero-grid {
        grid-template-columns: 1fr;
    }

    .services-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .footer-grid {
        grid-template-columns: 1fr 1fr;
    }

    .services-cta-box {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 640px) {
    .services-hero {
        padding: 54px 0 34px;
    }

    .services-hero h1 {
        font-size: 42px;
        letter-spacing: -1.6px;
    }

    .services-grid {
        grid-template-columns: 1fr;
    }

    .service-card {
        min-height: auto;
    }

    .services-highlight-card {
        min-height: 260px;
        padding: 26px;
    }

    .footer-grid {
        grid-template-columns: 1fr;
        gap: 30px;
    }

    .footer-bottom {
        flex-direction: column;
        align-items: flex-start;
    }
}



/* =========================================================
   FIX SERVICIOS + NAVBAR + FOOTER
   Pegar al final de assets/css/styles.css
========================================================= */

.container,
.section-container {
    width: min(var(--max), calc(100% - 36px));
    margin-inline: auto;
}

/* Navbar compatible con CSS original */
.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(255,248,236,.88);
    backdrop-filter: blur(18px);
    border-bottom: 1px solid var(--line);
}

.nav-container {
    width: min(1240px, calc(100% - 26px));
    min-height: 86px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.nav-logo {
    width: 142px;
    background: rgba(255,255,255,.68);
    border: 1px solid rgba(196,146,47,.22);
    border-radius: 22px;
    padding: 9px 12px;
    box-shadow: 0 14px 30px rgba(72,44,23,.08);
}

.nav-logo img {
    width: 100%;
    height: auto;
}

.main-nav {
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(255,255,255,.42);
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 8px;
}

.main-nav a {
    padding: 10px 16px;
    border-radius: 999px;
    color: var(--coffee-2);
    font-weight: 800;
    font-size: .93rem;
}

.main-nav a.active,
.main-nav a:hover {
    background: linear-gradient(135deg,var(--gold),var(--gold-2));
    color: #27180d;
}

.nav-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

.nav-action,
.nav-whatsapp-icon {
    background: #ffffffa8;
    border: 1px solid var(--line);
    color: var(--coffee);
    width: 44px;
    height: 38px;
    padding: 0;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.nav-whatsapp-icon svg {
    width: 20px;
    height: 20px;
    fill: #5a321f;
    transition: transform .25s ease, fill .25s ease;
}

.nav-whatsapp-icon:hover svg {
    transform: scale(1.08);
    fill: #b8872f;
}

.nav-cart {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    min-height: 38px;
    padding: 0 15px;
    border-radius: 999px;
    background: #5a321f;
    color: #fff7e9;
    font-size: 13px;
    font-weight: 800;
    text-decoration: none;
}

.nav-cart span {
    min-width: 19px;
    height: 19px;
    padding: 0 5px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: #d9ad42;
    color: #3b2317;
    font-size: 11px;
    font-weight: 900;
}

/* Servicios premium corregido */
.services-page {
    background:
        radial-gradient(circle at top left, rgba(212, 175, 55, .12), transparent 34%),
        linear-gradient(180deg, #fff8ec 0%, #f5ead8 100%);
    color: #3b2317;
    overflow: hidden;
}

.services-hero {
    padding: 86px 0 48px;
}

.services-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(320px, .85fr);
    gap: 42px;
    align-items: stretch;
}

.services-hero h1 {
    max-width: 850px;
    margin: 0;
    color: #3b2317;
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(2.4rem, 5vw, 4.8rem);
    line-height: .96;
    letter-spacing: -.055em;
}

.services-hero p,
.services-heading p {
    max-width: 760px;
    margin: 20px 0 0;
    color: #735340;
    font-size: 1rem;
    line-height: 1.8;
}

.services-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 30px;
}

.services-highlight-card {
    position: relative;
    overflow: hidden;
    min-height: 330px;
    padding: 34px;
    border-radius: 32px;
    background:
        linear-gradient(90deg, rgba(255,248,236,.96), rgba(255,248,236,.58), rgba(255,248,236,.15)),
        url("../img/banner/hero-optica-mira.webp") center right / cover no-repeat;
    border: 1px solid rgba(184, 135, 47, .30);
    box-shadow: 0 26px 60px rgba(88, 51, 28, .12);
}

.services-highlight-card span,
.service-number {
    display: inline-block;
    color: var(--gold);
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .16em;
    font-weight: 900;
    margin-bottom: 16px;
}

.services-highlight-card h2 {
    max-width: 320px;
    margin: 0;
    color: #3b2317;
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(2.2rem, 4vw, 3.8rem);
    line-height: 1;
}

.services-highlight-card p {
    max-width: 330px;
    margin-top: 18px;
    color: #624431;
    line-height: 1.7;
}

.services-list-section {
    padding: 34px 0 78px;
}

.services-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
}

.services-grid .service-card {
    position: relative;
    overflow: hidden;
    min-height: 245px;
    padding: 28px;
    border-radius: 28px;
    background: rgba(255, 250, 241, .78);
    border: 1px solid rgba(184, 135, 47, .20);
    box-shadow: 0 20px 45px rgba(93, 61, 39, .08);
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.services-grid .service-card::after {
    content: "";
    position: absolute;
    width: 170px;
    height: 170px;
    right: -72px;
    top: -72px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(212, 175, 55, .18), transparent 68%);
}

.services-grid .service-card:hover {
    transform: translateY(-6px);
    border-color: rgba(184, 135, 47, .46);
    box-shadow: 0 28px 65px rgba(93, 61, 39, .13);
}

.services-grid .service-card.featured {
    background: linear-gradient(145deg, #5a321f, #7a472c);
    color: #fff7e9;
}

.services-grid .service-card.featured h3,
.services-grid .service-card.featured p,
.services-grid .service-card.featured .service-number {
    color: #fff7e9;
}

.services-grid .service-card.featured .service-icon {
    background: linear-gradient(135deg, #d9ad42, #f4d27a);
    color: #3b2317;
}

.services-grid .service-card h3 {
    margin: 0 0 12px;
    color: #3b2317;
    font-size: 1.18rem;
    line-height: 1.22;
}

.services-grid .service-card p {
    margin: 0;
    color: #735340;
    font-size: .92rem;
    line-height: 1.75;
}

.service-icon {
    width: 48px;
    height: 48px;
    margin-bottom: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 18px;
    color: var(--gold);
    background: rgba(212, 175, 55, .13);
    border: 1px solid rgba(184, 135, 47, .24);
    font-size: 1.45rem;
    font-weight: 900;
}

.services-cta {
    padding: 0 0 86px;
}

.services-cta-box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
    padding: 36px;
    border-radius: 34px;
    background:
        radial-gradient(circle at top right, rgba(244, 210, 122, .28), transparent 36%),
        linear-gradient(135deg, rgba(90, 50, 31, .96), rgba(117, 70, 43, .95));
    color: #fff7e9;
    box-shadow: 0 30px 70px rgba(90, 50, 31, .22);
}

.services-cta-box h2 {
    margin: 0;
    color: #fff7e9;
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(2rem, 4vw, 3.2rem);
    line-height: 1.05;
}

.services-cta-box p {
    max-width: 760px;
    margin: 14px 0 0;
    color: rgba(255, 247, 233, .82);
    line-height: 1.7;
}

/* Footer premium corregido */
.site-footer {
    position: relative;
    overflow: hidden;
    padding-top: 58px;
    margin-top: 0;
    background:
        radial-gradient(circle at 14% 0%, rgba(244, 210, 122, .22), transparent 32%),
        linear-gradient(135deg, #4a2919 0%, #5a321f 48%, #3a2015 100%);
    color: #fff7e9;
    border-top: 1px solid rgba(244, 210, 122, .28);
}

.site-footer .footer-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1.35fr .85fr .85fr 1.1fr;
    gap: 44px;
    align-items: start;
    padding: 0 0 46px;
}

.footer-brand p {
    max-width: 300px;
    margin: 18px 0 22px;
    color: rgba(255, 247, 233, .82);
    font-size: .95rem;
    line-height: 1.7;
}

.footer-logo-card {
    width: 122px;
    height: 122px;
    padding: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 24px;
    background: #fff8ea;
    border: 1px solid rgba(244, 210, 122, .44);
    box-shadow: 0 20px 45px rgba(0, 0, 0, .18);
}

.footer-logo-card img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.footer-whatsapp {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 18px;
    border-radius: 999px;
    color: #3b2317;
    background: linear-gradient(135deg, #d9ad42, #f4d27a);
    font-size: .9rem;
    font-weight: 900;
    text-decoration: none;
    box-shadow: 0 14px 28px rgba(0, 0, 0, .18);
}

.footer-column h3 {
    margin: 4px 0 18px;
    color: #f4d27a;
    font-size: 1rem;
}

.footer-column a {
    display: block;
    margin-bottom: 12px;
    color: rgba(255, 247, 233, .84);
    font-size: .94rem;
    text-decoration: none;
    transition: color .25s ease, transform .25s ease;
}

.footer-column a:hover {
    color: #f4d27a;
    transform: translateX(4px);
}

.footer-contact p {
    margin: 0 0 18px;
    color: rgba(255, 247, 233, .82);
    font-size: .94rem;
    line-height: 1.6;
}

.footer-contact strong {
    display: block;
    color: #f4d27a;
    margin-bottom: 3px;
}

.site-footer .footer-bottom {
    position: relative;
    z-index: 1;
    margin-top: 0;
    padding: 22px 0;
    border-top: 1px solid rgba(244, 210, 122, .20);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    color: rgba(255, 247, 233, .72);
    font-size: .86rem;
}

.site-footer .footer-bottom a {
    color: #f4d27a;
    text-decoration: none;
    font-weight: 800;
}

@media (max-width: 980px) {
    .services-hero-grid {
        grid-template-columns: 1fr;
    }

    .services-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .site-footer .footer-grid {
        grid-template-columns: 1fr 1fr;
    }

    .services-cta-box {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 820px) {
    .main-nav {
        display: none;
    }

    .nav-toggle {
        display: flex;
    }
}

@media (max-width: 640px) {
    .container,
    .section-container {
        width: min(100% - 24px, var(--max));
    }

    .services-hero {
        padding: 54px 0 34px;
    }

    .services-hero h1 {
        font-size: 2.6rem;
    }

    .services-grid {
        grid-template-columns: 1fr;
    }

    .services-grid .service-card {
        min-height: auto;
    }

    .services-highlight-card {
        min-height: 260px;
        padding: 26px;
    }

    .site-footer .footer-grid {
        grid-template-columns: 1fr;
        gap: 30px;
    }

    .site-footer .footer-bottom {
        flex-direction: column;
        align-items: flex-start;
    }
}
