/* ==========================================================================
   Deira Packaging — design tokens + component CSS
   Ported from the hifi design handoff (Homepage/About/Industries/Product).
   ========================================================================== */

:root{
  --red:#C41E1E; --red-dark:#8B1414; --red-light:#FDEAEA;
  --black:#0A0A0A; --dark-gray:#1C1C1C; --off-white:#F5F3F0; --white:#FFFFFF;
  --body-dark:#333333; --mid-gray:#666666; --light-gray:#AAAAAA;
  --font-display:'Archivo',sans-serif; --font-head:'Archivo',sans-serif; --font-body:'Inter',sans-serif;
  --content:1200px; --nav-h:78px; --topbar-h:38px; --header-h:calc(var(--topbar-h) + var(--nav-h));
}

/* ---------- Reset / neutralize Astra container ---------- */
#page,#content,.ast-container,.site-content,#primary,#primary.site-main{max-width:none;padding:0;margin:0;width:100%;display:block!important;flex-direction:column!important;}
.ast-container{padding-left:0;padding-right:0;}
body.deira-page *{box-sizing:border-box;}
body.deira-page img{display:block;max-width:100%;}
body.deira-page a{color:inherit;}
body.deira-page{font-family:var(--font-body);color:var(--body-dark);background:var(--off-white);-webkit-font-smoothing:antialiased;line-height:1.65;}
html{scroll-behavior:smooth;}

.wrap{width:100%;max-width:none;margin:0;padding:0 7%;}
.section{padding:96px 0;}
.rule2{height:2px;background:var(--red);border:0;width:100%;}
.kicker{font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:0.18em;color:var(--red);margin-bottom:16px;display:flex;align-items:center;gap:14px;}
.kicker::before{content:"";width:34px;height:2px;background:var(--red);display:inline-block;}
h2.sec-title{font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:-0.02em;font-size:42px;line-height:1.04;color:var(--black);}
.sec-lead{font-size:18px;color:var(--mid-gray);max-width:640px;margin-top:18px;}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;white-space:nowrap;font-family:var(--font-body);font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:0.06em;padding:15px 28px;border-radius:4px;border:2px solid transparent;cursor:pointer;text-decoration:none;transition:background .15s,color .15s,border-color .15s,transform .15s;}
.btn svg{width:18px;height:18px;}
.btn-primary{background:var(--red);color:var(--white);}
.btn-primary:hover{background:var(--red-dark);}
.btn-sec-dark{background:transparent;border-color:var(--white);color:var(--white);}
.btn-sec-dark:hover{background:var(--white);color:var(--black);}
.btn-sec-light{background:transparent;border-color:var(--red);color:var(--red);}
.btn-sec-light:hover{background:var(--red);color:var(--white);}

/* ---------- NAV ---------- */
.topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar-h);background:var(--red);color:var(--white);z-index:101;display:flex;align-items:center;font-size:13px;}
.topbar .wrap{display:flex;align-items:center;justify-content:flex-end;width:100%;gap:24px;}
.topbar-left{display:flex;align-items:center;gap:24px;}
.topbar a{color:var(--white);text-decoration:none;display:inline-flex;align-items:center;gap:6px;opacity:.92;transition:opacity .15s;}
.topbar a:hover{opacity:1;text-decoration:underline;}
.topbar svg{width:14px;height:14px;flex:0 0 auto;}
.topbar-right{display:flex;align-items:center;gap:18px;}
.topbar-social{display:flex;gap:10px;}
.topbar-social a{width:22px;height:22px;border:1px solid rgba(255,255,255,.4);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:1;}
.topbar-social a:hover{background:rgba(255,255,255,.15);}
.topbar-social svg{width:11px;height:11px;}

