/* File: assets/styles/app.css */

/* ==========================================================================
   Design System
   ========================================================================== */
:root {
    --color-brand-primary: #14213D;
    --color-brand-secondary: #FCA311;
    --color-brand-accent: #C49A50;
    --color-hover-light: #e6eaef;
    --color-hover-dark: #2f3e5a;
    --color-bg-primary: #14213D;
    --color-bg-secondary: #FCA311;
    --color-bg-accent: #C49A50;
    --color-bg-dark: #0F1F2F;
    --color-bg-darker: #0A1520;
    --color-bg-light: #f5f5f5;
    --color-bg-body: #fff;
    --color-text-primary: #14213D;
    --color-text-secondary: #FCA311;
    --color-text-accent: #C49A50;
    --color-text-base: #333;
    --color-text-light: #fff;
    --color-text-dark: #0F1F2F;
    --color-text-title: #0A1520;
    --partner-premium-bg: #c3d2ff;
    --newsletter-bg: #C49A50;
    --newsletter-text: #fff;
    --newsletter-input-border: rgba(255, 255, 255, .3);
    --newsletter-input-bg: transparent;
    --newsletter-button-bg: #fff;
    --newsletter-button-color: #C49A50;
    --newsletter-button-hover: rgba(255, 255, 255, .9);
    --newsletter-error-bg: rgba(139, 0, 0, .9);
    --newsletter-success-bg: rgba(0, 100, 0, .9);
    --shadow-sm: rgba(0, 0, 0, .1) 0 1px 3px;
    --shadow-md: rgba(0, 0, 0, .24) 0 3px 8px;
    --container-width: 1100px;
    --header-height: 85px;
    --header-height-mobile: 70px;
    --font-primary: "Roboto Flex", serif, Arial, sans-serif;
    --transition-fast: 0.2s ease-in-out;
    --transition-base: 0.3s ease;
    --color-success: #22c55e;
}

[data-theme='dark'] {
    --color-bg-primary: #14213D;
    --color-bg-secondary: #FCA311;
    --color-bg-accent: #C49A50;
    --color-bg-dark: #1a2738;
    --color-bg-darker: #14213D;
    --color-bg-light: #243147;
    --color-bg-body: #1e2942;
    --color-hover-light: #2f3e5a;
    --color-hover-dark: #1a2738;
    --color-text-primary: #e6edf7;
    --color-text-secondary: #FCA311;
    --color-text-accent: #C49A50;
    --color-text-base: #e6edf7;
    --color-text-light: #fff;
    --color-text-dark: #e6edf7;
    --color-text-title: #FCA311;
    --partner-premium-bg: #4A78AA85;
    --newsletter-bg: #8B6B3E;
    --newsletter-text: #fff;
    --newsletter-input-border: rgba(255, 255, 255, .5);
    --newsletter-input-bg: rgba(0, 0, 0, .1);
    --newsletter-button-bg: #1e2942;
    --newsletter-button-color: #C49A50;
    --newsletter-button-hover: rgba(30, 41, 66, .9);
    --newsletter-error-bg: rgba(139, 0, 0, .95);
    --newsletter-success-bg: rgba(0, 100, 0, .95);
    --shadow-sm: rgba(0, 0, 0, .25) 0 1px 3px;
    --shadow-md: rgba(0, 0, 0, .45) 0 3px 8px;
}

@media (min-width:768px){.md\:p-0{padding:0}
    .md\:p-1{padding:.25rem}
    .md\:p-2{padding:.5rem}
    .md\:p-3{padding:1rem}
    .md\:p-4{padding:1.5rem}
    .md\:p-5{padding:2rem}
    .md\:m-0{margin:0}
    .md\:m-1{margin:.25rem}
    .md\:m-2{margin:.5rem}
    .md\:m-3{margin:1rem}
    .md\:m-4{margin:1.5rem}
    .md\:m-5{margin:2rem}
    .md\:gap-1{gap:.25rem}
    .md\:gap-2{gap:.5rem}
    .md\:gap-3{gap:1rem}
    .md\:gap-4{gap:1.5rem}
    .md\:gap-5{gap:2rem}}

/* ==========================================================================
   Base Styles
   ========================================================================== */
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{font-family:var(--font-primary);line-height:1.6;display:flex;flex-direction:column;min-height:100vh;color:var(--color-text-base);background-color:var(--color-bg-body)}
.page-wrapper{display:flex;flex-direction:column;min-height:100vh}
.main-content{flex:1;display:flex;flex-direction:column}

/* ==========================================================================
  Content HTML Elements
  ========================================================================== */
.product-text,
.blog-text,
.products-description,
.service-text{
    line-height:1.6}

.product-text a,
.blog-text a,
.products-description a,
.service-text a{color:var(--color-text-primary);text-decoration:underline;transition:color var(--transition-base)}

.product-text a:hover,
.blog-text a:hover,
.products-description a:hover,
.service-text a:hover{color:var(--color-text-accent)}

.product-text b,
.blog-text b,
.products-description b,
.service-text b,
.product-text strong,
.blog-text strong,
.products-description strong,
.service-text strong{font-weight:700}

.product-text div,
.blog-text div,
.products-description div,
.service-text div{margin:1em 0}

.product-text em,
.blog-text em,
.products-description em,
.service-text em{font-style:italic}

.product-text h2,
.blog-text h2,
.products-description h2,
.service-text h2{font-size:1.5em;margin:1.5em 0 0.5em;color:var(--color-text-primary)}

.product-text h3,
.blog-text h3,
.products-description h3,
.service-text h3{font-size:1.25em;margin:1.5em 0 0.5em;color:var(--color-text-primary)}

.product-text h4,
.blog-text h4,
.products-description h4,
.service-text h4{font-size:1.1em;margin:1.5em 0 0.5em;color:var(--color-text-primary)}

.product-text h5,
.blog-text h5,
.products-description h5,
.service-text h5{font-size:1em;margin:1.5em 0 0.5em;color:var(--color-text-primary)}

.product-text iframe,
.blog-text iframe,
.products-description iframe,
.service-text iframe{max-width:100%;margin:1em 0;border:none}

