/* ============================================================
   CR DECALS DESIGNS — main.css  |  Toluca, México
   Dark industrial · Neon orange accents · Premium feel
   ============================================================ */

:root {
    --bg-dark:    #09090b;
    --bg-mid:     #111113;
    --bg-card:    rgba(255,255,255,0.04);
    --bg-light:   #f5f5f0;
    --accent:     #ff5200;
    --accent2:    #ff7c00;
    --accent-glow: rgba(255,82,0,0.28);
    --green:      #22c55e;
    --text-light: #eeeee8;
    --text-muted: #88887e;
    --border:     rgba(255,255,255,0.07);
    --border-light:#e2e2d8;
    --font-display:'Bebas Neue', sans-serif;
    --font-ui:    'Rajdhani', sans-serif;
    --font-body:  'DM Sans', sans-serif;
    --r:          4px;
    --r-lg:       10px;
    --ease:       0.24s ease;
    --shadow:     0 8px 32px rgba(0,0,0,.45);
}

/* ── RESET ─────────────────────────────── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html  { scroll-behavior:smooth; font-size:16px; }
body  { background:var(--bg-dark); color:var(--text-light); font-family:var(--font-body); line-height:1.65; overflow-x:hidden; }
a     { color:inherit; text-decoration:none; }
img   { max-width:100%; display:block; }
ul,ol { list-style:none; }
button{ cursor:pointer; border:none; background:none; font-family:inherit; }
input,textarea,select { font-family:var(--font-body); }
body.is-preload * { animation:none!important; transition:none!important; }

/* ── LOADER ─────────────────────────────── */
#loader { position:fixed; inset:0; background:var(--bg-dark); display:flex; align-items:center; justify-content:center; z-index:9999; transition:opacity .5s ease, visibility .5s ease; }
#loader.hidden { opacity:0; visibility:hidden; pointer-events:none; }
.loader-inner { text-align:center; }
.loader-logo  { font-family:var(--font-display); font-size:3.5rem; letter-spacing:.15em; color:var(--text-light); line-height:1; }
.loader-logo span { color:var(--accent); }
.loader-tagline { font-family:var(--font-ui); font-size:.7rem; letter-spacing:.4em; color:var(--text-muted); margin:.4rem 0 1.5rem; text-transform:uppercase; }
.loader-bar   { width:220px; height:2px; background:var(--border); margin:0 auto; border-radius:2px; overflow:hidden; }
.loader-progress { height:100%; background:linear-gradient(90deg,var(--accent),var(--accent2)); animation:loadProg 1.6s cubic-bezier(.4,0,.2,1) forwards; width:0; }
@keyframes loadProg { to { width:100%; } }

/* ── LAYOUT ─────────────────────────────── */
.container { max-width:1200px; margin:0 auto; padding:0 2rem; }
.section-dark  { background:var(--bg-dark);  padding:6rem 0; }
.section-light { background:var(--bg-light); padding:6rem 0; }
.section-light .section-header h2 { color:#111; }
.section-light .accent  { color:var(--accent); }
.section-light p        { color:#555; }

.section-header { text-align:center; margin-bottom:3.5rem; }
.section-tag {
    display:inline-block; font-family:var(--font-ui); font-size:.75rem; font-weight:700;
    letter-spacing:.3em; text-transform:uppercase; color:var(--accent);
    margin-bottom:.6rem;
}
.section-header h2 {
    font-family:var(--font-display); font-size:clamp(2.2rem,5vw,3.6rem);
    color:var(--text-light); letter-spacing:.04em; line-height:1.05;
}
.accent { color:var(--accent); }
.section-cta { text-align:center; margin-top:3rem; }

/* ── HEADER ─────────────────────────────── */
#header {
    position:fixed; top:0; left:0; right:0; z-index:100;
    background:rgba(9,9,11,.96); backdrop-filter:blur(18px) saturate(180%);
    border-bottom:1px solid var(--border);
    transition:box-shadow var(--ease);
}
#header.scrolled { box-shadow:0 4px 40px rgba(0,0,0,.6); }
.header-inner { max-width:1200px; margin:0 auto; padding:0 2rem; display:flex; align-items:center; justify-content:space-between; height:68px; }

/* Logo */
#logo a, .footer-logo { display:flex; align-items:baseline; gap:.25rem; }
.logo-cr    { font-family:var(--font-display); font-size:1.75rem; color:var(--accent); letter-spacing:.08em; line-height:1; }
.logo-decals{ font-family:var(--font-display); font-size:1.75rem; color:var(--text-light); letter-spacing:.12em; line-height:1; }
.logo-sub   { font-family:var(--font-ui); font-size:.6rem; color:var(--text-muted); letter-spacing:.3em; text-transform:uppercase; align-self:center; margin-left:.2rem; }

/* Nav */
#nav ul { display:flex; }
#nav ul li a {
    font-family:var(--font-ui); font-weight:600; font-size:.875rem;
    letter-spacing:.12em; text-transform:uppercase; padding:0 1.1rem;
    color:var(--text-muted); transition:color var(--ease);
    display:flex; align-items:center; height:68px; position:relative;
}
#nav ul li a::after {
    content:''; position:absolute; bottom:0; left:1.1rem; right:1.1rem;
    height:2px; background:var(--accent); transform:scaleX(0);
    transition:transform var(--ease); transform-origin:center;
}
#nav ul li a:hover, #nav ul li.current a { color:var(--text-light); }
#nav ul li a:hover::after, #nav ul li.current a::after { transform:scaleX(1); }