header.nav{position:fixed;top:var(--topbar-h);left:0;right:0;height:var(--nav-h);background:var(--white);border-bottom:2px solid var(--red);z-index:100;display:flex;align-items:center;}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;width:100%;}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none;}
.brand img{height:46px;width:auto;}
.brand .wm{display:flex;flex-direction:column;line-height:0.9;}
.brand .wm .d{font-family:var(--font-display);font-weight:700;font-size:21px;letter-spacing:0.02em;color:var(--black);text-transform:uppercase;}
.brand .wm .p{font-family:var(--font-display);font-weight:700;font-size:21px;letter-spacing:0.02em;color:var(--red);text-transform:uppercase;}
.nav-right{display:flex;align-items:center;gap:36px;}
.nav-links{display:flex;gap:30px;align-items:center;list-style:none;margin:0;padding:0;}
.nav-links li{position:relative;}
.nav-links>li>a{font-family:var(--font-head);font-weight:600;font-size:15px;text-transform:uppercase;letter-spacing:0.05em;color:var(--body-dark);text-decoration:none;padding:4px 0;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;display:inline-flex;align-items:center;gap:6px;}
.nav-links>li>a:hover,.nav-links a.active{color:var(--red);}
.nav-links li.current-menu-item>a,.nav-links li.current_page_item>a,.nav-links li.current-menu-ancestor>a,.nav-links a.active{border-bottom-color:var(--red);color:var(--black);}
.nav .btn{padding:11px 22px;}

