/*
Theme Name: Atlas Worldwide
Theme URI: https://www.atlasroller.in
Author: Atlas Roller Solutions
Author URI: https://www.atlasroller.in
Description: Professional B2B industrial theme for Atlas Worldwide – Industrial Rollers, Polyurethane Components & Custom Manufacturing. Includes product catalogue, RFQ form, blog, gallery, and contact pages.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: atlas-worldwide
Tags: business, industrial, manufacturing, b2b, portfolio
*/

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--blue-600:#2563eb;--blue-700:#1d4ed8;--slate-50:#f8fafc;--slate-100:#f1f5f9;--slate-200:#e2e8f0;--slate-300:#cbd5e1;--slate-400:#94a3b8;--slate-500:#64748b;--slate-600:#475569;--slate-700:#334155;--slate-800:#1e293b;--slate-900:#0f172a;--slate-950:#020617;--amber-500:#f59e0b;--emerald-500:#10b981;--emerald-600:#059669;--font-sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;--font-mono:'Courier New',Courier,monospace}
html{scroll-behavior:smooth}
body{font-family:var(--font-sans);color:var(--slate-700);background:#fff;line-height:1.6;font-size:16px}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue-600);text-decoration:none;transition:color .2s}
a:hover{color:var(--blue-700)}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{font-weight:800;color:var(--slate-900);line-height:1.15;letter-spacing:-.02em}
h1{font-size:clamp(2.2rem,5vw,3.75rem);font-weight:900}
h2{font-size:clamp(1.6rem,3vw,2.5rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.875rem)}
h4{font-size:1.125rem}
p{margin-bottom:1rem}
.eyebrow{font-size:.625rem;font-weight:900;letter-spacing:.25em;text-transform:uppercase;color:var(--blue-600);display:block;margin-bottom:.75rem}
.container{max-width:1280px;margin:0 auto;padding:0 1.25rem}
@media(min-width:768px){.container{padding:0 1.5rem}}
@media(min-width:1024px){.container{padding:0 2.5rem}}
.section{padding:4rem 0}
.section--dark{background:var(--slate-900);color:var(--slate-300)}
.section--light{background:var(--slate-50)}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 2rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;border:none;cursor:pointer;transition:all .2s;text-decoration:none;line-height:1}
.btn-primary{background:var(--slate-900);color:#fff}
.btn-primary:hover{background:var(--slate-800);color:#fff}
.btn-outline{background:#fff;color:var(--slate-900);border:1px solid var(--slate-300)}
.btn-outline:hover{background:var(--slate-50);color:var(--slate-900)}
.btn-blue{background:var(--blue-600);color:#fff;border-radius:2px}
.btn-blue:hover{background:var(--blue-700);color:#fff}
.btn-sm{padding:.5rem 1rem;font-size:.65rem}

/* === HEADER === */
#masthead{background:#fff;border-bottom:1px solid var(--slate-200);position:sticky;top:0;z-index:100;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.site-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}
.logo-icon{width:36px;height:36px;background:var(--slate-900);display:flex;align-items:center;justify-content:center;border-radius:2px}
.logo-icon svg{width:20px;height:20px;fill:#fff}
.logo-main{font-size:1rem;font-weight:900;color:var(--slate-900);letter-spacing:-.04em;text-transform:uppercase;line-height:1;display:block}
.logo-sub{font-size:.6rem;color:var(--blue-600);font-weight:700;letter-spacing:.05em;text-transform:uppercase;line-height:1;margin-top:2px;display:block}
#site-navigation ul{display:flex;align-items:center;gap:1.75rem}
#site-navigation a{font-size:.8rem;font-weight:600;color:var(--slate-600);text-decoration:none;padding:.35rem 0;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap}
#site-navigation a:hover,.current-menu-item>a{color:var(--blue-600);border-bottom-color:var(--blue-600)}
.header-cta{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem;flex-direction:column;gap:5px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--slate-700);transition:all .2s}
@media(max-width:1023px){
  .nav-toggle{display:flex}
  #site-navigation{display:none;position:absolute;top:68px;left:0;right:0;background:#fff;border-top:1px solid var(--slate-200);box-shadow:0 8px 16px rgba(0,0,0,.1);z-index:200}
  #site-navigation.open{display:block}
  #site-navigation ul{flex-direction:column;gap:0;padding:.75rem 0}
  #site-navigation a{display:block;padding:.875rem 1.5rem;border-bottom:1px solid var(--slate-100);border-left:none}
  .header-cta .btn-outline{display:none}
}

/* === HERO === */
.hero{background:#fff;border-bottom:1px solid var(--slate-200);padding:5rem 0 4rem}
.hero-grid{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center}
@media(min-width:1024px){.hero-grid{grid-template-columns:7fr 5fr}}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:var(--slate-100);border:1px solid var(--slate-200);padding:.375rem .875rem;font-size:.65rem;color:#1e40af;font-family:var(--font-mono);font-weight:900;text-transform:uppercase;letter-spacing:.06em;border-radius:9999px;margin-bottom:1.5rem}
.hero-badge .pulse{width:10px;height:10px;background:var(--blue-600);border-radius:50%;animation:pulse 1.5s ease-in-out infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}
.hero h1{margin-bottom:1.25rem}
.hero h1 .accent{color:var(--blue-600)}
.hero-lead{font-size:1.0625rem;color:var(--slate-500);max-width:36rem;line-height:1.75;margin-bottom:2rem}
.hero-btns{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2.5rem}
.trust-strip{padding-top:2rem;border-top:1px solid var(--slate-100)}
.trust-label{font-size:.6rem;font-weight:900;letter-spacing:.25em;text-transform:uppercase;color:var(--slate-400);margin-bottom:1rem}
.trust-logos{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media(min-width:640px){.trust-logos{grid-template-columns:repeat(5,1fr)}}
.trust-item{border-left:2px solid var(--slate-200);padding-left:.75rem}
.trust-item .ti-name{font-size:.7rem;font-weight:900;color:var(--slate-900);text-transform:uppercase;letter-spacing:-.02em;line-height:1}
.trust-item .ti-type{font-size:.55rem;color:var(--slate-400);font-family:var(--font-mono);line-height:1;margin-top:3px}
.hero-panel{background:var(--slate-950);color:#fff;padding:2.5rem;border-left:6px solid var(--slate-900);position:relative;overflow:hidden}
.hero-panel::before{content:'AW';position:absolute;top:0;right:-10px;font-size:140px;font-weight:900;font-family:var(--font-mono);letter-spacing:-.08em;color:#fff;opacity:.07;line-height:1;pointer-events:none;user-select:none}
.hp-top{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #1e293b;padding-bottom:1rem;margin-bottom:1.25rem;position:relative;z-index:1}
.hp-tag{background:#1e293b;color:#94a3b8;font-size:.6rem;font-weight:900;text-transform:uppercase;letter-spacing:.12em;padding:.25rem .625rem}
.hp-right{color:var(--slate-400);font-size:.7rem;font-family:var(--font-mono)}
.hero-panel h2{font-size:1.75rem;font-weight:900;letter-spacing:-.03em;margin-bottom:1rem;color:#fff;position:relative;z-index:1}
.hero-panel>p{color:var(--slate-400);font-size:.875rem;line-height:1.7;margin-bottom:1.25rem;position:relative;z-index:1}
.hp-checks{border-top:1px solid #0f172a;padding-top:1rem;display:flex;flex-direction:column;gap:.875rem;position:relative;z-index:1}
.hp-check{display:flex;gap:.75rem;font-size:.75rem;color:var(--slate-300)}
.hp-check svg{width:16px;height:16px;flex-shrink:0;margin-top:2px;stroke:#10b981;fill:none}
.hp-subcard{background:#0f172a;border:1px solid #1e293b;border-radius:4px;padding:1rem;margin-top:1.25rem;position:relative;z-index:1}
.hp-sc-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}
.hp-sc-tag{font-size:.55rem;color:#f59e0b;font-family:var(--font-mono);font-weight:900;text-transform:uppercase;letter-spacing:.1em}
.hp-sc-dot{width:8px;height:8px;background:#10b981;border-radius:50%;animation:pulse 2s infinite}
.hp-subcard h4{font-size:.875rem;font-weight:700;text-transform:uppercase;color:#fff;margin-bottom:.375rem}
.hp-subcard p{font-size:.7rem;color:var(--slate-400);line-height:1.6;margin-bottom:.875rem}
.hp-subcard a{display:block;background:var(--blue-600);color:#fff;text-align:center;font-size:.7rem;font-weight:900;text-transform:uppercase;letter-spacing:.1em;padding:.625rem;border-radius:2px;transition:background .2s}
.hp-subcard a:hover{background:var(--blue-700)}

/* === CREDENTIALS === */
.credentials{background:#fff;border-bottom:1px solid var(--slate-200);padding:3.5rem 0}
.cred-layout{display:grid;grid-template-columns:1fr;gap:2.5rem}
@media(min-width:1024px){.cred-layout{grid-template-columns:4fr 8fr;align-items:center}}
.cred-cards{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:640px){.cred-cards{grid-template-columns:repeat(3,1fr)}}
.cred-card{background:var(--slate-50);border:1px solid var(--slate-200);border-radius:4px;padding:1.5rem;display:flex;flex-direction:column;justify-content:space-between;transition:all .3s}
.cred-card:hover{border-color:var(--blue-600);box-shadow:0 2px 8px rgba(37,99,235,.1)}
.cc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.875rem}
.cc-badge{font-size:.55rem;font-family:var(--font-mono);font-weight:900;padding:.25rem .5rem;border-radius:3px}
.cc-badge.india{background:#fef3c7;color:#92400e}
.cc-badge.msme{background:#eff6ff;color:#1e40af}
.cc-badge.iso{background:#f1f5f9;color:#334155}
.cc-status{font-size:.625rem;font-weight:700;font-family:var(--font-mono);text-transform:uppercase}
.cred-card h4{font-size:.9375rem;margin-bottom:.5rem}
.cred-card p{font-size:.75rem;color:var(--slate-500);line-height:1.6;margin:0}
.cc-foot{margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--slate-200);font-size:.55rem;color:var(--slate-400);font-family:var(--font-mono);letter-spacing:.05em}

/* === DIVISIONS === */
.divisions{background:var(--slate-50);border-bottom:1px solid var(--slate-200);padding:4rem 0}
.section-head{max-width:36rem;margin-bottom:3rem}
.div-grid{display:grid;grid-template-columns:1fr;gap:2rem}
@media(min-width:768px){.div-grid{grid-template-columns:repeat(3,1fr)}}
.div-card{background:#fff;border:1px solid var(--slate-200);padding:2rem;display:flex;flex-direction:column;justify-content:space-between;transition:all .2s}
.div-card:hover{border-color:var(--blue-600)}
.div-icon{width:48px;height:48px;background:var(--slate-100);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;border-left:4px solid var(--slate-900)}
.div-icon.blue{border-left-color:var(--blue-600)}
.div-icon.amber{border-left-color:var(--amber-500)}
.div-icon svg{width:24px;height:24px;stroke:var(--slate-900);fill:none;stroke-width:2}
.div-icon.blue svg{stroke:var(--blue-600)}
.div-icon.amber svg{stroke:var(--amber-500)}
.div-card h4{font-size:1.25rem;margin-bottom:.75rem}
.div-card p{font-size:.875rem;color:var(--slate-500);line-height:1.7;flex:1;margin:0}
.div-link{display:inline-flex;align-items:center;gap:.25rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--blue-600);margin-top:1.5rem;text-decoration:none}
.div-link:hover{color:var(--slate-900)}

/* === CTA BANNER === */
.cta-banner{background:var(--slate-900);color:#fff;padding:4rem 0}
.cta-grid{display:grid;grid-template-columns:1fr;gap:2.5rem}
@media(min-width:1024px){.cta-grid{grid-template-columns:8fr 4fr;align-items:center}}
.cta-banner .eyebrow{color:var(--blue-600)}
.cta-banner h2{color:#fff;margin-bottom:1rem}
.cta-banner>div>p{color:var(--slate-300);font-size:.9rem;line-height:1.7;max-width:36rem}
.cta-checklist{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:1.5rem}
.cta-check{display:flex;align-items:flex-start;gap:.5rem;font-size:.75rem;color:var(--slate-400)}
.cta-check svg{width:16px;height:16px;stroke:#10b981;fill:none;flex-shrink:0;margin-top:2px}
.cta-box{background:var(--slate-800);border:1px solid var(--slate-700);border-radius:6px;padding:1.5rem}
.cta-box h4{font-size:1.125rem;color:#fff;margin-bottom:.5rem}
.cta-box p{font-size:.75rem;color:var(--slate-300);margin-bottom:1.25rem}
.cta-box .btn-blue{width:100%;justify-content:center}

/* === PRODUCTS === */
.products-section{padding:4rem 0}
.filter-bar{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2.5rem}
.filter-btn{padding:.375rem .875rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;border:1px solid var(--slate-200);background:#fff;color:var(--slate-600);cursor:pointer;border-radius:3px;transition:all .2s}
.filter-btn.active,.filter-btn:hover{background:var(--slate-900);color:#fff;border-color:var(--slate-900)}
.product-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:640px){.product-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.product-grid{grid-template-columns:repeat(3,1fr)}}
.product-card{border:1px solid var(--slate-200);background:#fff;display:flex;flex-direction:column;transition:all .25s;overflow:hidden}
.product-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.1);border-color:var(--blue-600);transform:translateY(-2px)}
.pc-img{height:200px;overflow:hidden;background:var(--slate-100);position:relative}
.pc-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.product-card:hover .pc-img img{transform:scale(1.04)}
.pc-cat{position:absolute;top:.75rem;left:.75rem;background:var(--slate-950);color:#fff;font-size:.55rem;font-weight:900;text-transform:uppercase;letter-spacing:.1em;padding:.25rem .5rem}
.pc-body{padding:1.25rem;flex:1;display:flex;flex-direction:column}
.pc-body h4{font-size:1rem;margin-bottom:.5rem}
.pc-body p{font-size:.8rem;color:var(--slate-500);line-height:1.6;flex:1;margin:0}
.pc-specs{border-top:1px solid var(--slate-100);margin-top:1rem;padding-top:1rem;display:flex;flex-direction:column;gap:.375rem}
.spec-row{display:flex;justify-content:space-between;font-size:.65rem;font-family:var(--font-mono)}
.spec-k{color:var(--slate-400)}
.spec-v{color:var(--slate-700);font-weight:700;text-align:right;max-width:55%}
.pc-footer{padding:.875rem 1.25rem;border-top:1px solid var(--slate-100)}
.pc-footer a{font-size:.7rem;font-weight:700;color:var(--blue-600);text-transform:uppercase;letter-spacing:.08em}

/* === BLOG === */
.blog-section{background:#fff;border-bottom:1px solid var(--slate-200);padding:4rem 0}
.blog-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:2.5rem}
.blog-grid{display:grid;grid-template-columns:1fr;gap:2rem}
@media(min-width:768px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.blog-grid{grid-template-columns:repeat(3,1fr)}}
.blog-card{border:1px solid var(--slate-200);background:var(--slate-50);display:flex;flex-direction:column;transition:box-shadow .25s}
.blog-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.08)}
.bc-img{height:180px;overflow:hidden;background:var(--slate-200);position:relative}
.bc-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(80%);transition:filter .4s}
.blog-card:hover .bc-img img{filter:grayscale(0)}
.bc-tag{position:absolute;top:.75rem;left:.75rem;background:var(--slate-950);color:#fff;font-size:.55rem;font-weight:900;text-transform:uppercase;letter-spacing:.1em;padding:.25rem .5rem}
.bc-body{padding:1.25rem;flex:1;display:flex;flex-direction:column}
.bc-meta{font-size:.65rem;color:var(--slate-400);font-family:var(--font-mono);margin-bottom:.75rem}
.bc-body h4{font-size:1rem;margin-bottom:.625rem;line-height:1.4}
.bc-body h4 a{color:var(--slate-900)}
.bc-body h4 a:hover{color:var(--blue-600)}
.bc-body p{font-size:.8rem;color:var(--slate-500);line-height:1.6;flex:1;margin:0}
.bc-link{display:inline-flex;align-items:center;gap:.25rem;font-size:.7rem;font-weight:700;color:var(--slate-900);margin-top:1rem;text-decoration:none}
.bc-link:hover{color:var(--blue-600)}
.bc-link svg{width:14px;height:14px;stroke:currentColor;fill:none}

/* === ABOUT === */
.about-hero{background:var(--slate-950);color:#fff;padding:4rem 0}
.about-hero h1{color:#fff;margin-bottom:1rem}
.about-hero p{color:var(--slate-400);max-width:42rem;font-size:1rem;line-height:1.7;margin:0}
.about-body{padding:4rem 0}
.about-mv{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:4rem}
@media(min-width:768px){.about-mv{grid-template-columns:1fr 1fr}}
.mv-card{background:var(--slate-50);border:1px solid var(--slate-200);padding:2rem;border-radius:4px}
.mv-card h3{font-size:1.125rem;margin-bottom:.75rem;color:var(--blue-600)}
.mv-card p{font-size:.875rem;color:var(--slate-600);line-height:1.7;margin:0}
.cap-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-bottom:4rem}
@media(min-width:768px){.cap-grid{grid-template-columns:1fr 1fr}}
.cap-card{border:1px solid var(--slate-200);padding:1.5rem;border-radius:4px;background:#fff}
.cap-card h4{font-size:1rem;margin-bottom:1rem}
.cap-card ul{display:flex;flex-direction:column;gap:.5rem}
.cap-card li{font-size:.8rem;color:var(--slate-600);padding-left:1.25rem;position:relative;line-height:1.5}
.cap-card li::before{content:'→';position:absolute;left:0;color:var(--blue-600);font-size:.7rem}
.qa-section{background:var(--slate-50);border:1px solid var(--slate-200);padding:2rem;border-radius:4px;margin-bottom:3rem}
.qa-section h3{margin-bottom:1.5rem}
.qa-section ul{display:flex;flex-direction:column;gap:.875rem}
.qa-section li{display:flex;gap:.875rem;font-size:.875rem;color:var(--slate-600)}
.qa-section li svg{width:20px;height:20px;stroke:#10b981;fill:none;flex-shrink:0;margin-top:1px}
.str-grid{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:768px){.str-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.str-grid{grid-template-columns:repeat(3,1fr)}}
.str-item{background:#fff;border:1px solid var(--slate-200);padding:1.25rem 1.5rem;display:flex;gap:.875rem;align-items:flex-start;border-radius:3px;font-size:.875rem;color:var(--slate-700)}
.str-item svg{width:20px;height:20px;stroke:var(--blue-600);fill:none;flex-shrink:0;margin-top:1px}

/* === CONTACT === */
.contact-section{padding:4rem 0}
.contact-grid{display:grid;grid-template-columns:1fr;gap:3rem}
@media(min-width:1024px){.contact-grid{grid-template-columns:5fr 7fr}}
.contact-info h1{font-size:clamp(1.75rem,3vw,2.5rem);margin-bottom:1rem}
.contact-info>p{font-size:.9375rem;color:var(--slate-500);line-height:1.7;margin-bottom:2.5rem}
.c-detail{display:flex;gap:1rem;margin-bottom:2rem}
.cd-icon{width:40px;height:40px;background:var(--slate-100);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cd-icon svg{width:20px;height:20px;stroke:var(--slate-900);fill:none}
.c-detail h4{font-size:.9375rem;margin-bottom:.375rem}
.c-detail p,.c-detail address{font-size:.8rem;font-family:var(--font-mono);color:var(--slate-500);line-height:1.6;font-style:normal;margin:0}
.c-detail a{color:var(--blue-600)}
.audit-box{background:var(--slate-50);border:1px solid var(--slate-200);padding:1.25rem;margin-top:2rem}
.audit-box h4{font-size:.9375rem;margin-bottom:.5rem}
.audit-box p{font-size:.8rem;color:var(--slate-500);line-height:1.6;margin:0}
.cf-wrap{background:var(--slate-50);border:1px solid var(--slate-200);padding:2rem}
.cf-wrap h3{font-size:1.125rem;margin-bottom:.375rem}
.cf-wrap>.cf-sub{font-size:.75rem;color:var(--slate-500);margin-bottom:1.5rem}
.form-row{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1rem}
@media(min-width:640px){.form-row{grid-template-columns:1fr 1fr}}
.form-group{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}
.form-group label{font-size:.6rem;font-weight:900;text-transform:uppercase;letter-spacing:.15em;color:var(--slate-500)}
.form-group input,.form-group select,.form-group textarea{width:100%;background:#fff;border:1px solid var(--slate-300);padding:.625rem .75rem;font-size:.8rem;font-family:var(--font-mono);color:var(--slate-700);outline:none;transition:border-color .2s;border-radius:2px}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue-600)}
.form-group textarea{resize:vertical;min-height:120px}
.form-success{background:#ecfdf5;border:1px solid #6ee7b7;padding:2rem;text-align:center;display:none}
.form-success.show{display:block}
.form-success h4{color:#065f46;text-transform:uppercase;margin-bottom:.5rem}
.form-success p{font-size:.8rem;color:#047857;line-height:1.6;margin:0}

/* === GALLERY === */
.gallery-section{padding:4rem 0}
.gallery-grid{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:640px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}
.gallery-card{position:relative;overflow:hidden;background:var(--slate-100);aspect-ratio:4/3}
.gallery-card img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery-card:hover img{transform:scale(1.06)}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(2,6,23,.85) 0%,transparent 60%);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:1.25rem}
.gallery-card:hover .gallery-overlay{opacity:1}
.gallery-info h4{color:#fff;font-size:.9375rem;margin-bottom:.25rem}
.gallery-info p{color:var(--slate-400);font-size:.75rem;line-height:1.5;margin:0}

/* === PAGE HERO === */
.page-hero{background:var(--slate-950);color:#fff;padding:3rem 0}
.page-hero .eyebrow{color:var(--blue-600)}
.page-hero h1{color:#fff;font-size:clamp(1.75rem,4vw,3rem);margin-bottom:.875rem}
.page-hero p{color:var(--slate-400);max-width:40rem;font-size:.9375rem;line-height:1.7;margin:0}

/* === FOOTER === */
#colophon{background:var(--slate-900);color:var(--slate-400);padding:3rem 0 0;border-top:1px solid var(--slate-800);font-size:.75rem}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid var(--slate-800)}
@media(min-width:768px){.footer-grid{grid-template-columns:4fr 3fr 3fr}}
@media(min-width:1024px){.footer-grid{grid-template-columns:4fr 3fr 3fr 2fr}}
.fb-name{font-size:1rem;font-weight:900;color:#fff;text-transform:uppercase;letter-spacing:-.03em;display:block;margin-bottom:.875rem}
.fb-name span{color:var(--blue-600)}
.footer-brand p{font-size:.75rem;line-height:1.7;color:var(--slate-500);margin-bottom:1rem}
.footer-copy{font-family:var(--font-mono);font-size:.6rem;color:var(--slate-600)}
.footer-col h4{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--slate-400);margin-bottom:1rem}
.footer-col ul{display:flex;flex-direction:column;gap:.5rem}
.footer-col a{color:var(--slate-500);font-size:.7rem;font-family:var(--font-mono);text-decoration:none;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-col span{color:var(--slate-500);font-size:.7rem;font-family:var(--font-mono)}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;padding:1.25rem 0;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--slate-500);gap:1rem}
.footer-bottom a{color:var(--slate-500)}
.footer-bottom a:hover{color:#fff}

/* === UTILITIES === */
.text-blue{color:var(--blue-600)}
.text-center{text-align:center}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
@keyframes fadeInUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.animate-in{animation:fadeInUp .6s ease both}
nav.navigation{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;padding:2.5rem 0}
.page-numbers{display:inline-flex;align-items:center;padding:.375rem .75rem;border:1px solid var(--slate-200);background:#fff;color:var(--slate-600);font-size:.8rem;font-weight:600;text-decoration:none;transition:all .2s}
.page-numbers.current,.page-numbers:hover{background:var(--slate-900);color:#fff;border-color:var(--slate-900)}
