.brand-logo{height:48px;width:auto;display:block;object-fit:contain}

:root{
    --midnight-900:#0b1120;
    --midnight-800:#0f172a;
    --midnight-700:#172554;
    --midnight-500:#1e3a8a;
    --sky-300:#38bdf8;
    --sky-200:#bae6fd;
    --sky-100:#e0f2fe;
    --mint-400:#34d399;
    --slate-100:#f8fafc;
    --slate-200:#f1f5f9;
    --slate-400:#94a3b8;
    --slate-500:#64748b;
    --shadow-lg:0 2.4rem 4.5rem rgba(15,23,42,.28);
    --shadow-md:0 1.4rem 2.2rem rgba(15,23,42,.18);
}

body.site-background{
    min-height:100vh;
    background:radial-gradient(circle at 15% 18%,rgba(56,189,248,.25),transparent 55%),
               radial-gradient(circle at 75% 5%,rgba(14,165,233,.18),transparent 50%),
               radial-gradient(circle at 55% 80%,rgba(59,130,246,.22),transparent 55%),
               linear-gradient(135deg,var(--midnight-900),#111c3d 45%,var(--midnight-700));
    background-attachment:fixed;
    color:var(--midnight-800);
}

.site-navbar{
    background:linear-gradient(135deg,rgba(11,17,32,.92),rgba(30,58,138,.88));
    border:none;
    border-radius:1rem;
    padding:.75rem 1.1rem;
    box-shadow:0 1.25rem 2.5rem rgba(8,13,26,.35);
    backdrop-filter:blur(6px);
}

.site-navbar .navbar-brand{
    color:var(--slate-100);
    font-weight:700;
    letter-spacing:.04em;
}

.site-navbar .nav-link{
    color:rgba(226,232,240,.85);
    font-weight:600;
    letter-spacing:.03em;
    text-transform:uppercase;
    font-size:.85rem;
}

.site-navbar .nav-link:hover,
.site-navbar .nav-link:focus,
.site-navbar .nav-link.active{color:var(--sky-300);}

.site-navbar .navbar-toggler{
    border-color:rgba(248,250,252,.45);
    --bs-navbar-toggler-icon-bg:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(248, 250, 252, 0.85)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

.site-content{
    background:rgba(248,250,252,.94);
    border-radius:1.4rem;
    padding:2.75rem 1.75rem;
    box-shadow:var(--shadow-lg);
}

.site-content>:first-child{margin-top:0;}
.site-content>:last-child{margin-bottom:0;}

.site-footer{
    background:rgba(11,17,32,.75);
    color:rgba(226,232,240,.85);
    border-radius:1rem 1rem 0 0;
}

.site-footer .text-muted{color:rgba(226,232,240,.75)!important;}
.site-footer a{color:var(--sky-300);}

.pre-wrap{white-space:pre-wrap;}

@media (max-width:991.98px){
    .site-navbar{border-radius:1rem;}
}

@media (max-width:767.98px){
    body.site-background{background-attachment:scroll;}
    .site-navbar{border-radius:1rem;}
    .site-content{border-radius:1rem;padding:2.25rem 1.35rem;box-shadow:var(--shadow-md);}
}
/* Uniform gallery image box: ~portrait card ratio */
.card .gallery-img{
    width:100%;
    aspect-ratio:3/4;
    object-fit:cover;
    object-position:center;
    display:block;
    border-top-left-radius:.75rem;
    border-top-right-radius:.75rem;
}

.card{
    border:none;
    border-radius:1rem;
    background:linear-gradient(145deg,var(--slate-100),var(--slate-200));
    box-shadow:0 1rem 2.6rem rgba(15,23,42,.12);
}

.card .card-body{padding:1.5rem;}

.card .btn-primary{
    background:linear-gradient(135deg,var(--midnight-500),#2563eb);
    border:none;
    box-shadow:0 .8rem 1.8rem rgba(37,99,235,.3);
}

.card .btn-primary:hover,.card .btn-primary:focus{background:linear-gradient(135deg,#2563eb,#1d4ed8);}

.chart-wrapper{position:relative;min-height:320px;}
.kpi-chart{display:block;width:100%;height:100%;}

.homepage-hero{
    position:relative;
    overflow:hidden;
    border-radius:1.5rem;
    background:radial-gradient(circle at 20% 18%,rgba(255,255,255,.14),transparent 55%),
               radial-gradient(circle at 75% -5%,rgba(191,219,254,.28),transparent 45%),
               linear-gradient(140deg,#1d4ed8 5%,#1e3a8a 55%,var(--midnight-900));
    color:var(--slate-100);
    box-shadow:0 2.5rem 4.5rem rgba(15,23,42,.35);
}

.homepage-hero::after{
    content:"";
    position:absolute;
    inset:0;
    background:radial-gradient(circle at 60% 30%,rgba(56,189,248,.15),transparent 55%);
    mix-blend-mode:screen;
    pointer-events:none;
}

.homepage-hero .hero-badge{
    display:inline-flex;
    align-items:center;
    gap:.35rem;
    padding:.35rem .85rem;
    border-radius:999px;
    background:rgba(15,23,42,.35);
    font-size:.75rem;
    letter-spacing:.06em;
    text-transform:uppercase;
}

.homepage-hero .btn-outline-light{
    border-color:rgba(248,250,252,.7);
    color:var(--slate-100);
}

.homepage-hero .btn-outline-light:hover,
.homepage-hero .btn-outline-light:focus{
    background:rgba(248,250,252,.18);
    border-color:rgba(248,250,252,.9);
}

.hero-trust li{
    position:relative;
    padding-left:1.6rem;
    color:rgba(226,232,240,.88);
    margin-bottom:.4rem;
}

.hero-trust li::before{
    content:"";
    position:absolute;
    top:.55rem;
    left:.4rem;
    width:.55rem;
    height:.55rem;
    border-radius:50%;
    background:var(--sky-300);
    box-shadow:0 0 0 3px rgba(56,189,248,.25);
}

.hero-contact-panel{
    position:relative;
    border-radius:1.4rem;
    background:linear-gradient(160deg,rgba(15,23,42,.92) 5%,rgba(30,64,175,.9) 55%,rgba(15,23,42,.95));
    color:var(--slate-100);
    padding:1.3rem 1.35rem;
    box-shadow:0 2rem 3.5rem rgba(8,13,26,.4);
    overflow:hidden;
}

.hero-contact-panel::before{
    content:"";
    position:absolute;
    width:180%;
    height:180%;
    top:-60%;
    right:-110%;
    background:radial-gradient(circle,rgba(56,189,248,.45),transparent 60%);
    filter:blur(0.5px);
    opacity:.75;
}

.hero-contact-panel .panel-body{position:relative;z-index:1;}

.panel-eyebrow{
    font-size:.7rem;
    letter-spacing:.28em;
    text-transform:uppercase;
    color:rgba(186,230,253,.9);
    font-weight:700;
}

.panel-title{color:var(--slate-100);}

.panel-description{color:rgba(241,245,249,.82);}

.contact-actions{margin-top:1.2rem;}

.contact-pill{
    display:flex;
    align-items:center;
    text-decoration:none;
    padding:.85rem 1.05rem;
    border-radius:1.1rem;
    border:1px solid rgba(148,163,184,.25);
    background:rgba(15,23,42,.35);
    color:var(--slate-100);
    transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease;
}

.contact-pill:hover,
.contact-pill:focus{
    transform:translateY(-2px);
    box-shadow:0 1.5rem 2.5rem rgba(14,25,54,.45);
    border-color:rgba(186,230,253,.55);
    background:rgba(15,23,42,.5);
    color:var(--slate-100);
}

.contact-pill-whatsapp{background:linear-gradient(135deg,rgba(14,116,144,.4),rgba(20,83,136,.35));}
.contact-pill-mail{background:linear-gradient(135deg,rgba(59,130,246,.35),rgba(14,116,144,.28));}

.contact-icon{font-size:1.4rem;line-height:1;}

.contact-copy{display:flex;flex-direction:column;gap:.15rem;font-size:.95rem;}
.contact-copy strong{font-size:1.05rem;}
.contact-sub{font-size:.8rem;color:rgba(226,232,240,.78);}

.hero-contact-panel .hero-metrics{margin-top:auto;border-top:1px solid rgba(148,163,184,.35);padding-top:1.1rem;}

.hero-metrics.grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(110px,1fr));
    gap:.85rem;
}

.metric-tile{
    background:rgba(15,23,42,.25);
    border-radius:1rem;
    padding:.85rem 1rem;
    border:1px solid rgba(148,163,184,.25);
    display:flex;
    flex-direction:column;
    gap:.25rem;
    text-align:left;
}

.metric-value{
    font-size:1.6rem;
    font-weight:700;
    color:var(--sky-200);
}

.metric-label{font-size:.78rem;color:rgba(226,232,240,.78);text-transform:uppercase;letter-spacing:.08em;}

.hero-metrics .metric-tile:nth-child(2){
    background:linear-gradient(135deg,rgba(59,130,246,.35),rgba(30,64,175,.3));
}

.hero-metrics .metric-tile:nth-child(3){
    background:linear-gradient(135deg,rgba(52,211,153,.4),rgba(14,116,144,.3));
}

.catalog-controls .badge{
    font-weight:600;
    background:rgba(15,23,42,.05)!important;
    color:var(--midnight-800);
    border:1px solid rgba(15,23,42,.08);
}

.filter-card{border-radius:1.1rem;background:linear-gradient(135deg,var(--slate-100),rgba(255,255,255,.85));box-shadow:0 1.2rem 2.6rem rgba(15,23,42,.12);}

.filter-card .form-label{font-weight:600;letter-spacing:.05em;}
.filter-card .input-group-text{min-width:3rem;}
.filter-card .btn{min-width:12rem;}

@media (max-width:767.98px){
    .homepage-hero{border-radius:1.1rem;}
    .hero-metrics.grid{gap:1.5rem;}
    .filter-card .btn{width:100%;}
    .hero-contact-panel{padding:1.45rem 1.35rem;}
    .contact-pill{padding:.8rem .95rem;}
}

@media (min-width:992px){
    .homepage-hero{padding:1.25rem 1.75rem!important;}
    .hero-contact-panel{padding:1.5rem 1.45rem;}
}

/* Sticky Mobile Buy Bar */
.sticky-buy-bar {
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    border-top: 1px solid rgba(148, 163, 184, 0.2);
    box-shadow: 0 -4px 20px rgba(15, 23, 42, 0.1);
    z-index: 1040; /* Below modal (1055) but above content */
    padding-bottom: max(1rem, env(safe-area-inset-bottom)); /* iOS Safe Area */
}

/* Add padding to body on mobile so content isn't covered by sticky bar */
@media (max-width: 767.98px) {
    body {
        padding-bottom: 80px;
    }
}