/* dropdown submenus */
.nav-links li.menu-item-has-children>a::after{content:"";width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg);margin-top:-3px;}
.nav-links .sub-menu{list-style:none;margin:0;padding:8px 0;position:absolute;top:100%;left:0;background:var(--white);border:1px solid #e4e0db;min-width:220px;box-shadow:0 14px 30px rgba(0,0,0,.1);opacity:0;visibility:hidden;transform:translateY(4px);transition:opacity .15s,transform .15s,visibility .15s;z-index:60;}
.nav-links li.menu-item-has-children:hover>.sub-menu,.nav-links li.menu-item-has-children:focus-within>.sub-menu{opacity:1;visibility:visible;transform:translateY(0);}
.nav-links .sub-menu li{border-bottom:1px solid #e4e0db;}
.nav-links .sub-menu li:last-child{border-bottom:0;}
.nav-links .sub-menu a{display:block;padding:11px 18px;font-family:var(--font-body);font-weight:500;font-size:14px;text-transform:none;letter-spacing:0;color:var(--body-dark);text-decoration:none;border-bottom:0;}
.nav-links .sub-menu a:hover{color:var(--red);background:var(--off-white);}
.nav-toggle{display:none;background:none;border:0;padding:8px;cursor:pointer;color:var(--black);}
.nav-toggle svg{width:26px;height:26px;}

/* ---------- HERO (home) ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding-top:var(--header-h);overflow:hidden;background:var(--off-white);border-bottom:2px solid var(--red);}
.hero-octa{position:absolute;left:-180px;top:50%;transform:translateY(-50%);width:580px;height:580px;opacity:0.06;z-index:0;pointer-events:none;}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr 0.95fr;gap:60px;align-items:center;padding-top:56px;padding-bottom:72px;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-body);font-weight:600;font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--mid-gray);margin-bottom:26px;}
.hero-eyebrow::before{content:"";width:30px;height:2px;background:var(--red);}
.hero h1{font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:-0.02em;font-size:60px;line-height:1.02;color:var(--black);max-width:15ch;}
.hero h1 .accent{color:var(--red);}
.hero p.sub{font-size:19px;line-height:1.6;color:var(--mid-gray);max-width:560px;margin-top:26px;}
.hero-ctas{display:flex;gap:18px;margin-top:38px;flex-wrap:wrap;}
.hero-trust{display:flex;align-items:center;gap:12px;margin-top:32px;font-weight:500;font-size:13px;text-transform:uppercase;letter-spacing:0.08em;color:var(--mid-gray);}
.hero-trust svg{width:18px;height:18px;color:var(--red);}
.hero-media{position:relative;}
.hero-media img{width:100%;height:560px;object-fit:cover;}
.hero-media .hm-badge{position:absolute;left:0;bottom:0;background:var(--red);color:#fff;padding:16px 22px;}
.hero-media .hm-badge .n{font-family:var(--font-display);font-weight:700;font-size:30px;line-height:1;}
.hero-media .hm-badge .l{font-size:11px;text-transform:uppercase;letter-spacing:0.1em;margin-top:4px;}

/* ---------- CATEGORIES (home) ---------- */
.cat-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:46px;flex-wrap:wrap;}
.cat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;}
.cat-card{position:relative;background:var(--white);border:1px solid #e4e0db;display:flex;flex-direction:column;overflow:hidden;transition:border-color .15s,transform .15s,box-shadow .15s;}
.cat-card:hover{border-color:var(--red);transform:translateY(-4px);box-shadow:0 16px 36px rgba(0,0,0,.12);}
.cat-media{position:relative;aspect-ratio:4/3;background:#fff;border-bottom:1px solid #e4e0db;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.cat-media img{width:80%;height:80%;object-fit:contain;transition:transform .25s ease;}
.cat-card:hover .cat-media img{transform:scale(1.05);}
.cat-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1;}
.cat-card .cat-name{font-family:var(--font-head);font-weight:600;font-size:18px;color:var(--black);line-height:1.12;}
.cat-card .cat-tag{font-size:12.5px;color:var(--mid-gray);line-height:1.45;margin-top:6px;margin-bottom:auto;}
.cat-card .cat-go{margin-top:16px;display:inline-flex;align-items:center;gap:7px;color:var(--red);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:0.08em;text-decoration:none;}
.cat-card .cat-go svg{width:15px;height:15px;transition:transform .15s;}
.cat-card:hover .cat-go svg{transform:translateX(4px);}

/* ---------- ABOUT TEASER (home) ---------- */
.about{background:var(--white);position:relative;overflow:hidden;}
.about-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:64px;align-items:center;}
.about-copy p{font-size:17px;line-height:1.7;color:var(--body-dark);margin-top:20px;}
.about-copy .lead-link{display:inline-flex;align-items:center;gap:8px;margin-top:28px;color:var(--red);font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:0.06em;text-decoration:none;}
.about-copy .lead-link svg{width:16px;height:16px;}
.about-affl{margin-top:30px;padding-top:22px;border-top:1px solid #e4e0db;font-size:13px;letter-spacing:0.04em;color:var(--mid-gray);}
.about-affl a{color:var(--red);text-decoration:none;}
.about-media{position:relative;}
.about-media img{width:100%;aspect-ratio:4/3;object-fit:cover;}
.about-media .badge{position:absolute;left:0;bottom:0;background:var(--red);color:#fff;padding:20px 26px;}
.about-media .badge .n{font-family:var(--font-display);font-weight:700;font-size:40px;line-height:1;}
.about-media .badge .l{font-size:12px;text-transform:uppercase;letter-spacing:0.1em;margin-top:4px;}

/* ---------- WHY CHOOSE US (home) ---------- */
.why{background:var(--white);}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:50px;border-top:2px solid var(--red);}
.why-cell{padding:36px 28px 30px;border-right:1px solid #e4e0db;}
.why-cell:last-child{border-right:0;}
.why-cell .wi{color:var(--red);margin-bottom:22px;}
.why-cell .wi svg{width:38px;height:38px;}
.why-cell h3{font-family:var(--font-head);font-weight:600;font-size:22px;text-transform:uppercase;color:var(--black);margin-bottom:12px;line-height:1.1;}
.why-cell p{font-size:15px;color:var(--mid-gray);line-height:1.55;}

/* ---------- INDUSTRIES TILES (home) ---------- */
.ind{background:var(--off-white);}
.ind-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:300px;gap:18px;margin-top:48px;}
.ind-tile{position:relative;overflow:hidden;text-decoration:none;display:flex;align-items:flex-end;}
.ind-tile:nth-child(1){grid-column:span 3;}
.ind-tile:nth-child(2){grid-column:span 3;}
.ind-tile:nth-child(3){grid-column:span 2;}
.ind-tile:nth-child(4){grid-column:span 2;}
.ind-tile:nth-child(5){grid-column:span 2;}
.ind-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.ind-tile:hover img{transform:scale(1.05);}
.ind-tile .iov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.15) 30%,rgba(10,10,10,.82) 100%);}
.ind-tile .itx{position:relative;z-index:2;padding:28px;}
.ind-tile .itag{display:inline-block;background:var(--red);color:#fff;font-weight:700;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;padding:5px 10px;margin-bottom:12px;}
.ind-tile h3{font-family:var(--font-head);font-weight:600;font-size:24px;text-transform:uppercase;color:var(--white);line-height:1.05;}
.ind-tile p{font-size:14px;color:rgba(255,255,255,.82);line-height:1.45;margin-top:8px;max-width:42ch;}

/* ---------- QUOTE CTA (shared) ---------- */
.quote{background:var(--off-white);position:relative;overflow:hidden;border-top:2px solid var(--red);}
.quote .wmk{position:absolute;right:-60px;top:50%;transform:translateY(-50%);opacity:0.05;pointer-events:none;}
.quote .wrap{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:48px;flex-wrap:wrap;padding-top:72px;padding-bottom:72px;}
.quote h2{font-family:var(--font-display);font-weight:800;font-size:48px;text-transform:uppercase;letter-spacing:-0.02em;color:var(--black);line-height:1.0;}
.quote h2 .accent{color:var(--red);}
.quote p{font-size:18px;color:var(--mid-gray);margin-top:14px;max-width:46ch;}

/* ---------- FOOTER (shared) ---------- */
footer.site-foot{background:var(--off-white);border-top:2px solid var(--red);padding:64px 0 0;}
.foot-cols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:48px;}
.foot-brand .brand{margin-bottom:20px;}
.foot-brand .tag{font-size:14px;color:var(--mid-gray);line-height:1.6;max-width:260px;}
.foot-social{display:flex;gap:14px;margin-top:24px;}
.foot-social a{width:38px;height:38px;border:1px solid #d8d4ce;display:flex;align-items:center;justify-content:center;color:var(--mid-gray);transition:border-color .15s,color .15s;}
.foot-social a:hover{border-color:var(--red);color:var(--red);}
.foot-social svg{width:18px;height:18px;}
footer h4{font-family:var(--font-head);font-weight:600;font-size:15px;text-transform:uppercase;letter-spacing:0.06em;color:var(--black);margin-bottom:20px;}
footer ul{list-style:none;}
footer li{margin-bottom:11px;}
footer li a,footer .fc{font-size:14px;color:var(--mid-gray);text-decoration:none;line-height:1.5;transition:color .15s;}
footer li a:hover{color:var(--red);}
.foot-contact .fc{display:block;}
.foot-contact .fc.strong{color:var(--body-dark);}
.foot-bottom{margin-top:56px;border-top:1px solid #e4e0db;padding:22px 0;}
.foot-bottom .wrap{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.foot-bottom span,.foot-bottom a{font-size:13px;color:var(--mid-gray);text-decoration:none;}
.foot-bottom a:hover{color:var(--red);}

/* ---------- PAGE HEADER (about/industries) ---------- */
.phead{position:relative;padding-top:calc(var(--header-h) + 84px);padding-bottom:84px;overflow:hidden;background:var(--off-white);border-bottom:2px solid var(--red);}
.phead-octa{position:absolute;right:-160px;top:50%;transform:translateY(-50%);width:560px;height:560px;opacity:0.06;z-index:0;pointer-events:none;}
.phead .wrap{position:relative;z-index:2;}
.breadcrumb{display:flex;align-items:center;gap:10px;font-size:13px;text-transform:uppercase;letter-spacing:0.08em;color:var(--mid-gray);margin-bottom:26px;}
.breadcrumb a{text-decoration:none;color:var(--mid-gray);transition:color .15s;}
.breadcrumb a:hover{color:var(--red);}
.breadcrumb .sep{color:var(--light-gray);}
.breadcrumb .here{color:var(--red);font-weight:600;}
.phead h1{font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:-0.02em;font-size:64px;line-height:1.0;color:var(--black);max-width:18ch;}
.phead h1 .accent{color:var(--red);}
.phead p.lead{font-size:20px;line-height:1.6;color:var(--mid-gray);max-width:680px;margin-top:26px;}

/* ---------- STORY (about) ---------- */
.story{background:var(--white);}
.story-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:64px;align-items:center;}
.story-copy p{font-size:17px;line-height:1.7;color:var(--body-dark);margin-top:20px;}
.story-media{position:relative;}
.story-media img{width:100%;aspect-ratio:4/5;object-fit:cover;}
.story-media .badge{position:absolute;left:0;bottom:0;background:var(--red);color:#fff;padding:22px 28px;}
.story-media .badge .n{font-family:var(--font-display);font-weight:700;font-size:44px;line-height:1;}
.story-media .badge .l{font-size:12px;text-transform:uppercase;letter-spacing:0.1em;margin-top:5px;}

/* ---------- HERITAGE / DTC (about) ---------- */
.heritage{position:relative;overflow:hidden;background:var(--off-white);}
.heritage-grid{display:grid;grid-template-columns:0.9fr 1.1fr;gap:64px;align-items:center;}
.heritage-media{position:relative;}
.heritage-media img{width:100%;aspect-ratio:4/3;object-fit:cover;}
.heritage-copy p{font-size:17px;line-height:1.7;color:var(--body-dark);margin-top:20px;}
.heritage-copy .affl{margin-top:28px;padding:20px 24px;background:var(--white);border-left:3px solid var(--red);font-size:15px;color:var(--body-dark);}
.heritage-copy .affl a{color:var(--red);text-decoration:none;font-weight:600;}

/* ---------- STATS (about) ---------- */
.stats{background:var(--white);}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:2px solid var(--red);}
.stat{padding:40px 28px 34px;border-right:1px solid #e4e0db;}
.stat:last-child{border-right:0;}
.stat .n{font-family:var(--font-display);font-weight:800;font-size:52px;line-height:1;color:var(--red);letter-spacing:-0.02em;}
.stat .l{font-family:var(--font-head);font-weight:600;font-size:15px;text-transform:uppercase;letter-spacing:0.04em;color:var(--black);margin-top:14px;}
.stat .d{font-size:14px;color:var(--mid-gray);line-height:1.5;margin-top:8px;}

/* ---------- VALUES (about) ---------- */
.values{background:var(--off-white);}
.val-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:50px;}
.val-cell{background:var(--white);border:1px solid #e4e0db;border-top:2px solid var(--red);padding:34px 28px 30px;}
.val-cell .vi{color:var(--red);margin-bottom:22px;}
.val-cell .vi svg{width:38px;height:38px;}
.val-cell h3{font-family:var(--font-head);font-weight:600;font-size:21px;text-transform:uppercase;color:var(--black);margin-bottom:12px;line-height:1.1;}
.val-cell p{font-size:15px;color:var(--mid-gray);line-height:1.55;}

/* ---------- JUMP NAV (industries) ---------- */
.jumpnav{background:var(--white);border-bottom:1px solid #e4e0db;position:sticky;top:var(--header-h);z-index:50;}
.jumpnav .wrap{display:flex;gap:8px;flex-wrap:wrap;padding-top:16px;padding-bottom:16px;}
.jumpnav a{font-family:var(--font-head);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:0.04em;color:var(--body-dark);text-decoration:none;padding:9px 16px;border:1px solid #e4e0db;transition:border-color .15s,color .15s,background .15s;}
.jumpnav a:hover{border-color:var(--red);color:var(--red);}

/* ---------- INDUSTRY ROWS (industries) ---------- */
.ind-row{background:var(--white);}
.ind-row:nth-child(even){background:var(--off-white);}
.ind-row .ind-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.ind-row:nth-child(even) .ind-media{order:2;}
.ind-row .ind-media{position:relative;overflow:hidden;}
.ind-row .ind-media img{width:100%;aspect-ratio:4/3;object-fit:cover;}
.ind-row .ind-media .num{position:absolute;left:0;top:0;background:var(--red);color:#fff;font-family:var(--font-display);font-weight:800;font-size:22px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;letter-spacing:-0.02em;}
.ind-copy .tag{display:inline-block;background:var(--red-light);color:var(--red);font-weight:700;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;padding:6px 12px;margin-bottom:18px;}
.ind-copy h2{font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:-0.02em;font-size:36px;line-height:1.05;color:var(--black);}
.ind-copy p{font-size:17px;line-height:1.7;color:var(--body-dark);margin-top:18px;}
.prod-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px;}
.prod-chips .ck{flex-basis:100%;font-weight:700;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--mid-gray);margin-bottom:2px;}
.prod-chips a{font-family:var(--font-head);font-weight:600;font-size:13px;color:var(--body-dark);text-decoration:none;background:var(--white);border:1px solid #e4e0db;padding:8px 14px;transition:border-color .15s,color .15s;}
.prod-chips a:hover{border-color:var(--red);color:var(--red);}

/* ---------- PRODUCT HERO / GALLERY / SUMMARY ---------- */
.phero{padding-top:calc(var(--header-h) + 44px);padding-bottom:64px;background:var(--white);border-bottom:1px solid #e4e0db;}
.phero-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;}
.gallery .main{position:relative;aspect-ratio:4/3;background:var(--off-white);border:1px solid #e4e0db;overflow:hidden;}
.gallery .main img{width:100%;height:100%;object-fit:cover;}
.gallery .thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:14px;}
.gallery .thumbs button{padding:0;border:1px solid #e4e0db;background:var(--off-white);aspect-ratio:1;overflow:hidden;cursor:pointer;transition:border-color .15s;}
.gallery .thumbs button img{width:100%;height:100%;object-fit:cover;}
.gallery .thumbs button.active{border-color:var(--red);border-width:2px;}
.psum .ptag{display:inline-block;background:var(--red-light);color:var(--red);font-weight:700;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;padding:6px 12px;margin-bottom:16px;}
.psum h1{font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:-0.02em;font-size:46px;line-height:1.0;color:var(--black);}
.psum .psub{font-size:13px;text-transform:uppercase;letter-spacing:0.08em;color:var(--mid-gray);margin-top:10px;}
.psum .pdesc{font-size:17px;line-height:1.7;color:var(--body-dark);margin-top:22px;}
.quickspecs{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:30px;border-top:1px solid #e4e0db;border-left:1px solid #e4e0db;}
.quickspecs .qs{padding:16px 18px;border-right:1px solid #e4e0db;border-bottom:1px solid #e4e0db;}
.quickspecs .qs .k{font-size:11px;text-transform:uppercase;letter-spacing:0.08em;color:var(--mid-gray);font-weight:600;}
.quickspecs .qs .v{font-family:var(--font-head);font-weight:600;font-size:18px;color:var(--black);margin-top:4px;}
.phero-ctas{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap;}

/* ---------- BENEFITS (product) ---------- */
.benefits{background:var(--off-white);}
.ben-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:18px;margin-top:46px;}
.ben{background:var(--white);border:1px solid #e4e0db;border-top:2px solid var(--red);padding:24px 20px;}
.ben .bi{color:var(--red);margin-bottom:16px;}
.ben .bi svg{width:32px;height:32px;}
.ben h3{font-family:var(--font-head);font-weight:600;font-size:15px;text-transform:uppercase;color:var(--black);line-height:1.2;}

/* ---------- APPLICATIONS (product) ---------- */
.apps{background:var(--white);}
.app-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:50px;}
.app{background:var(--white);border:1px solid #e4e0db;padding:30px 26px;display:flex;flex-direction:column;transition:border-color .15s,box-shadow .15s,transform .15s;}
.app:hover{border-color:var(--red);box-shadow:0 14px 30px rgba(0,0,0,.08);transform:translateY(-3px);}
.app .ai{color:var(--red);margin-bottom:18px;}
.app .ai svg{width:34px;height:34px;}
.app h3{font-family:var(--font-head);font-weight:600;font-size:20px;text-transform:uppercase;color:var(--black);line-height:1.1;margin-bottom:16px;}
.app ul{list-style:none;}
.app li{font-size:14px;color:var(--body-dark);line-height:1.5;padding-left:18px;position:relative;margin-bottom:8px;}
.app li::before{content:"";position:absolute;left:0;top:9px;width:6px;height:6px;background:var(--red);}

/* ---------- SPECS + IMG SPLIT (product) ---------- */
.specs{background:var(--off-white);}
.specs-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.spec-table{width:100%;border-collapse:collapse;margin-top:6px;background:var(--white);border:1px solid #e4e0db;}
.spec-table tr{border-bottom:1px solid #e4e0db;}
.spec-table tr:last-child{border-bottom:0;}
.spec-table td{padding:16px 20px;font-size:15px;vertical-align:top;}
.spec-table td.k{font-family:var(--font-head);font-weight:600;text-transform:uppercase;letter-spacing:0.03em;font-size:13px;color:var(--mid-gray);width:42%;background:var(--off-white);border-right:1px solid #e4e0db;}
.spec-table td.v{color:var(--black);font-weight:500;}
.specs-media img{width:100%;aspect-ratio:3/4;object-fit:cover;border:1px solid #e4e0db;}

/* ---------- QUOTE MODAL ---------- */
.qm-overlay{position:fixed;inset:0;background:rgba(10,10,10,.6);backdrop-filter:blur(3px);z-index:1000;display:none;align-items:center;justify-content:center;padding:24px;opacity:0;transition:opacity .2s;}
.qm-overlay.open{display:flex;opacity:1;}
.qm{background:var(--white);width:100%;max-width:560px;max-height:92vh;overflow:auto;position:relative;box-shadow:0 30px 80px rgba(0,0,0,.4);border-top:3px solid var(--red);transform:translateY(14px);transition:transform .2s;}
.qm-overlay.open .qm{transform:translateY(0);}
.qm-close{position:absolute;top:16px;right:16px;width:38px;height:38px;border:1px solid #e4e0db;background:var(--white);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--mid-gray);transition:border-color .15s,color .15s;z-index:3;}
.qm-close:hover{border-color:var(--red);color:var(--red);}
.qm-close svg{width:18px;height:18px;}
.qm-head{padding:30px 34px 22px;border-bottom:1px solid #e4e0db;position:relative;overflow:hidden;}
.qm-head .octa{position:absolute;right:-50px;top:-46px;width:190px;height:190px;opacity:.05;pointer-events:none;}
.qm-kicker{font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.18em;color:var(--red);margin-bottom:10px;display:flex;align-items:center;gap:12px;}
.qm-kicker::before{content:"";width:28px;height:2px;background:var(--red);}
.qm-head h3{font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:-.02em;font-size:30px;color:var(--black);line-height:1;}
.qm-head p{font-size:14px;color:var(--mid-gray);margin-top:10px;max-width:42ch;}
.qm-body{padding:24px 34px 30px;}
.qm-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.qm-field{margin-bottom:16px;}
.qm-field.full{grid-column:1 / -1;}
.qm-field label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--body-dark);margin-bottom:7px;}
.qm-field label .req{color:var(--red);}
.qm-field input,.qm-field select,.qm-field textarea{width:100%;font-family:var(--font-body);font-size:15px;color:var(--black);background:var(--off-white);border:1px solid #e4e0db;padding:12px 14px;border-radius:3px;transition:border-color .15s,background .15s;}
.qm-field input:focus,.qm-field select:focus,.qm-field textarea:focus{outline:none;border-color:var(--red);background:var(--white);}
.qm-field textarea{resize:vertical;min-height:88px;}
.qm-field-msg{display:none;color:var(--red);font-size:12px;margin-top:6px;line-height:1.4;}
.qm-field-msg.show{display:block;}
.qm-note{font-size:12px;color:var(--mid-gray);margin-top:16px;line-height:1.6;}
.qm-note strong{color:var(--body-dark);}
.qm-success{display:none;padding:54px 34px 58px;text-align:center;}
.qm-success.show{display:block;}
.qm-success .ic{width:66px;height:66px;border-radius:50%;background:var(--red-light);color:var(--red);display:flex;align-items:center;justify-content:center;margin:0 auto 22px;}
.qm-success .ic svg{width:32px;height:32px;}
.qm-success h3{font-family:var(--font-display);font-weight:800;text-transform:uppercase;font-size:26px;color:var(--black);margin-bottom:12px;}
.qm-success p{font-size:15px;color:var(--mid-gray);max-width:36ch;margin:0 auto;line-height:1.6;}
.qm-error-banner{display:none;background:var(--red-light);color:var(--red);font-size:13px;padding:12px 16px;margin-bottom:16px;}
.qm-error-banner.show{display:block;}

/* ==========================================================================
   Responsive — breakpoints match the reference: 1080 (tablet), 640 (mobile)
   ========================================================================== */
@media(max-width:1080px){
  .topbar-social{display:none;}
  .cat-grid{grid-template-columns:repeat(3,1fr);}
  .cat-head{flex-direction:column;align-items:flex-start;gap:18px;}
  .cat-head .sec-lead{max-width:none;}
  .why-grid{grid-template-columns:repeat(2,1fr);}
  .why-cell:nth-child(2){border-right:0;}
  .why-cell{border-bottom:1px solid #e4e0db;}
  .about-grid{grid-template-columns:1fr;gap:40px;}
  .ind-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:260px;}
  .ind-tile:nth-child(n){grid-column:span 1;}
  .ind-tile:nth-child(1){grid-column:span 2;}
  .foot-cols{grid-template-columns:1fr 1fr;gap:36px;}
  .hero .wrap{grid-template-columns:1fr;gap:36px;}
  .hero-media img{height:320px;}
  .hero h1{font-size:46px;}
  .story-grid,.heritage-grid{grid-template-columns:1fr;gap:40px;}
  .heritage-media{order:-1;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .stat:nth-child(2){border-right:0;}
  .stat{border-bottom:1px solid #e4e0db;}
  .val-grid{grid-template-columns:1fr 1fr;}
  .phead h1{font-size:46px;}
  .jumpnav{position:static;}
  .ind-row .ind-grid{grid-template-columns:1fr;gap:36px;}
  .ind-row:nth-child(even) .ind-media{order:-1;}
  .phero-grid{grid-template-columns:1fr;gap:40px;}
  .ben-grid{grid-template-columns:repeat(3,1fr);}
  .app-grid{grid-template-columns:1fr 1fr;}
  .specs-grid{grid-template-columns:1fr;gap:40px;}
  .specs-media{max-width:420px;}

  /* mobile nav */
  .nav-links{position:fixed;top:var(--header-h);left:0;right:0;background:var(--white);flex-direction:column;align-items:flex-start;gap:0;border-bottom:2px solid var(--red);max-height:0;overflow:hidden;transition:max-height .25s ease;}
  .nav-links.open{max-height:70vh;overflow-y:auto;}
  .nav-links li{width:100%;border-bottom:1px solid #e4e0db;}
  .nav-links>li>a{width:100%;padding:16px 7%;border-bottom:0;}
  .nav-links li.menu-item-has-children{display:flex;flex-wrap:wrap;align-items:center;}
  .nav-links li.menu-item-has-children>a{flex:1 1 auto;width:auto;}
  .nav-links li.menu-item-has-children>a::after{display:none;}
  .submenu-toggle{display:flex;flex:0 0 auto;align-items:center;justify-content:center;width:54px;height:54px;background:none;border:0;color:var(--body-dark);cursor:pointer;}
  .submenu-toggle svg{width:16px;height:16px;transition:transform .2s;}
  .nav-links li.submenu-open .submenu-toggle svg{transform:rotate(180deg);}
  .nav-links .sub-menu{flex:1 0 100%;max-height:0;overflow:hidden;transition:max-height .3s ease;position:static;opacity:1;visibility:visible;transform:none;border:0;box-shadow:none;background:var(--off-white);padding:0;}
  .nav-links li.submenu-open>.sub-menu{max-height:1000px;}
  .nav-links .sub-menu li{border-bottom:1px solid #e9e5e0;}
  .nav-links .sub-menu a{padding:14px 11%;}
  .nav-toggle{display:flex;align-items:center;justify-content:center;}
  .nav-right{gap:16px;}
}
@media(min-width:1081px){
  .submenu-toggle{display:none;}
}
@media(max-width:640px){
  :root{--topbar-h:34px;}
  .topbar-left a:nth-child(2){display:none;}
  .topbar{font-size:11.5px;}
  .brand img{height:36px;}
  .brand .wm .d,.brand .wm .p{font-size:17px;}
  .nav-right{gap:10px;}
  .nav-right>a.btn{display:none;}
  .nav-toggle{padding:6px;}
  .nav-toggle svg{width:22px;height:22px;}
  .cat-grid{grid-template-columns:1fr 1fr;}
  .wrap{padding:0 22px;}
  .section{padding:64px 0;}
  .nav-links>li>a{padding:16px 22px;}
  .nav-links .sub-menu a{padding:14px 22px 14px 36px;}
  .stats-grid{grid-template-columns:1fr;}
  .stat{border-right:0;}
  .val-grid{grid-template-columns:1fr;}
  .phead h1{font-size:38px;}
  .ind-copy h2{font-size:28px;}
  .psum h1{font-size:34px;}
  .ben-grid{grid-template-columns:1fr 1fr;}
  .app-grid{grid-template-columns:1fr;}
  .quickspecs{grid-template-columns:1fr;}
  .qm-row{grid-template-columns:1fr;}
  .qm-head,.qm-body{padding-left:24px;padding-right:24px;}
}