.product-text img,
.blog-text img,
.products-description img,
.service-text img{max-width:100%;height:auto;margin:1em 0;box-shadow:var(--shadow-md)}

.product-text li,
.blog-text li,
.products-description li,
.service-text li{margin:0.5em 0}

.product-text ol,
.blog-text ol,
.products-description ol,
.service-text ol{margin:1em 0 1em 1.5em}

.product-text p,
.blog-text p,
.products-description p,
.service-text p{margin:1em 0}

.product-text section,
.blog-text section,
.products-description section,
.service-text section{margin:2em 0}

.product-text span,
.blog-text span,
.products-description span,
.service-text span{display:inline}

.product-text ul,
.blog-text ul,
.products-description ul,
.service-text ul{margin:1em 0 1em 1.5em;list-style:disc}

.product-text li:before,
.blog-text li:before,
.products-description li:before,
.service-text li:before{content:none}

/* ==========================================================================
   Layout
   ========================================================================== */
.container{max-width:var(--container-width);margin:0 auto;padding:0 20px}

/* ==========================================================================
   Utility Classes
   ========================================================================== */
.bg-primary {
    background-color: var(--color-bg-primary);
}

.transition {
    transition: all var(--transition-base);
}

.transition-fast {
    transition: all var(--transition-fast);
}

.shadow-md {
    box-shadow: var(--shadow-md);
}


/* ==========================================================================
   Top Navigation
   ========================================================================== */
.top-nav{position:fixed;top:0;z-index:1000;background-color:var(--color-bg-primary);width:100%}
.top-nav .container{display:flex;justify-content:space-between;align-items:center;position:relative;height:var(--header-height)}
.nav-logo{display:block;flex-shrink:0;margin-right:20px}
.nav-logo img{display:block;width:100px;height:65px;object-fit:contain;transition:transform var(--transition-base)}
.nav-logo:hover img{transform:scale(1.1)}
.nav-menu{list-style:none;display:flex;justify-content:center;margin:0;padding:0;flex-grow:1;height:100%}
.nav-menu li{height:100%;display:flex;align-items:stretch}
.nav-menu a{color:var(--color-text-light);text-decoration:none;padding:0 15px;display:flex;align-items:center;transition:all var(--transition-fast)}
.nav-menu a:hover{color:var(--color-text-primary);background-color:var(--color-bg-secondary)}
.nav-menu a.active{color:var(--color-text-secondary)}
.nav-menu a.active:hover{color:var(--color-text-primary)}
.menu-image{padding:0 15px}
.menu-image a{padding:6px!important}
.menu-image img{height:40px;width:auto}
.nav-controls{display:flex;align-items:center;gap:5px}
.mobile-menu-toggle{display:none;background:none;border:none;padding:10px;cursor:pointer}
.hamburger{color:var(--color-text-light);font-size:24px;transition:transform var(--transition-base)}
.mobile-menu-toggle.active .hamburger{transform:rotate(180deg)}
.nav-menu .home-link{width:85px;justify-content:center}
.nav-menu .home-link i{font-size:1.2em}

@media (max-width:768px){
    .top-nav .container{height:var(--header-height-mobile)}
    .nav-logo img{width:77px;height:50px}
    .mobile-menu-toggle{display:block}
    .nav-menu{display:block;position:absolute;top:100%;left:0;right:0;background:var(--color-bg-primary);padding:0;margin:0;z-index:1000;border-top:1px solid rgba(255,255,255,.1);height:auto;opacity:0;visibility:hidden;transform:translateY(-10px);box-shadow:var(--shadow-md)}
    .nav-menu.animate{transition:all var(--transition-base)}
    .nav-menu.active{opacity:1;visibility:visible;transform:translateY(0)}
    .nav-menu li{width:100%;height:auto}
    .nav-menu li.menu-image{display:none}
    .nav-menu a{width:100%;padding:15px;justify-content:center;border-bottom:1px solid rgba(255,255,255,.1)}
    .nav-menu a:hover{background-color:var(--color-bg-secondary);color:var(--color-text-primary)}}

/* ==========================================================================
   Theme toggle button
   ========================================================================== */
.theme-toggle{background:none;border:none;padding:10px;cursor:pointer;position:relative;width:85px;height:85px;transition:background var(--transition-fast)}
.theme-toggle:hover{background:var(--color-bg-secondary)}
.theme-toggle i{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:32px;text-align:center;font-size:24px;color:rgba(255,255,255,0.5);transition:opacity var(--transition-base),transform var(--transition-base),color var(--transition-base);opacity:0}
.theme-toggle:hover i{color:var(--color-text-primary)}
.theme-toggle i.active{opacity:1}
.theme-toggle i.fa-moon{transform:translate(-50%,-50%) rotate(-30deg)}
.theme-toggle i.fa-moon.active{transform:translate(-50%,-50%) rotate(0)}
.theme-toggle i.fa-sun{transform:translate(-50%,-50%) rotate(30deg)}
.theme-toggle i.fa-sun.active{transform:translate(-50%,-50%) rotate(0)}

@media (max-width:768px){
    .theme-toggle{height:70px}}

/* ==========================================================================
   Main Content Area
   ========================================================================== */
.content{padding:calc(var(--header-height) + 40px) 0 40px;flex:1}
.content h1{font-size:2.5em;margin-bottom:30px;color:var(--color-text-primary)}

/* ==========================================================================
   Section Headers
   ========================================================================== */
.section-header{color:var(--color-text-primary);font-size:1.5em;margin-bottom:15px;position:relative}
.section-header::after{content:'';display:block;width:100%;height:1px;background:var(--color-bg-secondary);margin-top:10px}

/* ==========================================================================
   Contact
   ========================================================================== */