/* Header actions */
.header-actions { display:flex; align-items:center; gap:.9rem; }
.cart-btn {
    position:relative; display:flex; align-items:center; justify-content:center;
    width:42px; height:42px; border:1px solid var(--border); border-radius:var(--r);
    color:var(--text-light); transition:all var(--ease); font-size:.95rem;
}
.cart-btn:hover { border-color:var(--accent); color:var(--accent); background:var(--accent-glow); }
.cart-count {
    position:absolute; top:-7px; right:-7px;
    background:var(--accent); color:#fff; font-size:.6rem; font-weight:700;
    width:18px; height:18px; border-radius:50%; display:flex; align-items:center; justify-content:center;
    font-family:var(--font-ui);
}
.mobile-toggle { display:none; flex-direction:column; gap:5px; padding:8px; }
.mobile-toggle span { display:block; width:24px; height:2px; background:var(--text-light); transition:all .25s ease; border-radius:2px; }
.mobile-toggle.active span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.mobile-toggle.active span:nth-child(2) { opacity:0; width:0; }
.mobile-toggle.active span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Mobile nav */
#mobileNav {
    position:fixed; top:68px; left:0; right:0; z-index:99;
    background:var(--bg-mid); border-bottom:1px solid var(--border);
    transform:translateY(-110%); opacity:0;
    transition:transform .3s ease, opacity .3s ease; pointer-events:none;
}
#mobileNav.open { transform:translateY(0); opacity:1; pointer-events:all; }
#mobileNav ul { padding:1rem 2rem 2rem; display:flex; flex-direction:column; gap:.25rem; }
#mobileNav ul li a {
    font-family:var(--font-ui); font-size:1.05rem; font-weight:600;
    letter-spacing:.08em; text-transform:uppercase; color:var(--text-muted);
    padding:.7rem 0; border-bottom:1px solid var(--border); display:block;
    transition:color var(--ease);
}
#mobileNav ul li a:hover { color:var(--accent); }

/* ── BUTTONS ─────────────────────────────── */
.btn-primary {
    display:inline-flex; align-items:center; gap:.55rem;
    font-family:var(--font-ui); font-weight:700; font-size:.875rem;
    letter-spacing:.12em; text-transform:uppercase;
    background:var(--accent); color:#fff;
    padding:.85rem 1.9rem; border-radius:var(--r);
    border:2px solid var(--accent); transition:all var(--ease);
    position:relative; overflow:hidden;
}
.btn-primary::before { content:''; position:absolute; inset:0; background:rgba(255,255,255,.12); transform:translateX(-101%); transition:transform .3s ease; }
.btn-primary:hover   { background:#e64800; border-color:#e64800; transform:translateY(-2px); box-shadow:0 10px 28px var(--accent-glow); }
.btn-primary:hover::before { transform:translateX(0); }
.btn-primary:active  { transform:translateY(0); }

.btn-outline {
    display:inline-flex; align-items:center; gap:.55rem;
    font-family:var(--font-ui); font-weight:700; font-size:.875rem;
    letter-spacing:.12em; text-transform:uppercase;
    background:transparent; color:var(--text-light);
    padding:.85rem 1.9rem; border-radius:var(--r);
    border:2px solid var(--border); transition:all var(--ease);
}
.btn-outline:hover { border-color:var(--accent); color:var(--accent); }

.btn-outline-white {
    display:inline-flex; align-items:center; gap:.55rem;
    font-family:var(--font-ui); font-weight:700; font-size:.875rem;
    letter-spacing:.12em; text-transform:uppercase;
    background:transparent; color:#fff;
    padding:.85rem 1.9rem; border-radius:var(--r);
    border:2px solid rgba(255,255,255,.3); transition:all var(--ease);
}
.btn-outline-white:hover { border-color:#fff; background:rgba(255,255,255,.1); }

.btn-whatsapp {
    display:inline-flex; align-items:center; gap:.55rem;
    font-family:var(--font-ui); font-weight:700; font-size:.875rem;
    letter-spacing:.1em; text-transform:uppercase;
    background:#25d366; color:#fff;
    padding:.85rem 1.9rem; border-radius:var(--r); transition:all var(--ease);
}
.btn-whatsapp:hover { background:#1ab553; transform:translateY(-2px); box-shadow:0 8px 24px rgba(37,211,102,.35); }
.btn-full { width:100%; justify-content:center; }

/* ── HERO ─────────────────────────────── */
#hero {
    position:relative; min-height:100vh; display:flex; align-items:center;
    padding-top:68px; overflow:hidden;
}
.hero-bg { position:absolute; inset:0; }
.hero-grid {
    position:absolute; inset:0;
    background-image:
        linear-gradient(rgba(255,82,0,.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,82,0,.06) 1px, transparent 1px);
    background-size:55px 55px;
    animation:gridMove 25s linear infinite;
}
@keyframes gridMove { to { background-position:55px 55px; } }
.hero-glow {
    position:absolute; top:15%; left:45%; transform:translateX(-50%);
    width:900px; height:500px;
    background:radial-gradient(ellipse, rgba(255,82,0,.1) 0%, transparent 65%);
    pointer-events:none;
}
.hero-content {
    position:relative; z-index:2; flex:1;
    padding:4rem 2rem 4rem 5%;
    max-width:640px;
    opacity:0;
}
body:not(.is-preload) .hero-content { animation:fadeUp .8s .25s ease forwards; }
@keyframes fadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }

.hero-tag {
    display:inline-flex; align-items:center; gap:.5rem;
    font-family:var(--font-ui); font-size:.8rem; font-weight:700;
    letter-spacing:.12em; text-transform:uppercase;
    color:var(--accent); border:1px solid rgba(255,82,0,.3);
    padding:.4rem 1rem; border-radius:20px; background:rgba(255,82,0,.07);
    margin-bottom:1.5rem;
}
.hero-title { font-family:var(--font-display); line-height:.93; margin-bottom:1.4rem; }
.hero-title .line1 { display:block; font-size:clamp(3.5rem,8vw,7.2rem); color:var(--text-light); }
.hero-title .line2 { display:block; font-size:clamp(3rem,7vw,6.2rem); color:var(--accent); }
.hero-title .line3 { display:block; font-size:clamp(3.5rem,8vw,7.2rem); color:transparent; -webkit-text-stroke:1.5px rgba(255,255,255,.18); }
.hero-desc  { font-size:1.05rem; color:var(--text-muted); max-width:480px; margin-bottom:2rem; line-height:1.7; }
.hero-btns  { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:3rem; }
.hero-stats { display:flex; align-items:center; gap:2rem; }
.stat { display:flex; flex-direction:column; gap:.15rem; }
.stat-num  { font-family:var(--font-display); font-size:2.2rem; color:var(--accent); line-height:1; }
.stat-num small { font-size:1.2rem; }
.stat-label{ font-family:var(--font-ui); font-size:.7rem; color:var(--text-muted); letter-spacing:.12em; text-transform:uppercase; }
.stat-div  { width:1px; height:40px; background:var(--border); }

.hero-visual {
    position:relative; z-index:2; flex:1;
    display:flex; justify-content:center; align-items:center;
    padding:4rem 2rem;
    opacity:0;
}
body:not(.is-preload) .hero-visual { animation:fadeUp .8s .5s ease forwards; }
.decal-showcase { display:grid; grid-template-columns:1fr 1fr; gap:1.4rem; max-width:360px; }
.decal-card {
    aspect-ratio:1; border:1px solid var(--border); border-radius:var(--r-lg);
    display:flex; align-items:center; justify-content:center;
    background:var(--bg-card); transition:all .3s ease; cursor:pointer;
    position:relative; overflow:hidden;
}
.decal-card::before {
    content:''; position:absolute; inset:0;
    background:radial-gradient(circle at center, var(--accent-glow), transparent);
    opacity:0; transition:opacity .3s;
}
.decal-card:hover { border-color:var(--accent); transform:scale(1.05); box-shadow:0 8px 30px var(--accent-glow); }
.decal-card:hover::before { opacity:1; }
.decal-inner { display:flex; flex-direction:column; align-items:center; gap:.75rem; position:relative; z-index:1; }
.decal-inner i    { font-size:2.4rem; color:var(--text-muted); transition:color var(--ease); }
.decal-inner span { font-family:var(--font-ui); font-size:.8rem; font-weight:700; letter-spacing:.1em; color:var(--text-muted); text-transform:uppercase; transition:color var(--ease); }
.decal-card:hover .decal-inner i, .decal-card:hover .decal-inner span { color:var(--accent); }
.d1{ animation:float 4s ease-in-out infinite; }
.d2{ animation:float 4s 1s ease-in-out infinite; }
.d3{ animation:float 4s 2s ease-in-out infinite; }
.d4{ animation:float 4s .5s ease-in-out infinite; }
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }

.scroll-down {
    position:absolute; bottom:2rem; left:50%; transform:translateX(-50%);
    color:var(--text-muted); animation:bounce 2.2s ease infinite; font-size:1.1rem;
}
@keyframes bounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(9px)} }

/* ── CATEGORIES ─────────────────────────── */
.cat-grid {
    display:grid;
    grid-template-columns:repeat(4,1fr);
    grid-template-rows:auto auto;
    gap:1.4rem;
}
.cat-card {
    position:relative; overflow:hidden; border-radius:var(--r-lg);
    border:1px solid var(--border); min-height:200px;
    display:flex; align-items:flex-end; padding:2rem;
    transition:all .3s ease;
}
.cat-card:hover { transform:translateY(-5px); border-color:var(--accent); box-shadow:0 16px 40px rgba(0,0,0,.5); }
.cat-main { grid-column:span 2; grid-row:span 2; min-height:420px; }
.cat-bg { position:absolute; inset:0; }
.cat-bg img { width:100%; height:100%; object-fit:cover; opacity:.35; }
.cat-bg-1 { background:linear-gradient(150deg,#1e0800,#0b0400); }
.cat-bg-2 { background:linear-gradient(150deg,#0c0c1e,#060612); }
.cat-bg-3 { background:linear-gradient(150deg,#0a1a0a,#05100a); }
.cat-bg-4 { background:linear-gradient(150deg,#1a1000,#0a0700); }
.cat-card::after {
    content:''; position:absolute; inset:0;
    background:linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.2) 60%, transparent 100%);
}
.cat-content { position:relative; z-index:1; }
.cat-content i  { font-size:2rem; color:var(--accent); margin-bottom:.75rem; display:block; }
.cat-content h3 { font-family:var(--font-ui); font-size:1.25rem; font-weight:700; color:#fff; margin-bottom:.4rem; letter-spacing:.04em; }
.cat-main .cat-content h3 { font-size:1.75rem; }
.cat-content p  { color:rgba(255,255,255,.55); font-size:.88rem; margin-bottom:.9rem; line-height:1.5; }
.cat-link { font-family:var(--font-ui); font-size:.78rem; font-weight:700; color:var(--accent); letter-spacing:.1em; text-transform:uppercase; display:flex; align-items:center; gap:.4rem; }
.cat-special { border-color:rgba(255,82,0,.25)!important; }

/* ── PRODUCTS ─────────────────────────── */
.products-grid, .catalog-grid {
    display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:1.5rem;
}
.product-card {
    border-radius:var(--r-lg); overflow:hidden;
    border:1px solid var(--border-light); background:#fff;
    transition:all .3s ease; position:relative;
    box-shadow:0 2px 12px rgba(0,0,0,.06);
}
.product-card:hover { border-color:var(--accent); transform:translateY(-5px); box-shadow:0 16px 40px rgba(0,0,0,.12); }
.product-img {
    aspect-ratio:4/3; background:#f0f0ea;
    display:flex; align-items:center; justify-content:center;
    font-size:3.5rem; position:relative; overflow:hidden;
}
.product-img img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.product-img-icon { position:relative; z-index:1; transition:transform .3s ease; }
.product-card:hover .product-img-icon { transform:scale(1.1) rotate(-3deg); }
.product-badge {
    position:absolute; top:.75rem; left:.75rem; z-index:2;
    font-family:var(--font-ui); font-size:.65rem; font-weight:800;
    letter-spacing:.1em; text-transform:uppercase;
    background:var(--accent); color:#fff;
    padding:.25rem .65rem; border-radius:3px;
}
.product-badge.sale { background:#dc2626; }
.product-badge.new  { background:#16a34a; }
.product-info { padding:1.2rem; }
.product-cat  { font-family:var(--font-ui); font-size:.68rem; font-weight:700; color:var(--accent); letter-spacing:.15em; text-transform:uppercase; margin-bottom:.35rem; }
.product-name { font-family:var(--font-ui); font-size:1rem; font-weight:700; color:#111; margin-bottom:.45rem; line-height:1.25; }
.product-desc { font-size:.82rem; color:#666; margin-bottom:1rem; line-height:1.55; }
.product-footer { display:flex; align-items:center; justify-content:space-between; gap:.5rem; flex-wrap:wrap; }
.product-price     { font-family:var(--font-display); font-size:1.55rem; color:var(--accent); line-height:1; }
.product-price-old { font-size:.82rem; color:#aaa; text-decoration:line-through; margin-left:.3rem; }
.add-cart-btn {
    display:flex; align-items:center; gap:.4rem;
    font-family:var(--font-ui); font-size:.75rem; font-weight:800;
    letter-spacing:.08em; text-transform:uppercase;
    background:var(--accent); color:#fff;
    padding:.55rem 1.1rem; border-radius:var(--r); transition:all var(--ease);
}
.add-cart-btn:hover { background:#e64800; transform:scale(1.03); }

/* ── FEATURES ─────────────────────────── */
.features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; }
.feature-item {
    background:var(--bg-card); border:1px solid var(--border);
    border-radius:var(--r-lg); padding:2rem;
    transition:all .3s ease;
}
.feature-item:hover { border-color:var(--accent); transform:translateY(-4px); box-shadow:0 12px 32px rgba(0,0,0,.3); }
.feature-icon {
    width:54px; height:54px; border-radius:var(--r);
    background:var(--accent-glow); border:1px solid rgba(255,82,0,.3);
    display:flex; align-items:center; justify-content:center;
    font-size:1.35rem; color:var(--accent); margin-bottom:1.2rem;
}
.feature-item h3 { font-family:var(--font-ui); font-size:1.05rem; font-weight:700; margin-bottom:.65rem; color:var(--text-light); }
.feature-item p  { font-size:.88rem; color:var(--text-muted); line-height:1.65; }

/* ── PROCESS ─────────────────────────── */
.process-steps { display:flex; align-items:flex-start; gap:1.2rem; flex-wrap:wrap; justify-content:center; margin-bottom:1rem; }
.step { flex:1; min-width:175px; max-width:215px; text-align:center; }
.step-num  { font-family:var(--font-display); font-size:4.5rem; color:rgba(255,82,0,.08); line-height:1; margin-bottom:-.9rem; }
.step-icon {
    width:62px; height:62px; border-radius:50%; border:2px solid var(--accent);
    background:var(--accent-glow); display:flex; align-items:center; justify-content:center;
    font-size:1.35rem; color:var(--accent); margin:0 auto 1rem; position:relative; z-index:1;
}
.step h3 { font-family:var(--font-ui); font-size:.98rem; font-weight:700; color:#111; margin-bottom:.4rem; }
.step p  { font-size:.83rem; color:#666; line-height:1.55; }
.step-arrow { align-self:center; color:var(--accent); font-size:1.1rem; flex-shrink:0; margin-top:-1.5rem; opacity:.6; }

/* ── TESTIMONIALS ─────────────────────── */
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.testimonial {
    background:var(--bg-card); border:1px solid var(--border);
    border-radius:var(--r-lg); padding:1.75rem;
    transition:border-color .3s ease;
}
.testimonial:hover     { border-color:rgba(255,82,0,.3); }
.testimonial.featured-t{ border-color:var(--accent); background:rgba(255,82,0,.04); }
.t-stars    { color:var(--accent); font-size:.95rem; margin-bottom:.9rem; letter-spacing:.1em; }
.testimonial p { font-size:.88rem; color:var(--text-muted); line-height:1.75; margin-bottom:1.4rem; font-style:italic; }
.t-author   { display:flex; align-items:center; gap:.9rem; }
.t-avatar   { width:40px; height:40px; border-radius:50%; background:var(--accent); color:#fff; display:flex; align-items:center; justify-content:center; font-family:var(--font-ui); font-weight:700; font-size:.82rem; flex-shrink:0; }
.t-author strong { display:block; font-family:var(--font-ui); font-weight:700; color:var(--text-light); }
.t-author span   { font-size:.78rem; color:var(--text-muted); }

/* ── CTA BANNER ─────────────────────────── */
#cta-banner {
    background:linear-gradient(140deg,#1c0800,#0e0500);
    border-top:1px solid var(--border); border-bottom:1px solid var(--border);
    padding:5rem 2rem; text-align:center; position:relative; overflow:hidden;
}
.cta-bg-lines {
    position:absolute; inset:0; pointer-events:none;
    background-image:linear-gradient(rgba(255,82,0,.04) 1px, transparent 1px),
                     linear-gradient(90deg, rgba(255,82,0,.04) 1px, transparent 1px);
    background-size:40px 40px;
}
.cta-content { position:relative; z-index:1; max-width:680px; margin:0 auto; }
#cta-banner h2 { font-family:var(--font-display); font-size:clamp(2rem,5vw,3.8rem); color:var(--text-light); margin-bottom:.9rem; letter-spacing:.04em; }
#cta-banner p  { color:var(--text-muted); font-size:1rem; margin-bottom:2rem; line-height:1.65; }
.cta-btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* ── FOOTER ─────────────────────────────── */
footer { background:var(--bg-mid); border-top:1px solid var(--border); }
.footer-top { padding:4rem 0; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:2.5rem; }
.footer-brand p { font-size:.88rem; color:var(--text-muted); line-height:1.65; margin:1rem 0 1.5rem; max-width:280px; }
.social-links { display:flex; gap:.65rem; }
.social-links a {
    width:38px; height:38px; border:1px solid var(--border); border-radius:var(--r);
    display:flex; align-items:center; justify-content:center;
    color:var(--text-muted); transition:all var(--ease); font-size:.9rem;
}
.social-links a:hover { border-color:var(--accent); color:var(--accent); background:var(--accent-glow); }
.footer-links h4, .footer-contact h4 {
    font-family:var(--font-ui); font-size:.75rem; font-weight:700;
    letter-spacing:.22em; text-transform:uppercase; color:var(--text-light);
    margin-bottom:1.1rem;
}
.footer-links ul { display:flex; flex-direction:column; gap:.5rem; }
.footer-links ul li a { font-size:.88rem; color:var(--text-muted); transition:color var(--ease); }
.footer-links ul li a:hover { color:var(--accent); }
.contact-item { display:flex; align-items:center; gap:.75rem; margin-bottom:.7rem; }
.contact-item i    { color:var(--accent); width:16px; text-align:center; font-size:.9rem; }
.contact-item span { font-size:.88rem; color:var(--text-muted); }
.footer-bottom { border-top:1px solid var(--border); padding:1.5rem 0; }
.footer-bottom .container, .footer-bottom-flex { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:.5rem; }
.footer-bottom p { font-size:.83rem; color:var(--text-muted); }
.footer-bottom i { color:var(--accent); }

/* ── CART SIDEBAR ─────────────────────── */
#cartSidebar {
    position:fixed; top:0; right:0; bottom:0; width:390px; z-index:200;
    background:var(--bg-mid); border-left:1px solid var(--border);
    transform:translateX(100%); transition:transform .3s cubic-bezier(.4,0,.2,1);
    display:flex; flex-direction:column;
}
#cartSidebar.open { transform:translateX(0); }
#cartOverlay {
    position:fixed; inset:0; background:rgba(0,0,0,.75); z-index:199;
    opacity:0; pointer-events:none; transition:opacity .3s ease;
}
#cartOverlay.active { opacity:1; pointer-events:all; }
.cart-header {
    padding:1.4rem 1.5rem; border-bottom:1px solid var(--border);
    display:flex; align-items:center; justify-content:space-between; flex-shrink:0;
}
.cart-header h3 { font-family:var(--font-display); font-size:1.35rem; letter-spacing:.08em; display:flex; align-items:center; gap:.6rem; }
.cart-header h3 i { color:var(--accent); }
.cart-header button { color:var(--text-muted); font-size:1.15rem; transition:color var(--ease); }
.cart-header button:hover { color:var(--accent); }
.cart-items { flex:1; overflow-y:auto; padding:1.25rem; }
.cart-empty { text-align:center; padding:3rem 0; color:var(--text-muted); }
.cart-empty i { font-size:2.8rem; margin-bottom:.9rem; display:block; opacity:.4; }
.cart-empty p { font-size:.9rem; }
.cart-item { display:flex; gap:1rem; padding:1rem 0; border-bottom:1px solid var(--border); align-items:flex-start; }
.cart-item-img { width:58px; height:58px; background:var(--bg-card); border-radius:var(--r); display:flex; align-items:center; justify-content:center; font-size:1.6rem; flex-shrink:0; border:1px solid var(--border); }
.cart-item-info { flex:1; }
.cart-item-name  { font-family:var(--font-ui); font-weight:700; font-size:.9rem; margin-bottom:.2rem; color:var(--text-light); }
.cart-item-size  { font-size:.75rem; color:var(--text-muted); margin-bottom:.25rem; }
.cart-item-price { font-size:.88rem; color:var(--accent); font-weight:600; }
.cart-item-actions { display:flex; align-items:center; gap:.5rem; margin-top:.4rem; }
.cart-qty-btn { width:24px; height:24px; border:1px solid var(--border); border-radius:3px; display:flex; align-items:center; justify-content:center; font-size:.75rem; color:var(--text-muted); transition:all var(--ease); }
.cart-qty-btn:hover { border-color:var(--accent); color:var(--accent); }
.cart-qty-num  { font-family:var(--font-ui); font-weight:700; font-size:.85rem; min-width:20px; text-align:center; }
.cart-item-remove { color:var(--text-muted); font-size:.82rem; transition:color var(--ease); margin-left:auto; }
.cart-item-remove:hover { color:#ef4444; }
.cart-footer { padding:1.25rem 1.5rem; border-top:1px solid var(--border); flex-shrink:0; }
.cart-total { display:flex; justify-content:space-between; align-items:center; margin-bottom:.5rem; font-family:var(--font-ui); font-weight:700; }
.cart-total span:first-child { color:var(--text-muted); font-size:.9rem; }
#cartTotal { color:var(--accent); font-family:var(--font-display); font-size:1.6rem; }

/* ── WHATSAPP FLOAT ─────────────────────── */
.whatsapp-float {
    position:fixed; bottom:2rem; right:2rem; z-index:150;
    width:58px; height:58px; border-radius:50%;
    background:#25d366; color:#fff;
    display:flex; align-items:center; justify-content:center;
    font-size:1.65rem; box-shadow:0 6px 24px rgba(37,211,102,.45);
    transition:all var(--ease);
}
.whatsapp-float:hover { background:#1ab553; transform:scale(1.1) translateY(-2px); }
.wa-tooltip {
    position:absolute; right:calc(100% + 12px); white-space:nowrap;
    background:rgba(0,0,0,.85); color:#fff; font-family:var(--font-ui);
    font-size:.75rem; font-weight:600; letter-spacing:.05em;
    padding:.4rem .9rem; border-radius:4px; opacity:0;
    transform:translateX(8px); transition:all .25s ease; pointer-events:none;
}
.whatsapp-float:hover .wa-tooltip { opacity:1; transform:translateX(0); }

/* ── PAGE HERO (inner pages) ─────────────── */
.page-hero {
    position:relative; padding:8rem 0 4rem; margin-top:68px;
    background:var(--bg-mid); border-bottom:1px solid var(--border); overflow:hidden;
}
.page-hero-bg {
    position:absolute; inset:0;
    background-image:
        linear-gradient(rgba(255,82,0,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,82,0,.04) 1px, transparent 1px);
    background-size:45px 45px;
}
.page-hero .container { position:relative; z-index:1; }
.page-title    { font-family:var(--font-display); font-size:clamp(3.5rem,9vw,7rem); color:var(--text-light); letter-spacing:.04em; line-height:.95; }
.page-subtitle { font-size:1rem; color:var(--text-muted); margin:.75rem 0 1.25rem; line-height:1.6; max-width:560px; }
.breadcrumb    { font-family:var(--font-ui); font-size:.75rem; color:var(--text-muted); letter-spacing:.1em; text-transform:uppercase; }
.breadcrumb a  { color:var(--accent); }

/* ── CATALOG CONTROLS ─────────────────── */
.catalog-controls { display:flex; justify-content:space-between; align-items:center; margin-bottom:2.5rem; flex-wrap:wrap; gap:1rem; }
.filter-tabs { display:flex; gap:.5rem; flex-wrap:wrap; }
.filter-tab {
    font-family:var(--font-ui); font-size:.78rem; font-weight:700;
    letter-spacing:.1em; text-transform:uppercase;
    padding:.5rem 1.2rem; border-radius:20px;
    border:1.5px solid var(--border-light); background:transparent; color:#777;
    transition:all var(--ease); cursor:pointer;
}
.filter-tab.active, .filter-tab:hover { background:var(--accent); border-color:var(--accent); color:#fff; }
.catalog-sort select {
    font-family:var(--font-ui); font-size:.85rem; font-weight:600;
    border:1.5px solid var(--border-light); background:#fff; color:#444;
    padding:.5rem 1rem; border-radius:var(--r); cursor:pointer;
    outline:none; transition:border-color var(--ease);
}
.catalog-sort select:focus { border-color:var(--accent); }

/* ── CUSTOM CTA ─────────────────────────── */
.custom-cta { padding:4rem 0; }
.custom-cta-inner { display:flex; align-items:center; justify-content:space-between; gap:2rem; flex-wrap:wrap; }
.custom-cta h2 { font-family:var(--font-display); font-size:2.2rem; color:var(--text-light); margin-bottom:.4rem; }
.custom-cta p  { color:var(--text-muted); font-size:.92rem; }

/* ── PRODUCT MODAL ─────────────────────── */
.modal { position:fixed; inset:0; z-index:500; display:none; align-items:center; justify-content:center; padding:1rem; }
.modal.open { display:flex; }
.modal-overlay { position:absolute; inset:0; background:rgba(0,0,0,.88); }
.modal-content {
    position:relative; z-index:1; background:var(--bg-mid);
    border:1px solid var(--border); border-radius:var(--r-lg);
    width:100%; max-width:720px; max-height:90vh; overflow-y:auto;
}
.modal-close { position:absolute; top:1rem; right:1rem; color:var(--text-muted); font-size:1.15rem; z-index:2; transition:color var(--ease); }
.modal-close:hover { color:var(--accent); }
.modal-body  { padding:2rem; }
.modal-product { display:grid; grid-template-columns:1fr 1fr; gap:2rem; }
.modal-img { aspect-ratio:1; background:#1a1a1f; border-radius:var(--r); display:flex; align-items:center; justify-content:center; font-size:5rem; overflow:hidden; }
.modal-img img { width:100%; height:100%; object-fit:cover; }
.modal-info h2 { font-family:var(--font-display); font-size:2rem; color:var(--text-light); margin-bottom:.4rem; letter-spacing:.04em; }
.modal-cat  { font-family:var(--font-ui); font-size:.72rem; color:var(--accent); letter-spacing:.15em; text-transform:uppercase; margin-bottom:.9rem; }
.modal-desc { font-size:.88rem; color:var(--text-muted); line-height:1.7; margin-bottom:1.25rem; }
.modal-price{ font-family:var(--font-display); font-size:2.4rem; color:var(--accent); margin-bottom:1.25rem; line-height:1; }
.modal-options label { display:block; font-family:var(--font-ui); font-size:.75rem; font-weight:700; color:var(--text-muted); letter-spacing:.1em; text-transform:uppercase; margin-bottom:.5rem; }
.size-btns { display:flex; gap:.5rem; flex-wrap:wrap; margin-bottom:1.25rem; }
.size-btn {
    font-family:var(--font-ui); font-size:.8rem; font-weight:700;
    padding:.45rem .9rem; border:1.5px solid var(--border); border-radius:var(--r);
    color:var(--text-muted); background:transparent; cursor:pointer; transition:all var(--ease);
}
.size-btn.active, .size-btn:hover { border-color:var(--accent); color:var(--accent); background:var(--accent-glow); }
.modal-qty-row { display:flex; align-items:center; gap:1rem; margin-bottom:1.25rem; }
.modal-qty-row label { font-family:var(--font-ui); font-size:.75rem; font-weight:700; color:var(--text-muted); letter-spacing:.1em; text-transform:uppercase; }
.qty-ctrl { display:flex; align-items:center; gap:.5rem; }
.qty-ctrl button { width:30px; height:30px; border:1.5px solid var(--border); border-radius:var(--r); display:flex; align-items:center; justify-content:center; font-size:.85rem; color:var(--text-muted); transition:all var(--ease); }
.qty-ctrl button:hover { border-color:var(--accent); color:var(--accent); }
.qty-ctrl span { font-family:var(--font-ui); font-weight:700; font-size:1rem; min-width:24px; text-align:center; }

/* ── ORDER PAGE ─────────────────────────── */
.order-type-tabs { display:flex; gap:.9rem; margin-bottom:3rem; justify-content:center; flex-wrap:wrap; }
.order-type-btn {
    display:flex; align-items:center; gap:.7rem;
    font-family:var(--font-ui); font-size:.95rem; font-weight:700;
    letter-spacing:.05em; text-transform:uppercase;
    padding:.95rem 2rem; border-radius:var(--r-lg);
    border:2px solid var(--border-light); background:#fff; color:#777;
    transition:all var(--ease); cursor:pointer;
}
.order-type-btn i { font-size:1.1rem; }
.order-type-btn.active, .order-type-btn:hover { border-color:var(--accent); color:var(--accent); background:rgba(255,82,0,.04); }

.order-layout { display:grid; grid-template-columns:1fr 340px; gap:3rem; align-items:start; }
.order-form-section { display:none; }
.order-form-section.active { display:block; }
.form-header  { margin-bottom:2.5rem; }
.form-header h2 { font-family:var(--font-display); font-size:2.2rem; color:#111; margin-bottom:.4rem; letter-spacing:.03em; }
.form-header p  { color:#666; font-size:.92rem; line-height:1.6; }

.form-section-title {
    font-family:var(--font-ui); font-size:.75rem; font-weight:800;
    letter-spacing:.22em; text-transform:uppercase; color:var(--accent);
    border-bottom:2px solid rgba(255,82,0,.18); padding-bottom:.5rem;
    margin:.9rem 0 1.4rem; display:flex; align-items:center; gap:.5rem; margin-top:2rem;
}
.cr-form .form-section-title:first-of-type { margin-top:0; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group { margin-bottom:.9rem; }
.form-group.full { grid-column:span 2; }
.form-group label {
    display:block; font-family:var(--font-ui); font-size:.75rem; font-weight:700;
    color:#444; letter-spacing:.06em; margin-bottom:.35rem; text-transform:uppercase;
}
.form-group input, .form-group select, .form-group textarea {
    width:100%; background:#fff; border:1.5px solid #ddd;
    border-radius:var(--r); padding:.75rem 1rem;
    font-size:.95rem; color:#333; transition:border-color var(--ease);
    appearance:auto;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
    outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(255,82,0,.1);
}
.form-group textarea { resize:vertical; min-height:100px; }
.payment-options { display:grid; grid-template-columns:repeat(4,1fr); gap:.75rem; margin-bottom:1.75rem; }
.payment-opt input { display:none; }
.payment-card {
    border:2px solid #ddd; border-radius:var(--r); padding:.9rem .5rem;
    text-align:center; cursor:pointer; transition:all var(--ease);
    display:flex; flex-direction:column; align-items:center; gap:.45rem;
}
.payment-card i    { font-size:1.4rem; color:#aaa; transition:color var(--ease); }
.payment-card span { font-family:var(--font-ui); font-size:.7rem; font-weight:700; color:#777; text-transform:uppercase; letter-spacing:.05em; }
.payment-opt input:checked + .payment-card { border-color:var(--accent); background:rgba(255,82,0,.05); }
.payment-opt input:checked + .payment-card i { color:var(--accent); }

.form-submit-row { margin-top:1.75rem; }
.form-note { text-align:center; font-size:.78rem; color:#999; margin-top:.9rem; line-height:1.5; }
.form-note i { color:var(--accent); }

.form-msg {
    padding:1rem 1.25rem; border-radius:var(--r); margin-bottom:1rem;
    font-family:var(--font-ui); font-size:.9rem; font-weight:600;
}
.form-msg.success { background:#f0fdf4; border:1.5px solid #22c55e; color:#15803d; }
.form-msg.error   { background:#fff1f2; border:1.5px solid #f87171; color:#b91c1c; }

/* Sidebar info cards */
.order-info-sidebar { display:flex; flex-direction:column; gap:1.25rem; position:sticky; top:88px; }
.info-card {
    background:#fff; border:1px solid var(--border-light); border-radius:var(--r-lg);
    padding:1.5rem;
}
.info-card h3 { font-family:var(--font-ui); font-size:.82rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:#333; margin-bottom:1rem; display:flex; align-items:center; gap:.5rem; }
.info-card h3 i { color:var(--accent); }
.info-list { display:flex; flex-direction:column; gap:.6rem; }
.info-list li { display:flex; align-items:center; justify-content:space-between; font-size:.88rem; gap:.5rem; }
.info-label { color:#666; }
.info-val    { font-weight:700; color:#333; text-align:right; }
.info-note   { font-size:.78rem; color:#999; margin-top:.75rem; line-height:1.55; }
.info-card-accent { background:rgba(255,82,0,.03); border-color:rgba(255,82,0,.2); }
.info-card p { font-size:.88rem; color:#666; line-height:1.6; }
.btn-loader  { margin-left:.3rem; }

/* ── SHIPPING PAGE ─────────────────────── */
.shipping-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.shipping-card {
    background:#fff; border:2px solid var(--border-light); border-radius:var(--r-lg);
    padding:2rem; position:relative; transition:all .3s ease;
}
.shipping-card:hover     { border-color:var(--accent); transform:translateY(-4px); box-shadow:0 14px 35px rgba(0,0,0,.1); }
.shipping-card.featured-ship { border-color:var(--accent); }
.ship-badge {
    position:absolute; top:-12px; left:50%; transform:translateX(-50%);
    background:var(--accent); color:#fff; font-family:var(--font-ui);
    font-size:.65rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase;
    padding:.3rem 1rem; border-radius:20px; white-space:nowrap;
}
.ship-icon  { font-size:2.4rem; color:var(--accent); margin-bottom:1rem; }
.shipping-card h3 { font-family:var(--font-ui); font-size:1.15rem; font-weight:700; color:#111; margin-bottom:.4rem; }
.ship-price { font-family:var(--font-display); font-size:1.7rem; color:var(--accent); margin-bottom:.9rem; line-height:1; }
.shipping-card p  { font-size:.88rem; color:#666; margin-bottom:1.2rem; line-height:1.55; }
.ship-features    { display:flex; flex-direction:column; gap:.5rem; }
.ship-features li { font-size:.84rem; color:#555; display:flex; align-items:center; gap:.5rem; }
.ship-features .fa-check { color:var(--green); font-size:.75rem; }

/* Timeline */
.timeline { max-width:720px; margin:0 auto; }
.timeline-item { display:flex; gap:2rem; margin-bottom:2.5rem; position:relative; }
.timeline-item::before { content:''; position:absolute; left:27px; top:58px; bottom:-22px; width:2px; background:var(--border); }
.timeline-item:last-child::before { display:none; }
.tl-dot {
    width:56px; height:56px; border-radius:50%; flex-shrink:0;
    background:var(--accent-glow); border:2px solid var(--accent);
    display:flex; align-items:center; justify-content:center;
    color:var(--accent); font-size:1.15rem;
}
.tl-day     { font-family:var(--font-ui); font-size:.72rem; font-weight:800; color:var(--accent); letter-spacing:.18em; text-transform:uppercase; margin-bottom:.35rem; }
.tl-content h3 { font-family:var(--font-ui); font-size:1.05rem; font-weight:700; color:var(--text-light); margin-bottom:.45rem; }
.tl-content p  { font-size:.88rem; color:var(--text-muted); line-height:1.65; }

/* Regions */
.regions-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:1.1rem; }
.region-card {
    background:#fff; border:1.5px solid var(--border-light); border-radius:var(--r-lg);
    padding:1.5rem 1.2rem; text-align:center; transition:all .3s ease; position:relative;
}
.region-card:hover     { border-color:var(--accent); transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.1); }
.region-card.featured-region { border-color:var(--accent); background:rgba(255,82,0,.03); }
.region-badge {
    position:absolute; top:-10px; left:50%; transform:translateX(-50%);
    background:var(--accent); color:#fff; font-family:var(--font-ui);
    font-size:.62rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase;
    padding:.2rem .8rem; border-radius:20px;
}
.region-card i      { color:var(--accent); font-size:1.4rem; margin-bottom:.75rem; display:block; }
.region-card h4     { font-family:var(--font-ui); font-weight:700; color:#111; margin-bottom:.35rem; font-size:.95rem; }
.region-card p      { font-size:.78rem; color:#888; margin-bottom:.6rem; line-height:1.45; }
.region-time        { display:block; font-family:var(--font-ui); font-size:.75rem; font-weight:700; color:#333; margin-bottom:.25rem; }
.region-price       { font-family:var(--font-display); font-size:1rem; color:var(--accent); }
.provinces-note     { font-size:.78rem; color:#888; text-align:center; margin-top:1.2rem; }

/* FAQ */
.faq-list { max-width:760px; margin:0 auto; }
.faq-item { border-bottom:1px solid var(--border); }
.faq-q {
    width:100%; text-align:left; padding:1.2rem 0;
    font-family:var(--font-ui); font-size:.98rem; font-weight:600; color:var(--text-light);
    display:flex; justify-content:space-between; align-items:center; gap:1rem;
    transition:color var(--ease); cursor:pointer;
}
.faq-q:hover, .faq-item.open .faq-q { color:var(--accent); }
.faq-q i { transition:transform var(--ease); color:var(--text-muted); flex-shrink:0; }
.faq-item.open .faq-q i { transform:rotate(180deg); color:var(--accent); }
.faq-a { display:none; padding-bottom:1.2rem; }
.faq-a p { font-size:.88rem; color:var(--text-muted); line-height:1.75; }
.faq-item.open .faq-a { display:block; }

/* ── SCROLL REVEAL ─────────────────────── */
.reveal { opacity:0; transform:translateY(24px); transition:opacity .6s ease, transform .6s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ── RESPONSIVE ─────────────────────────── */
@media (max-width:1100px) {
    .cat-grid { grid-template-columns:1fr 1fr; }
    .cat-main { grid-column:span 2; }
    .features-grid { grid-template-columns:repeat(2,1fr); }
    .footer-grid { grid-template-columns:1fr 1fr; gap:2rem; }
    .order-layout { grid-template-columns:1fr; }
    .order-info-sidebar { position:static; display:grid; grid-template-columns:repeat(2,1fr); gap:1rem; }
    .info-card-accent { grid-column:span 2; }
    .shipping-cards { grid-template-columns:1fr; max-width:480px; margin:0 auto; }
    .regions-grid { grid-template-columns:repeat(3,1fr); }
}
@media (max-width:768px) {
    #nav { display:none; }
    .mobile-toggle { display:flex; }
    #hero { flex-direction:column; text-align:center; justify-content:center; }
    .hero-content { padding:2rem 1.5rem; max-width:100%; }
    .hero-visual { display:none; }
    .hero-stats, .hero-btns { justify-content:center; }
    .features-grid { grid-template-columns:1fr; }
    .testimonials-grid { grid-template-columns:1fr; }
    .process-steps { flex-direction:column; align-items:center; }
    .step-arrow { transform:rotate(90deg); margin:0; align-self:center; }
    .footer-grid { grid-template-columns:1fr; }
    .footer-bottom .container { flex-direction:column; text-align:center; }
    #cartSidebar { width:100%; }
    .form-row { grid-template-columns:1fr; }
    .form-group.full { grid-column:span 1; }
    .payment-options { grid-template-columns:repeat(2,1fr); }
    .modal-product { grid-template-columns:1fr; }
    .order-info-sidebar { grid-template-columns:1fr; }
    .info-card-accent { grid-column:span 1; }
    .order-type-tabs { flex-direction:column; }
    .custom-cta-inner { flex-direction:column; text-align:center; }
    .regions-grid { grid-template-columns:repeat(2,1fr); }
    .cta-btns { flex-direction:column; align-items:center; }
    .section-dark, .section-light { padding:4rem 0; }
    .container { padding:0 1.25rem; }
    .header-inner { padding:0 1.25rem; }
    .cat-grid { grid-template-columns:1fr; }
    .cat-main { grid-column:span 1; min-height:260px; }
}
@media (max-width:480px) {
    .products-grid, .catalog-grid { grid-template-columns:1fr; }
    .regions-grid { grid-template-columns:1fr; }
    .shipping-cards { grid-template-columns:1fr; }
    .catalog-controls { flex-direction:column; }
    .hero-title .line1 { font-size:3rem; }
    .hero-title .line2 { font-size:2.6rem; }
    .hero-title .line3 { font-size:3rem; }
}