.contact-section{margin-bottom:40px}
.contact-section h2{composes:section-header}
.contact-section address{margin:20px 0;font-style:normal}
.contact-info{margin-top:20px}
.contact-info p{margin-bottom:8px}
.contact-info a{color:inherit;text-decoration:none;transition:color var(--transition-base)}
.contact-info a:hover{color:var(--color-text-accent)}
.contact-info i{margin-right:4px;color:var(--color-text-primary)}
.contact-wrapper{display:grid;grid-template-columns:1fr;gap:40px}
.contact-map{height:588px;box-shadow:var(--shadow-md);display:none;width:497px;justify-self:end;position:relative}
.map-recenter{position:absolute;top:10px;right:10px;z-index:1000;width:40px;height:40px;border:none;border-radius:4px;background:var(--color-bg-primary);color:var(--color-text-light);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2em;box-shadow:var(--shadow-md)}
.map-recenter:hover{background:var(--color-bg-secondary)}
@media(min-width:768px){.contact-wrapper{grid-template-columns:1fr 497px}
    .contact-map{display:block}}

/* ==========================================================================
   Partners Search
   ========================================================================== */
.partners-header{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-bottom:30px}
.partners-header h1{margin:0}
.partners-search-form{display:flex;gap:10px;align-items:center}
.partners-search-input-wrapper{position:relative;display:flex;align-items:center}
.partners-search-input{padding:8px 40px 8px 12px;border:1px solid #ddd;border-radius:4px;width:250px;font-size:14px}
.partners-search-clear{position:absolute;right:8px;padding:6px 8px;color:#999;text-decoration:none;transition:color 0.2s}
.partners-search-clear:hover{color:#666}
.partners-search-button{padding:8px 16px;font-size:14px;display:inline-flex;align-items:center;gap:5px}
.search-results-info{margin-bottom:20px;padding:10px 15px;background-color:var(--color-bg-light);border-radius:4px}
.search-results-info p{margin:0}
.no-results{text-align:center;padding:80px 20px}
.no-results p{margin:0;font-size:1.5rem;color:var(--color-text-secondary);font-weight:500}

/* Mobile responsive for partners header */
@media (max-width: 768px) {
    .partners-header{flex-direction:column;align-items:flex-start;gap:15px}
    .partners-search-form{width:100%;flex-direction:column}
    .partners-search-input{width:100%}
    .partners-search-button{width:100%;justify-content:center}
}

/* ==========================================================================
   Dealer Cards
   ========================================================================== */
.dealers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:30px;margin-top:20px}
.dealer-card{background:var(--color-bg-light);box-shadow:var(--shadow-md);display:flex;flex-direction:column;min-height:350px;height:100%;transition:background-color var(--transition-base)}
.dealer-card.partner-premium{background-color:var(--partner-premium-bg)}
.dealer-card:hover{background:var(--color-hover-light)}
.dealer-card i{margin-right:4px}
.dealer-card a{text-decoration:none;transition:color var(--transition-base)}
.dealer-card a:hover{color:var(--color-text-accent)}
.dealer-name{padding:20px 20px 10px}
.dealer-name h3{color:var(--color-text-title)}
.dealer-name a{color:var(--color-text-title)}
.dealer-info{padding:0 20px}
.dealer-info a{color:var(--color-text-base)}
.dealer-features{padding:0 20px 40px;flex-grow:1}
.dealer-features ul{margin:0;padding:0;list-style:none}
.dealer-features li{font-size:.9em;line-height:1.6}
.dealer-web{padding:20px;margin-top:auto}
.dealer-web a{color:var(--color-text-base)}
.dealer-strip{height:4px;background-color:var(--color-bg-secondary);margin:0}
.dealer-contact{background:var(--color-bg-primary);color:var(--color-text-light);padding:15px}
.dealer-contact a{color:var(--color-text-light)}
.dealer-contact a:hover{color:var(--color-text-accent)}
.dealers-section{padding-bottom:40px}

/* ==========================================================================
   Footer
   ========================================================================== */
.footer{background:var(--color-bg-primary);color:var(--color-text-light);padding:40px 0;font-size:0.95em;display:block}
.footer-grid{display:grid;grid-template-columns:1fr minmax(250px,25%);gap:30px}
.footer-section h3{margin-bottom:15px}
.footer-section ul{list-style:none}
.footer-section a{color:var(--color-text-light);text-decoration:none;transition:color var(--transition-base)}
.footer-section a:hover{color:var(--color-text-accent)}
.footer-section.footer-about p+p{margin-top:20px}
.footer-section .fa-brands{font-size:2em;padding-right:10px}
@media(max-width:767px){
.footer{padding:30px 0}
.footer-grid{grid-template-columns:1fr;gap:15px}
.footer-section.footer-about{display:none}
}

/* ==========================================================================
   Brands
   ========================================================================== */
.brands{background:var(--color-bg-dark);padding:20px 0;display:none}
.brands-grid{display:flex;justify-content:center;align-items:center;gap:20px;flex-wrap:wrap}
.brands-grid img{height:16px;width:auto;object-fit:contain;transition:transform var(--transition-base)}
.brands-grid img:hover{transform:scale(1.2)}
@media(min-width:768px){.brands{display:block}}

/* ==========================================================================
   Credits
   ========================================================================== */
.credits{background:var(--color-bg-darker);padding:10px 0}
.credits-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.credits-left{text-align:left;opacity:.5;color:var(--color-text-light)}
.credits-right{text-align:right;opacity:.5;color:var(--color-text-light);font-size:11px}
.credits-right i{color:#ff0000}

@media (max-width:768px){
    .credits-grid{grid-template-columns:1fr}
    .credits-left{display:none}}

/* ==========================================================================
   Service
   ========================================================================== */
.service-section{margin-bottom:60px}
.service-section h2{composes:section-header}
.service-grid{display:grid;grid-template-columns:1fr;gap:30px;margin-top:30px}
.service-image{display:flex;flex-direction:column;gap:30px}
.service-image img{display:block;width:100%;height:auto;box-shadow:var(--shadow-md)}
.service-content p{margin-bottom:1em;line-height:1.6}
.service-content p:last-child{margin-bottom:0}
.service-content h4{color:var(--color-text-secondary);font-size:1.2em;margin-bottom:15px}
.service-text{padding:20px 0}
.service-text:first-child{padding-top:0}
.service-text h3{color:var(--color-text-primary);font-size:1.2em;margin-bottom:15px}
.service-text ul{margin:0 0 0 20px}

@media(min-width:768px){
    .service-grid{grid-template-columns:1fr 400px}}

/* ==========================================================================
   Blog
   ========================================================================== */
.blog-section{margin-bottom:60px}
.blog-section h2.section-header{color:var(--color-text-primary);font-size:1.5em;margin-bottom:15px;position:relative}
.blog-section h2.section-header::after{content:'';display:block;width:100%;height:1px;background:var(--color-bg-secondary);margin-top:10px}
.blog-grid{display:grid;grid-template-columns:1fr;gap:30px;margin-top:30px}
.blog-image{display:flex;flex-direction:column;gap:30px}
.blog-image img{display:block;width:100%;height:auto;box-shadow:var(--shadow-md)}
.blog-content p{margin-bottom:1em;line-height:1.6}
.blog-content p:last-child{margin-bottom:0}
.blog-text{padding:20px 0}
.blog-text:first-child{padding-top:0}
.blog-text h2{color:var(--color-text-primary);font-size:1.2em;margin-bottom:15px}
.blog-text h3{color:var(--color-text-primary);font-size:1.1em;margin-bottom:15px}
.blog-text ul{margin:0 0 0 20px}
.blog-text a{color:inherit;text-decoration:underline;transition:color var(--transition-base)}
.blog-text a:hover{color:var(--color-text-accent)}
@media(min-width:768px){.blog-grid{grid-template-columns:1fr 400px}}

/* ==========================================================================
   Blog Index
   ========================================================================== */
.blog-index-section{margin-bottom:60px}
.blog-index-section h1{color:var(--color-text-light);font-size:1.5em;margin-bottom:15px;position:relative}
.blog-index-section h1::after{content:'';display:block;width:100%;height:1px;background:var(--color-bg-secondary);margin-top:10px}
.blog-index-grid{display:grid;grid-template-columns:repeat(3,calc((100% - 60px) / 3));gap:30px;margin-top:20px}
.blog-index-card{display:block;text-decoration:none;box-shadow:var(--shadow-md);aspect-ratio:1/1;position:relative;overflow:hidden}
.blog-index-card-bg{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;background-repeat:no-repeat;background-color:#ffffff;z-index:1;transition:transform var(--transition-base),filter var(--transition-base)}
.blog-index-card:hover .blog-index-card-bg{transform:scale(1.05);filter:brightness(1.15)}
.blog-index-card-content{position:relative;z-index:2;background:linear-gradient(to top,rgba(0,0,0,0.8),transparent);height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:30px 20px}
.blog-index-title{color:var(--color-text-light);font-size:1.5em;text-shadow:1px 1px 3px rgba(0,0,0,0.5);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.2;height:2.4em;transition:color var(--transition-base)}
.blog-index-card:hover .blog-index-title{color:var(--color-text-accent)}
@media(max-width:1000px){.blog-index-grid{grid-template-columns:repeat(2,calc((100% - 30px) / 2))}}
@media(max-width:650px){.blog-index-grid{grid-template-columns:100%}}

/* ==========================================================================
  Products
  ========================================================================== */
.products-wrapper{display:grid;grid-template-columns:300px 1fr;gap:30px;margin-top:20px}
.product-groups{background:var(--color-bg-light);padding:17px;border-radius:4px}
.group-tree{display:flex;flex-direction:column;gap:4px;position:relative}
.group-tree:before{content:'';position:absolute;top:0;bottom:17px;left:18px;width:2px;background:color-mix(in srgb,var(--color-bg-secondary) 70%,black)}
.group-item{position:relative}
.group-item>.group-link{color:var(--color-text-accent)}
.group-item>.group-link i{transition:transform var(--transition-base);color:var(--color-bg-secondary);background:var(--color-bg-light);position:relative;z-index:1;outline:2px solid var(--color-bg-secondary);border-radius:50%;font-size:0.95em}
.group-item.active>.group-link i{transform:rotate(90deg)}
.group-link{display:flex;align-items:center;gap:10px;padding:7px 12px;text-decoration:none;border-radius:4px}
.group-link:hover{background:var(--color-hover-light);color:var(--color-text-primary)}
.group-link.active{background:var(--color-bg-secondary);color:var(--color-text-primary)}
.group-item.active>.group-link{background:var(--color-bg-primary);color:var(--color-text-light)}
.group-item.active .group-children .group-link{background:transparent;padding:1px 12px}
.group-item.active .group-children .group-link:hover{background:var(--color-hover-light)}
.group-children{display:flex;flex-direction:column;gap:0;margin:0 0 0 18px;padding-left:16px;font-size:0.85em;margin-top:-2px;margin-bottom:2px}
.group-children .group-link{color:var(--color-text-base);padding:3px 12px}
.products-content{display:flex;flex-direction:column;gap:30px}
.products-content h2.section-header{color:var(--color-text-primary);font-size:1.5em;margin-bottom:15px;position:relative}
.products-content h2.section-header::after{content:'';display:block;width:100%;height:1px;background:var(--color-bg-secondary);margin-top:10px}
.products-description{color:var(--color-text-base);line-height:1.6}
.products-grid{display:grid;grid-template-columns:repeat(3,calc((100% - 60px) / 3));gap:30px}
.product-card{box-shadow:var(--shadow-md);position:relative;overflow:hidden;aspect-ratio:1/1;background-color:#ffffff}
.product-card-bg{position:absolute;top:4px;left:4px;width:calc(100% - 8px);height:calc(100% - 8px);background-size:contain;background-position:center;background-repeat:no-repeat;background-color:#ffffff;z-index:1;transition:transform var(--transition-base),filter var(--transition-base)}
.product-card:hover .product-card-bg{transform:scale(1.05);filter:brightness(1.15)}
.product-card-content{position:absolute;bottom:0;left:0;right:0;z-index:2;background:linear-gradient(to top,rgba(0,0,0,0.8),transparent);padding:20px}
.product-title{color:var(--color-text-light);font-size:1.2em;text-shadow:1px 1px 3px rgba(0,0,0,0.5);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;white-space:normal;line-height:1.2;max-height:2.4em;transition:color var(--transition-base)}
.product-card:hover .product-title{color:var(--color-text-accent)}
.product-text img{background-color:#ffffff}
@media(max-width:1000px){
    .products-wrapper{grid-template-columns:250px 1fr}
    .products-grid{grid-template-columns:repeat(2,calc((100% - 30px) / 2))}
}
@media(max-width:768px){
    .products-wrapper{grid-template-columns:1fr}
    .product-groups{display:none}
    .products-grid{grid-template-columns:repeat(2,calc((100% - 30px) / 2))}
}

/* ==========================================================================
  Product Details
  ========================================================================== */
.product-section{margin-bottom:60px}
.product-section h2.section-header{color:var(--color-text-primary);margin-bottom:15px;position:relative;font-size:1.5em}
.product-section h3.section-header{color:var(--color-text-primary);margin-bottom:15px;position:relative;font-size:1.2em}
.product-section h4.section-header{color:var(--color-text-primary);margin-bottom:15px;position:relative;font-size:1.1em}
.product-section .section-header::after{content:'';display:block;width:100%;height:1px;background:var(--color-bg-secondary);margin-top:10px}
.product-section .brand-wrapper{position:absolute;right:0;top:0;display:flex;align-items:center;gap:8px}
.product-section .brand-icon{height:32px;max-width:120px;object-fit:contain;vertical-align:middle}
.product-grid{display:grid;grid-template-columns:1fr;gap:30px;margin-top:30px}
.product-side{display:flex;flex-direction:column;gap:30px;order:-1}
.product-price{width:100%;font-size:1.5em;font-weight:700;border-radius:4px}
.product-image{display:grid;grid-template-columns:100%;gap:30px}
.product-image-container{position:relative;overflow:hidden}
.product-image-container .product-thumbnail,
.product-image-container .product-fullsize{display:block;position:absolute;top:0;left:0;width:100%;height:100%;background-color:#ffffff;box-shadow:var(--shadow-md)}
.product-image-container .product-thumbnail{position:relative}
.product-loading-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.3);display:flex;align-items:center;justify-content:center;z-index:10}
.product-loading-overlay img{width:40px;height:40px;animation:spin 1s linear infinite}
.product-image .main-image{width:100%;height:300px;grid-column:1/-1}
.product-image .main-image img{object-fit:contain}
.product-image .gallery-image{width:100%;height:150px}
.product-image .gallery-image img{object-fit:contain}
.product-image:has(.gallery-image){grid-template-columns:repeat(2,1fr)}
.product-colors{display:grid;grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:20px;margin-top:30px}
.product-color{width:50px;height:50px;border-radius:50%;display:block;box-shadow:var(--shadow-sm);transition:transform var(--transition-base);position:relative}
.product-color:hover{transform:scale(1.1)}
.product-color:hover::after{content:attr(data-name);position:absolute;bottom:calc(100% + 5px);left:50%;transform:translateX(-50%);background:var(--color-bg-primary);color:var(--color-text-light);padding:5px 10px;border-radius:4px;font-size:0.9em;white-space:nowrap}
.product-content p{margin-bottom:1em;line-height:1.6}
.product-content p:last-child{margin-bottom:0}
.product-text{padding:20px 0}
.product-text:first-child{padding-top:0}
.product-text h2{color:var(--color-text-primary);font-size:1.2em;margin-bottom:15px}
.product-text h3{color:var(--color-text-primary);font-size:1.1em;margin-bottom:15px}
.product-text ul{list-style:none;margin:0 0 0 20px}
.product-text li{position:relative}
.product-text li:before{content:'•';position:absolute;left:-15px;color:var(--color-text-secondary)}
.product-text a{color:inherit;text-decoration:underline;transition:color var(--transition-base)}
.product-text a:hover{color:var(--color-text-accent)}
@media(min-width:768px){
    .product-grid{grid-template-columns:1fr 400px}
    .product-side{order:2}
}

/* ==========================================================================
   Product Lightbox
   ========================================================================== */
.product-lightbox{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(to bottom,rgba(15,31,47,.95),rgba(10,21,32,.98));z-index:2000;display:flex;align-items:center;justify-content:center;padding:40px;opacity:0;visibility:hidden;transition:opacity 0.3s ease-in-out,visibility 0.3s ease-in-out}
.product-lightbox.active{opacity:1;visibility:visible}
.product-lightbox-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60px;height:60px;z-index:10;background:rgba(255,255,255,0.9);border-radius:50%;padding:10px;box-shadow:0 2px 8px rgba(0,0,0,0.3)}
.product-lightbox-loading img{width:100%;height:100%;animation:spin 1s linear infinite}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.product-lightbox-image{width:80%;height:80%;display:flex;align-items:center;justify-content:center;transform:scale(0.8);opacity:0;transition:transform 0.3s ease-out,opacity 0.3s ease-out}
.product-lightbox.active .product-lightbox-image{transform:scale(1);opacity:1;transition-delay:0.1s}
.product-lightbox-image img{max-width:100%;max-height:100%;object-fit:contain;background:#fff;padding:4px;background-clip:padding-box;border:4px solid #e1e1e1;box-shadow:var(--shadow-md)}
.product-lightbox-close{position:absolute;top:20px;right:20px;background:none;border:none;color:rgba(255,255,255,.8);font-size:24px;cursor:pointer;padding:10px;transition:color var(--transition-base)}
.product-lightbox-close:hover{color:var(--color-text-accent)}
.product-lightbox-button{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;color:rgba(255,255,255,.3);padding:16px;cursor:pointer;transition:color var(--transition-base);z-index:2;font-size:2em}
.product-lightbox-button:hover{color:var(--color-text-accent)}
.product-lightbox-button.prev{left:20px}
.product-lightbox-button.next{right:20px}

/* ==========================================================================
   Custom Error Page
   ========================================================================== */
.error-content{text-align:center;padding:40px 0}
.error-content p{margin-bottom:30px}
.error-button{display:inline-block;padding:12px 30px;background-color:var(--color-bg-primary);color:var(--color-text-light);text-decoration:none;font-weight:bold;border:2px solid var(--color-brand-primary)}
.error-button:hover{background-color:var(--color-bg-secondary);color:var(--color-text-primary);border-color:var(--color-brand-secondary)}

/* ==========================================================================
   Size Table
   ========================================================================== */
.size-table-wrapper{overflow-x:auto;margin-top:30px}
.size-table-wrapper a,
.size-table-link{color:var(--color-text-primary);text-decoration:none;transition:color var(--transition-base)}
.size-table-wrapper a:hover,
.size-table-link:hover{color:var(--color-text-accent)}
.size-table{width:100%;border-collapse:collapse;min-width:600px}
.size-table th,.size-table td{padding:8px 12px;text-align:center;border:1px solid var(--newsletter-input-border);transition:background-color var(--transition-base)}
.size-table thead th{background:var(--color-bg-primary);color:var(--color-text-light);font-weight:500}
.size-table tbody th{background:var(--color-bg-light);font-weight:500}
.size-table td{background:var(--color-bg-body)}
.size-table td:hover{background:var(--color-hover-light)}

.available-sizes{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.size-badge{background:var(--color-bg-light);padding:8px 16px;border-radius:4px;transition:all var(--transition-base)}
.size-badge:hover{background:var(--color-hover-light);transform:translateY(-2px)}

/* ==========================================================================
   Login Form
   ========================================================================== */
.login-section{max-width:400px;margin:40px auto;background:var(--color-bg-light);padding:30px;border-radius:8px;box-shadow:var(--shadow-md)}
.login-form{display:flex;flex-direction:column;gap:20px}
.login-error{background:var(--newsletter-error-bg);color:var(--color-text-light);padding:15px;border-radius:4px;margin-bottom:20px}
.login-success{background:var(--color-success);color:var(--color-text-light);padding:15px;border-radius:4px;margin-bottom:20px}
.login-info{text-align:center;padding:20px;border:1px solid var(--color-bg-secondary);border-radius:4px;margin-bottom:20px}
.login-info p{margin-bottom:15px}
.form-group{display:flex;flex-direction:column;gap:8px}
.form-group label{font-weight:500;color:var(--color-text-primary)}
.form-control{padding:10px 15px;border:1px solid #ddd;border-radius:4px;font-size:16px;background-color:var(--color-bg-body);color:var(--color-text-base);transition:border-color var(--transition-base)}
.form-control:focus{outline:none;border-color:var(--color-bg-secondary)}
.btn-solid{background:var(--color-bg-secondary);color:var(--color-text-light);padding:12px 20px;border:none;border-radius:4px;font-size:16px;cursor:pointer;text-decoration:none;display:inline-block;transition:background-color var(--transition-base)}
.btn-solid:hover{background:color-mix(in srgb,var(--color-bg-secondary) 90%,black)}

/* ==========================================================================
   FTP Files Section
   ========================================================================== */
.ftp-wrapper{display:grid;grid-template-columns:280px 1fr;gap:40px;margin-top:40px;align-items:start}
.ftp-groups{background:var(--color-bg-dark);padding:24px;border-radius:8px}
.ftp-groups .group-tree{display:flex;flex-direction:column;gap:4px;position:relative}
.ftp-groups .group-tree:before{content:'';position:absolute;top:0;bottom:17px;left:14px;width:2px;background:color-mix(in srgb,var(--color-bg-secondary) 70%,black)}
.ftp-groups .group-item{position:relative}
.ftp-groups .group-item>.group-link{color:var(--color-text-light);display:flex;align-items:center;gap:10px;padding:7px 12px;text-decoration:none;border-radius:4px;transition:background-color var(--transition-base)}
.ftp-groups .group-item>.group-link i{transition:transform var(--transition-base);color:var(--color-bg-secondary);background:var(--color-bg-dark);position:relative;z-index:1;outline:2px solid var(--color-bg-secondary);border-radius:50%;font-size:0.95em}
.ftp-groups .group-item>.group-link i.toggle-icon{cursor:pointer}
.ftp-groups .group-item>.group-link i.expanded,
.ftp-groups .group-item.active>.group-link i{transform:rotate(90deg)}
.ftp-groups .group-link:hover{background:rgba(255,255,255,0.1)}
.ftp-groups .group-link.active{background:var(--color-bg-secondary);color:var(--color-text-primary)}
.ftp-groups .group-item.active>.group-link{background:var(--color-bg-secondary);color:var(--color-text-primary)}
.ftp-groups .group-children .group-link.active{background:var(--color-bg-secondary);color:var(--color-text-primary)}
.ftp-groups .group-item.active .group-children .group-link{background:transparent;padding:3px 12px}
.ftp-groups .group-item.active .group-children .group-link:hover{background:rgba(255,255,255,0.1)}
.ftp-groups .group-children{display:flex;flex-direction:column;gap:0;margin:0 0 0 10px;padding-left:12px;font-size:0.85em;margin-top:-2px;margin-bottom:2px;overflow:hidden;transition:max-height var(--transition-base), opacity var(--transition-base)}
.ftp-groups .group-children.collapsed{max-height:0;opacity:0;margin-top:0;margin-bottom:0;pointer-events:none}
.ftp-groups .group-children.nested{font-size:0.9em;margin-left:14px}
.ftp-groups .group-children .group-link{color:var(--color-text-light);padding:3px 12px}
.ftp-groups .group-item i.fa-minus{font-size:0.8em}
.ftp-groups .group-link .folder-count{font-size:0.85em;opacity:0.7;margin-left:3px}
.ftp-content{display:flex;flex-direction:column;gap:24px}
.ftp-header-line{position:relative;width:100%;margin-bottom:30px}
.ftp-header-line:after{content:'';display:block;width:100%;height:1px;background:var(--color-bg-secondary);margin-top:10px;position:absolute;bottom:-10px;left:0}
.folder-title{color:var(--color-text-primary);font-size:1.5em;margin-bottom:15px}
.ftp-download-btn{background:var(--color-bg-secondary);color:var(--color-text-light);padding:10px 24px;border:none;border-radius:4px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;transition:background-color var(--transition-base)}
.ftp-download-btn:hover{background:color-mix(in srgb,var(--color-bg-secondary) 90%,black)}
.folder-description{margin-bottom:32px;color:var(--color-text-base);line-height:1.6}
.ftp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:24px}
.ftp-card-wrapper{position:relative}
.ftp-card-wrapper .ftp-card{position:relative}
.ftp-card{display:block;background:transparent;border-radius:8px;overflow:hidden;text-decoration:none;transition:transform var(--transition-base),box-shadow var(--transition-base);position:relative}
.ftp-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.ftp-card-bg{height:200px;background-size:198px;background-position:center -20px;background-repeat:no-repeat;position:relative}
.ftp-card.default-folder-icon .ftp-card-bg{background-size:198px;background-position:center -20px}
.ftp-card-content{padding:16px 20px;background:rgba(0,0,0,0.48);position:absolute;bottom:0;left:0;right:0;min-height:60px;display:flex;align-items:center;justify-content:center}
.ftp-title{color:var(--color-text-light);font-size:1rem;margin:0;word-break:break-word;line-height:1.3;text-align:center}
.ftp-empty-folder{text-align:center;padding:80px 20px;color:var(--color-text-light)}
.ftp-empty-folder .empty-folder-icon{width:192px;height:192px;margin:0 auto 20px auto;display:block;opacity:0.8}
.ftp-empty-folder p{font-size:1.2rem;font-weight:500}

@media (max-width: 768px) {
    .ftp-wrapper{grid-template-columns:1fr;gap:24px}
    .ftp-groups{display:none}
}

/* Spacers for proper FTP layout */
.ftp-content-spacer,
.ftp-page-spacer {
    width: 100%;
    clear: both;
}

/* ==========================================================================
   Home Page Sections
   ========================================================================== */
.home-section {
    margin: 60px 0;
    position: relative;
}

.home-section:first-of-type {
    margin-top: 40px;
}

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

.home-grid.full-width {
    grid-template-columns: 1fr;
}

.home-grid.reversed {
    direction: rtl;
}

.home-grid.reversed > * {
    direction: ltr;
}

.home-content h2 {
    color: var(--color-text-primary);
    font-size: 1.5em;
    margin-bottom: 25px;
    position: relative;
}

.home-content h2::after {
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    background: var(--color-bg-secondary);
    margin-top: 10px;
}

.home-text {
    color: var(--color-text-base);
    line-height: 1.6;
}

.home-text p {
    margin-bottom: 1.5em;
}

.home-text p:last-child {
    margin-bottom: 0;
}

.home-image img {
    width: 100%;
    height: auto;
    display: block;
}

.home-buttons {
    display: flex;
    gap: 20px;
    margin-top: 30px;
}

/* Button Styles */
.btn-outline {
    display: inline-block;
    padding: 12px 30px;
    background-color: rgba(15,31,47,0.2);
    color: var(--color-text-secondary);
    text-decoration: none;
    font-weight: bold;
    border: 2px solid var(--color-bg-secondary);
    transition: all 0.3s ease;
}

.btn-outline:hover {
    background-color: var(--color-bg-secondary);
    color: var(--color-text-light);
}

@media(min-width:768px) {
    .home-grid:not(.full-width) {
        grid-template-columns: 1fr 400px;
    }

    .service-highlight .home-grid,
    .offer-highlight .home-grid {
        grid-template-columns: 1fr 500px;
    }
}

/* ==========================================================================
   Item Scroller
   ========================================================================== */
.item-scroller{margin:60px 0;position:relative}
.item-scroller:first-of-type{margin-top:40px}
.item-scroller-section-title{color:var(--color-text-primary);font-size:1.5em;margin-bottom:25px;position:relative}
.item-scroller-section-title::after{content:'';display:block;width:100%;height:1px;background:var(--color-bg-secondary);margin-top:10px}
.item-scroller-container{position:relative;overflow:hidden;margin-bottom:20px}
.item-scroller-wrapper{display:flex;gap:30px;transition:transform var(--transition-base);width:fit-content}
.item-scroller .item-scroller-card{flex-shrink:0;display:block;text-decoration:none;box-shadow:var(--shadow-md);position:relative;overflow:hidden}
.item-scroller.large .item-scroller-card{width:calc((100% - 60px) / 3);aspect-ratio:1/1;max-width:360px;max-height:360px}
.item-scroller.medium .item-scroller-card{width:calc((100% - 90px) / 4);aspect-ratio:1/1;max-width:280px;max-height:280px}
.item-scroller-card-bg{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;background-repeat:no-repeat;background-color:#ffffff;z-index:1;transition:transform var(--transition-base),filter var(--transition-base)}
.item-scroller-card:hover .item-scroller-card-bg{transform:scale(1.05);filter:brightness(1.15)}
.item-scroller-card-content{position:relative;z-index:2;background:linear-gradient(to top,rgba(0,0,0,0.8),transparent);height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:30px 20px}
.item-scroller.medium .item-scroller-card-content{padding:24px 16px}
.item-scroller-card-title{color:var(--color-text-light);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.2;transition:color var(--transition-base);margin:0}
.item-scroller.large .item-scroller-card-title{font-size:1.5em;height:2.4em}
.item-scroller.medium .item-scroller-card-title{font-size:1.2em;height:2.4em}
.item-scroller-card:hover .item-scroller-card-title{color:var(--color-text-accent)}
.item-scroller-description{color:var(--color-text-light);margin-top:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.item-scroller.large .item-scroller-description{font-size:0.9em}
.item-scroller.medium .item-scroller-description{font-size:0.8em}
.item-scroller-button{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;color:rgba(20,33,61,0.3);padding:16px;cursor:pointer;transition:color var(--transition-base);z-index:2;font-size:2em}
.item-scroller-button:hover{color:var(--color-text-accent)}
.item-scroller-button.prev{left:-50px}
.item-scroller-button.next{right:-50px}
@media(max-width:1200px){
    .item-scroller-button.prev{left:-30px}
    .item-scroller-button.next{right:-30px}
    .item-scroller.large .item-scroller-card{width:calc((100% - 30px) / 2);max-width:320px;max-height:320px}
    .item-scroller.medium .item-scroller-card{width:calc((100% - 60px) / 3);max-width:260px;max-height:260px}
}
@media(max-width:768px){.item-scroller{display:none}}
[data-theme='dark'] .item-scroller-button{color:rgba(255,255,255,0.3)}

/* ==========================================================================
   Group Brands Filter
   ========================================================================== */
.group-brands{display:flex;gap:15px;margin-bottom:20px;flex-wrap:nowrap;overflow-x:auto;padding:10px 0;}
.brand-item{background:var(--color-bg-light);padding:8px 16px;border-radius:4px;cursor:pointer;transition:all var(--transition-base);white-space:nowrap;text-decoration:none;color:var(--color-text-base)}
.brand-item:hover{background:var(--color-hover-light)}
.brand-item.active{background:var(--color-bg-primary);color:var(--color-text-light)}
.brand-item.active .fa-circle-check{color:var(--color-success)}

/* ==========================================================================
   Product Configurator
   ========================================================================== */
.configurator-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(to bottom,rgba(15,31,47,.95),rgba(10,21,32,.98));z-index:2000;display:none;padding:20px}
.configurator-modal.active{display:flex;align-items:center;justify-content:center}
.configurator-container{background:var(--color-bg-body);position:relative;box-shadow:var(--shadow-md);flex:none;width:min(95vw,var(--width,1200px))!important;height:min(95vh,var(--height,800px))!important;display:flex;flex-direction:column}
.configurator-close{position:absolute;top:10px;right:20px;background:none;border:none;color:var(--color-text-base);font-size:24px;cursor:pointer;padding:10px;transition:color var(--transition-base);z-index:10}
.configurator-close:hover{color:var(--color-text-accent)}
.configurator-content{flex:1;display:flex;flex-direction:column;height:100%;overflow:hidden}
.configurator-preview{background:#fff;position:relative;height:40%;flex:none}
.configurator-preview-title{font-size:clamp(1rem,2vw,1.5em);color:var(--color-text-primary);padding:15px 20px;text-align:center;background:var(--color-bg-body);margin:0;height:60px;display:flex;align-items:center;justify-content:center;position:absolute;top:0;left:0;right:0;z-index:2}
.configurator-preview-container{position:relative;height:calc(100% - 60px);display:flex;align-items:center;justify-content:center;margin-top:60px}
.configurator-preview-container img{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);max-width:90%;max-height:90%;object-fit:contain}
.configurator-controls{flex:1;display:flex;flex-direction:column;background:var(--color-bg-light)}
.configurator-controls-content{flex:1;overflow-y:auto;padding:20px;min-height:250px}
.configurator-title{color:var(--color-text-primary);font-size:clamp(1rem,2vw,1.5em);margin-bottom:25px;position:relative}
.configurator-title::after{content:'';display:block;width:100%;height:1px;background:var(--color-bg-secondary);margin-top:10px}
.configurator-layer-section{margin-bottom:30px;padding-right:5px}
.configurator-layer-section h4{color:var(--color-text-primary);margin-bottom:15px}
.configurator-colors{display:flex;justify-content:space-between;gap:6px;flex-wrap:nowrap;margin-right:-5px}
.configurator-color{flex:0 0 35px;width:35px;height:35px;border:2px solid var(--color-bg-light);border-radius:50%;cursor:pointer;padding:0;transition:transform var(--transition-base)}
.configurator-color:hover{transform:scale(1.1)}
.configurator-color.active{border-color:var(--color-bg-secondary)}
.configurator-note{padding:15px 20px;background:var(--color-bg-light);color:var(--color-text-base);font-size:0.85em;line-height:1.5}
.configurator-open{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;font-size:1.2em}
.configurator-open i{font-size:1.2em}
.configurator-copy{padding:15px 20px;background:var(--color-bg-light);position:sticky;bottom:0;display:flex;justify-content:stretch}
.configurator-copy button{flex:1}
.configurator-copy button:disabled{opacity:.5;cursor:not-allowed;background:var(--color-bg-secondary)}
.configurator-copy button:disabled:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}
.configurator-copy button i{margin-right:8px}

@media (min-width:768px){
    .configurator-content{flex-direction:row}
    .configurator-preview{height:100%;flex:0 0 70%}
    .configurator-controls{width:30%}
    .configurator-controls-content{padding:60px 40px 20px}
    .configurator-note{padding:20px 40px}
    .configurator-copy{padding:20px 40px}
    .configurator-color{flex:0 0 32px;width:32px;height:32px}
    .configurator-layer-section{padding-right:0}
}

/* Unified FTP Back Button Styles */
.ftp-back-btn{background:var(--color-bg-secondary);color:var(--color-text-light);width:32px;height:32px;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-base);text-decoration:none}
.ftp-back-btn:hover{background:color-mix(in srgb,var(--color-bg-secondary) 90%,black);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.ftp-back-btn i{font-size:16px}
.ftp-header-content{display:flex;justify-content:space-between;align-items:center}
.ftp-header-left{display:flex;align-items:center;gap:15px;flex:1}
.ftp-item-header .folder-title{margin:0;padding-right:0}

/* ==========================================================================
   Files Section
   ========================================================================== */
.files-section{margin-bottom:40px}
.files-section h2{composes:section-header}
.files-grid{margin-top:20px}
.file-item{margin-bottom:10px}
.file-link{display:flex;align-items:center;gap:10px;color:var(--color-text-base);text-decoration:none;padding:10px;border-radius:4px;transition:all var(--transition-base)}
.file-link:hover{background:var(--color-hover-light);color:var(--color-text-accent)}
.file-link i{color:var(--color-text-primary);font-size:1.2em}
.file-link:hover i{color:var(--color-text-accent)}

/* ==========================================================================
   B2B File Download UX Improvements
   ========================================================================== */
.ftp-download-overlay{position:absolute;top:8px;right:8px;width:44px;height:44px;background:rgba(0,0,0,0.7);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-base);z-index:10}
.ftp-download-overlay:hover{background:var(--color-secondary);transform:scale(1.1)}
.ftp-download-overlay i{color:white;font-size:20px}
.ftp-download-overlay:active{transform:scale(0.95)}
