/* =========================================================
   AL-OMARI TRADING EST. — DESIGN SYSTEM
   Concept: "The Manifest" — light, warm-paper trade-document
   aesthetic with a teal accent tied to the brand mark.
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@500;600;700;800&family=Inter:wght@400;500;600&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root{
  --ink:#16212F;
  --ink-soft:#3C4A59;
  --sand:#EEE6D3;
  --paper:#FBF9F3;
  --paper-2:#F3EEE0;
  --accent:#1B6E7A;
  --accent-deep:#134F58;
  --line: rgba(22,33,47,0.13);
  --line-soft: rgba(22,33,47,0.08);
  --max: 1280px;
}

*{box-sizing:border-box;}
html,body{margin:0; padding:0; width:100%;}
html{scroll-behavior:smooth;}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'Inter', sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%; display:block;}
a{color:inherit;}
.mono{font-family:'IBM Plex Mono', monospace; letter-spacing:0.04em;}
h1,h2,h3{font-family:'Barlow Condensed', sans-serif; text-transform:uppercase; letter-spacing:0.01em; line-height:0.97; margin:0;}
p{margin:0;}

/* ---- reveal-on-scroll ---- */
.reveal{opacity:0; transform:translateY(24px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1; transform:translateY(0);}

/* ---- ticker ---- */
.ticker-wrap{
  background:var(--paper-2); color:var(--ink); overflow:hidden;
  border-bottom:1px solid var(--line);
  padding:9px 0;
}
.ticker{
  display:flex; white-space:nowrap; width:max-content;
  animation:scrollTicker 42s linear infinite;
  font-family:'IBM Plex Mono', monospace; font-size:12px; letter-spacing:0.08em;
}
.ticker span{padding:0 22px; opacity:0.85; display:flex; align-items:center; gap:22px;}
.ticker span::after{content:'◆'; color:var(--accent); font-size:8px;}
@keyframes scrollTicker{from{transform:translateX(0)} to{transform:translateX(-50%)}}

/* ---- header ---- */
header.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(251,249,243,0.88); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:var(--max); margin:0 auto; padding:16px 40px;
  display:flex; align-items:center; justify-content:space-between;
}
.brand{display:flex; align-items:center; gap:12px; text-decoration:none;}
.brand-mark{
  width:42px; height:42px; border-radius:8px; overflow:hidden; flex-shrink:0;
  box-shadow:0 2px 10px rgba(22,33,47,0.15);
}
.brand-mark img{width:100%; height:100%; object-fit:cover; display:block;}
.brand-name{font-family:'Barlow Condensed'; font-weight:700; font-size:19px; letter-spacing:0.02em; text-transform:uppercase; color:var(--ink);}
.brand-name small{display:block; font-family:'IBM Plex Mono'; font-weight:400; text-transform:none; font-size:10px; letter-spacing:0.06em; color:var(--ink-soft); margin-top:1px;}
.navlinks{display:flex; gap:36px; align-items:center;}
.navlinks a{
  color:var(--ink); text-decoration:none; font-size:13px; font-weight:600;
  text-transform:uppercase; letter-spacing:0.08em; position:relative; padding-bottom:4px;
}
.navlinks a::after{content:''; position:absolute; left:0; bottom:0; width:0; height:2px; background:var(--accent); transition:width .3s;}
.navlinks a:hover::after, .navlinks a.active::after{width:100%;}
.btn-cta{
  background:var(--ink); color:var(--paper); border:none; padding:11px 22px;
  font-family:'IBM Plex Mono'; font-size:12px; letter-spacing:0.06em; text-transform:uppercase;
  cursor:pointer; display:inline-flex; align-items:center; gap:8px; text-decoration:none;
  transition:background .25s;
}
.btn-cta:hover{background:var(--accent);}

.menu-toggle{
  display:none; flex-direction:column; justify-content:center; gap:5px;
  width:38px; height:38px; background:none; border:none; cursor:pointer; padding:0;
}
.menu-toggle span{width:100%; height:2px; background:var(--ink); transition:transform .3s, opacity .3s;}
.menu-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.menu-toggle.open span:nth-child(2){opacity:0;}
.menu-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.mobile-menu{
  display:none; flex-direction:column; gap:2px; background:var(--paper);
  border-top:1px solid var(--line); overflow:hidden; max-height:0; transition:max-height .35s ease;
}
.mobile-menu.open{max-height:400px;}
.mobile-menu a{
  color:var(--ink); text-decoration:none; font-size:15px; font-weight:600; padding:16px 40px;
  border-bottom:1px solid var(--line-soft); text-transform:uppercase; letter-spacing:0.05em;
  display:block;
}
.mobile-menu .btn-cta{display:flex; margin:16px 40px 20px;}

/* ---- generic page hero (about/services/contact) ---- */
.page-hero{
  max-width:var(--max); margin:0 auto; padding:80px 40px 60px;
}
.page-hero .eyebrow-row{display:flex; align-items:center; gap:14px; margin-bottom:20px;}
.page-hero .eyebrow-row .rule{width:44px; height:1px; background:var(--line);}
.page-hero .eyebrow-row .txt{font-family:'IBM Plex Mono'; font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-soft);}
.page-hero h1{font-size:clamp(38px,6vw,72px); max-width:900px;}
.page-hero p.lead{color:var(--ink-soft); max-width:640px; margin-top:20px; font-size:16px; line-height:1.7;}

/* ---- hero tag-card (home) ---- */
.hero{position:relative; min-height:94vh; display:flex; align-items:center; padding:60px 40px 0; overflow:hidden;}
.hero-bg{position:absolute; inset:0; z-index:0;}
.hero-bg img{width:100%; height:100%; object-fit:cover; filter:brightness(1.08) saturate(1.05);}
.hero-bg::after{
  content:''; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(251,249,243,0.25) 0%, rgba(251,249,243,0.12) 45%, var(--paper) 96%),
    linear-gradient(90deg, rgba(251,249,243,0.35) 0%, transparent 45%);
}
.hero-inner{max-width:var(--max); margin:0 auto; width:100%; position:relative; z-index:2; padding-bottom:70px;}
.tag-card{
  position:relative; background:var(--paper); max-width:640px; padding:44px 46px 40px;
  border:1.5px dashed rgba(22,33,47,0.28); box-shadow:0 24px 60px -18px rgba(22,33,47,0.35);
  animation:tagSettle .9s cubic-bezier(.16,1,.3,1) both;
}
@keyframes tagSettle{from{opacity:0; transform:translateY(30px) rotate(-1.2deg);} to{opacity:1; transform:translateY(0) rotate(0deg);}}
.tag-hole{position:absolute; top:26px; left:-13px; width:26px; height:26px; border-radius:50%; background:var(--paper); border:1.5px dashed rgba(22,33,47,0.28);}
.tag-hole::after{content:''; position:absolute; inset:6px; border-radius:50%; background:var(--paper-2);}
.eyebrow-row{display:flex; align-items:center; gap:14px; margin-bottom:20px;}
.eyebrow-row .num{font-family:'IBM Plex Mono'; font-size:11.5px; color:var(--accent-deep); font-weight:500;}
.eyebrow-row .rule{flex:1; max-width:44px; height:1px; background:var(--line);}
.eyebrow-row .txt{font-family:'IBM Plex Mono'; font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-soft);}
.hero h1{color:var(--ink); font-size:clamp(40px, 5.6vw, 68px); font-weight:800;}
.hero h1 em{font-style:normal; color:var(--accent-deep);}
.hero-sub{color:var(--ink-soft); max-width:480px; margin-top:20px; font-size:15.5px; line-height:1.65;}
.hero-cta-row{display:flex; gap:14px; margin-top:30px; flex-wrap:wrap;}
.btn-solid-sm{
  background:var(--accent); color:var(--paper); border:none; padding:14px 26px;
  font-family:'IBM Plex Mono'; font-size:12.5px; letter-spacing:0.05em; text-transform:uppercase; cursor:pointer;
  text-decoration:none; display:inline-flex; align-items:center; gap:8px; transition:transform .25s, background .25s;
}
.btn-solid-sm:hover{background:var(--accent-deep); transform:translateY(-2px);}
.btn-outline-sm{
  background:transparent; color:var(--ink); border:1px solid var(--line); padding:14px 26px;
  font-family:'IBM Plex Mono'; font-size:12.5px; letter-spacing:0.05em; text-transform:uppercase; cursor:pointer;
  text-decoration:none; display:inline-flex; align-items:center;
}
.hero-meta{display:flex; gap:0; margin-top:34px; border-top:1px solid var(--line); flex-wrap:nowrap;}
.hero-meta div{padding:16px 18px 0 0; margin-right:18px; border-right:1px solid var(--line); flex:1; min-width:0;}
.hero-meta div:last-child{border-right:none; margin-right:0; padding-right:0;}
.hero-meta .val{font-family:'Barlow Condensed'; font-size:22px; font-weight:700; color:var(--ink);}
.hero-meta .lbl{font-family:'IBM Plex Mono'; font-size:9.5px; text-transform:uppercase; letter-spacing:0.06em; color:var(--ink-soft); margin-top:2px;}

/* ---- section shell ---- */
.section{max-width:var(--max); margin:0 auto; padding:110px 40px;}
.section-head{display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:56px; gap:40px; flex-wrap:wrap;}
.tag-line{display:flex; align-items:center; gap:10px; margin-bottom:18px;}
.tag-line .dot{width:7px; height:7px; background:var(--accent);}
.tag-line span{font-family:'IBM Plex Mono'; font-size:11.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-soft);}
.section-head h2{font-size:clamp(32px,4.2vw,50px);}
.section-head p{max-width:380px; color:var(--ink-soft); font-size:14.5px; line-height:1.6; padding-bottom:6px;}

/* ---- manifest doc / info panel ---- */
.manifest-doc{background:var(--paper-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.manifest-grid{display:grid; grid-template-columns:1fr 1fr; gap:0;}
.manifest-left{padding:100px 60px 100px 40px;}
.manifest-left h2{font-size:clamp(30px,3.2vw,42px); margin-bottom:26px;}
.manifest-left p{color:var(--ink-soft); font-size:15.5px; line-height:1.8; margin-bottom:18px; max-width:460px;}
.manifest-right{padding:100px 40px 100px 60px; position:relative; border-left:1px solid var(--line);}
.field-row{display:flex; justify-content:space-between; padding:15px 0; border-bottom:1px solid var(--line); font-family:'IBM Plex Mono'; font-size:12.5px;}
.field-row .k{color:var(--ink-soft); text-transform:uppercase; letter-spacing:0.06em; font-size:10.5px;}
.field-row .v{color:var(--ink); text-align:right; font-weight:500;}

/* ---- category cards ---- */
.cat-grid{display:grid; grid-template-columns:1fr 1fr; gap:2px; background:var(--line);}
.cat-card{position:relative; height:460px; overflow:hidden; background:var(--ink); cursor:pointer; outline:none;}
.cat-card:focus-visible{outline:2px solid var(--accent); outline-offset:-2px;}
.cat-card img{
  width:100%; height:100%; object-fit:cover; position:absolute; inset:0;
  filter:saturate(1.05) brightness(1.02); transform:scale(1.06);
  transition:transform 1s cubic-bezier(.2,.7,.2,1);
}
.cat-card:hover img{transform:scale(1.14);}
.cat-card::before{content:''; position:absolute; inset:0; z-index:1; background:linear-gradient(180deg, rgba(22,33,47,0.04) 0%, rgba(22,33,47,0.82) 100%);}
.cat-tag{
  position:absolute; top:24px; left:24px; z-index:2;
  font-family:'IBM Plex Mono'; font-size:11px; color:var(--paper); background:rgba(22,33,47,0.55);
  padding:6px 12px; letter-spacing:0.08em;
}
.cat-content{position:absolute; bottom:0; left:0; right:0; z-index:2; padding:32px;}
.cat-content h3{color:var(--paper); font-size:36px; margin-bottom:10px;}
.cat-content .sub-list{font-family:'IBM Plex Mono'; font-size:11px; color:var(--sand); letter-spacing:0.02em; margin-bottom:18px;}
.cat-link{
  display:inline-flex; align-items:center; gap:10px; color:var(--accent); text-decoration:none;
  font-size:12.5px; font-weight:600; text-transform:uppercase; letter-spacing:0.08em;
  border-bottom:1px solid var(--accent); padding-bottom:4px; transition:gap .3s; background:none; border-top:none; border-left:none; border-right:none; cursor:pointer; font-family:'IBM Plex Mono';
}
.cat-card:hover .cat-link{gap:16px;}

/* ---- quick browse strip (with scroll affordance) ---- */
.strip-wrap{
  position:relative;
}
.strip{
  display:flex; overflow-x:auto; gap:2px; background:var(--line);
  scrollbar-width:none; scroll-behavior:smooth; cursor:grab;
}
.strip.dragging{cursor:grabbing; scroll-behavior:auto;}
.strip::-webkit-scrollbar{display:none;}
.strip-item{min-width:220px; height:270px; position:relative; flex-shrink:0; overflow:hidden; background:var(--ink); cursor:pointer; outline:none;}
.strip-item:focus-visible{outline:2px solid var(--accent); outline-offset:-2px;}
.strip-item img{width:100%; height:100%; object-fit:cover; opacity:0.92; transition:transform .6s;}
.strip-item:hover img{transform:scale(1.06);}
.strip-item::after{content:''; position:absolute; inset:0; background:linear-gradient(180deg, transparent 50%, rgba(22,33,47,0.85) 100%);}
.strip-item span{position:absolute; bottom:16px; left:16px; right:16px; color:var(--paper); z-index:2; font-family:'IBM Plex Mono'; font-size:11.5px; letter-spacing:0.05em; text-transform:uppercase;}

.strip-wrap::before, .strip-wrap::after{
  content:''; position:absolute; top:0; bottom:0; width:60px; z-index:3;
  pointer-events:none; transition:opacity .3s;
}
.strip-wrap::before{left:0; background:linear-gradient(90deg, var(--paper), transparent); opacity:0;}
.strip-wrap::after{right:0; background:linear-gradient(270deg, var(--paper), transparent);}
.strip-wrap.at-start::before{opacity:0;}
.strip-wrap:not(.at-start)::before{opacity:1;}
.strip-wrap.at-end::after{opacity:0;}

.strip-arrow{
  position:absolute; top:50%; transform:translateY(-50%); z-index:4;
  width:44px; height:44px; border-radius:50%; background:var(--paper);
  border:1px solid var(--line); box-shadow:0 6px 18px rgba(22,33,47,0.15);
  display:flex; align-items:center; justify-content:center; cursor:pointer;
  color:var(--ink); font-size:16px; transition:background .25s, opacity .25s;
}
.strip-arrow:hover{background:var(--accent); color:var(--paper);}
.strip-arrow.prev{left:-8px;}
.strip-arrow.next{right:-8px;}
.strip-arrow[disabled]{opacity:0; pointer-events:none;}
.strip-scroll-hint{
  display:flex; align-items:center; gap:8px; margin-top:14px;
  font-family:'IBM Plex Mono'; font-size:11px; color:var(--ink-soft); letter-spacing:0.04em;
}
.strip-scroll-hint svg{width:14px; height:14px;}

/* ---- industries served ---- */
.industries{background:var(--sand);}
.ind-list{border-top:1px solid var(--line);}
.ind-row{display:grid; grid-template-columns:70px 1fr 220px; align-items:center; padding:24px 0; border-bottom:1px solid var(--line); transition:background .3s;}
.ind-row:hover{background:rgba(27,110,122,0.07);}
.ind-row .idx{font-family:'IBM Plex Mono'; color:var(--accent-deep); font-size:13px;}
.ind-row h4{font-family:'Barlow Condensed'; font-weight:600; font-size:24px; letter-spacing:0.01em; text-transform:none;}
.ind-row .code{font-family:'IBM Plex Mono'; font-size:11px; color:var(--ink-soft); text-align:right; letter-spacing:0.06em;}
.ind-grid-cards{display:grid; grid-template-columns:repeat(5,1fr); gap:16px;}
.ind-card{background:var(--paper); border:1px solid var(--line); padding:30px 20px; text-align:center;}
.ind-card .num{font-family:'Barlow Condensed'; color:var(--accent-deep); font-size:28px; font-weight:700; margin-bottom:10px;}
.ind-card p{font-family:'Barlow Condensed'; text-transform:none; font-size:17px; font-weight:600; line-height:1.35;}

/* ---- vision / mission cards ---- */
.vm-grid{display:grid; grid-template-columns:1fr 1fr; border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.vm-card{padding:56px 50px; position:relative;}
.vm-card:first-child{border-right:1px solid var(--line);}
.vm-card .roman{font-family:'Barlow Condensed'; color:var(--accent-deep); font-size:36px; font-weight:700; margin-bottom:16px;}
.vm-card h3{font-size:26px; margin-bottom:16px;}
.vm-card p{color:var(--ink-soft); font-size:15px; line-height:1.85;}

/* ---- leadership ---- */
.lead-grid{display:grid; grid-template-columns:1fr 1fr; gap:28px;}
.lead-card{display:flex; gap:24px; background:var(--paper-2); padding:32px; border:1px solid var(--line);}
.lead-photo{width:180px; height:180px; border-radius:50%; overflow:hidden; flex-shrink:0; border:2px solid var(--paper);}
.lead-photo img{width:100%; height:100%; object-fit:cover;}
.lead-card h4{font-family:'Barlow Condensed'; text-transform:none; font-size:20px; font-weight:600; margin-bottom:3px;}
.lead-card .role{font-family:'IBM Plex Mono'; font-size:10.5px; letter-spacing:0.06em; text-transform:uppercase; color:var(--accent-deep); margin-bottom:12px;}
.lead-card p{font-size:13.5px; color:var(--ink-soft); line-height:1.7;}

/* ---- CTA block ---- */
.cta-block{background:var(--accent); color:var(--paper); text-align:center; padding:120px 40px; position:relative; overflow:hidden;}
.cta-block h2{font-size:clamp(38px,5.6vw,72px); margin-bottom:24px; color:var(--paper);}
.cta-block .contact-line{color:var(--sand); font-family:'IBM Plex Mono'; font-size:14px; margin-bottom:6px;}
.cta-block .contact-line a{color:var(--sand); text-decoration:none;}
.cta-block p.desc{color:var(--sand); max-width:480px; margin:0 auto 36px; font-size:15px; line-height:1.7;}
.btn-row{display:flex; gap:16px; justify-content:center; flex-wrap:wrap;}
.btn-dark{
  background:var(--ink); color:var(--paper); border:none; padding:16px 34px;
  font-family:'IBM Plex Mono'; font-size:13px; letter-spacing:0.06em; text-transform:uppercase; cursor:pointer;
  text-decoration:none; display:inline-flex; align-items:center; gap:8px; transition:transform .25s;
}
.btn-dark:hover{transform:translateY(-3px);}
.btn-ghost-dark{
  background:transparent; color:var(--paper); border:1.5px solid rgba(251,249,243,0.45); padding:16px 34px;
  font-family:'IBM Plex Mono'; font-size:13px; letter-spacing:0.06em; text-transform:uppercase; cursor:pointer;
  text-decoration:none; display:inline-flex; align-items:center;
}

/* ---- contact cards ---- */
.contact-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--line); margin-top:20px;}
.contact-card{background:var(--paper); padding:40px 32px;}
.contact-card .ic{width:44px; height:44px; border:1px solid var(--line); border-radius:50%; display:flex; align-items:center; justify-content:center; margin-bottom:20px; color:var(--accent-deep);}
.contact-card h3{font-family:'Barlow Condensed'; text-transform:none; font-size:19px; font-weight:600; margin-bottom:12px;}
.contact-card a, .contact-card p{display:block; color:var(--ink-soft); text-decoration:none; font-size:14px; line-height:1.8;}
.contact-card a:hover{color:var(--accent-deep);}

/* ---- footer ---- */
footer.site-footer{background:var(--paper); border-top:1px solid var(--line); padding:70px 40px 30px;}
.foot-grid{max-width:var(--max); margin:0 auto; display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:50px;}
.foot-grid h5{font-family:'IBM Plex Mono'; font-size:11px; text-transform:uppercase; letter-spacing:0.1em; color:var(--ink-soft); margin-bottom:18px;}
.foot-grid p, .foot-grid a{color:var(--ink); font-size:14px; line-height:1.9; text-decoration:none; display:block; margin:0;}
.foot-grid a:hover{color:var(--accent-deep);}
.foot-grid .static-text{color:var(--ink-soft); cursor:default;}
.foot-bottom{
  max-width:var(--max); margin:0 auto; border-top:1px solid var(--line); padding-top:24px;
  display:flex; justify-content:space-between; font-family:'IBM Plex Mono'; font-size:11px; color:var(--ink-soft);
}

/* ---- modal (shared across pages) ---- */
.modal-overlay{
  position:fixed; inset:0; z-index:100; background:rgba(22,33,47,0.55); backdrop-filter:blur(4px);
  display:flex; align-items:center; justify-content:center; padding:30px;
  opacity:0; pointer-events:none; transition:opacity .3s;
}
.modal-overlay.open{opacity:1; pointer-events:auto;}
.modal-panel{
  background:var(--paper); max-width:760px; width:100%; max-height:84vh; overflow-y:auto;
  border:1px solid var(--line); position:relative; padding:48px 50px 50px;
  transform:translateY(24px) scale(0.98); transition:transform .35s cubic-bezier(.16,1,.3,1);
  box-shadow:0 30px 80px -20px rgba(22,33,47,0.4);
}
.modal-overlay.open .modal-panel{transform:translateY(0) scale(1);}
.modal-close{
  position:absolute; top:22px; right:22px; width:38px; height:38px; border-radius:50%;
  background:var(--paper-2); border:1px solid var(--line); color:var(--ink); font-size:15px; cursor:pointer;
  transition:background .3s;
}
.modal-close:hover{background:var(--accent); color:var(--paper);}
.modal-head{margin-bottom:8px; padding-right:40px;}
.modal-head h2{font-size:clamp(30px,4vw,42px); margin-bottom:8px; text-transform:none; font-weight:700;}
.modal-sub-heading{
  font-family:'IBM Plex Mono'; font-size:11.5px; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--accent-deep); margin:32px 0 16px; padding-top:20px; border-top:1px solid var(--line);
}
.modal-sub-heading:first-of-type{border-top:none; padding-top:0; margin-top:24px;}
.modal-item-row{display:flex; gap:16px; align-items:flex-start; padding:16px 0; border-bottom:1px solid var(--line-soft);}
.modal-item-row:last-child{border-bottom:none;}
.modal-item-dot{width:8px; height:8px; border-radius:50%; background:var(--accent); margin-top:7px; flex-shrink:0;}
.modal-item-name{font-family:'Barlow Condensed'; font-size:19px; font-weight:600; text-transform:none; margin-bottom:4px;}
.modal-item-varieties{font-size:13px; color:var(--ink-soft); line-height:1.6;}

/* ---- email choice popover ---- */
.email-overlay{
  position:fixed; inset:0; z-index:110; background:rgba(22,33,47,0.55); backdrop-filter:blur(4px);
  display:flex; align-items:center; justify-content:center; padding:20px;
  opacity:0; pointer-events:none; transition:opacity .3s;
}
.email-overlay.open{opacity:1; pointer-events:auto;}
.email-panel{
  background:var(--paper); max-width:380px; width:100%; position:relative;
  padding:36px 32px 30px; border:1px solid var(--line);
  transform:translateY(20px) scale(0.97); transition:transform .3s cubic-bezier(.16,1,.3,1);
  box-shadow:0 30px 80px -20px rgba(22,33,47,0.4);
}
.email-overlay.open .email-panel{transform:translateY(0) scale(1);}
.email-panel-head{margin-bottom:22px; padding-right:30px;}
.email-panel-head h3{
  font-family:'Barlow Condensed'; text-transform:none; font-weight:700; font-size:22px; margin-bottom:6px;
}
.email-target{font-family:'IBM Plex Mono'; font-size:12px; color:var(--accent-deep); word-break:break-all;}
.email-options{display:flex; flex-direction:column; gap:8px;}
.email-option{
  display:flex; align-items:center; gap:14px; padding:14px 16px; background:var(--paper-2);
  border:1px solid var(--line); text-decoration:none; color:var(--ink); font-size:14.5px; font-weight:600;
  cursor:pointer; transition:background .25s, border-color .25s; font-family:'Inter', sans-serif;
  width:100%; text-align:left;
}
.email-option:hover{background:var(--accent); color:var(--paper); border-color:var(--accent);}
.email-option:hover .email-ic{background:var(--paper); color:var(--accent);}
.email-ic{
  width:30px; height:30px; border-radius:50%; background:var(--ink); color:var(--paper);
  display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:700; flex-shrink:0;
  transition:background .25s, color .25s;
}
.email-copy-note{
  margin-top:14px; text-align:center; font-family:'IBM Plex Mono'; font-size:11.5px; color:var(--accent-deep);
  opacity:0; transition:opacity .25s;
}
.email-copy-note.show{opacity:1;}

/* ==========================================================
   RESPONSIVE
   ========================================================== */
@media(max-width:900px){
  .contact-grid{grid-template-columns:1fr;}
}

@media(max-width:860px){
  .strip-arrow{display:none;}
  .navlinks{display:none;}
  .btn-cta.desktop-only{display:none;}
  .menu-toggle{display:flex;}
  .mobile-menu{display:flex;}
  .nav-inner{padding:14px 20px;}
  .hero{padding:24px 20px 0;}
  .tag-card{padding:30px 24px 26px; max-width:100%;}
  .hero h1{font-size:clamp(34px,9vw,52px);}
  .page-hero{padding:50px 20px 40px;}
  .section{padding:70px 20px;}
  .section-head{margin-bottom:38px;}
  .manifest-left{padding:60px 20px 50px;}
  .manifest-right{padding:50px 20px 60px;}
  .manifest-grid{grid-template-columns:1fr;}
  .manifest-right{border-left:none; border-top:1px solid var(--line);}
  .cat-grid{grid-template-columns:1fr;}
  .cat-card{height:380px;}
  .ind-row{grid-template-columns:40px 1fr;}
  .ind-row .code{display:none;}
  .ind-grid-cards{grid-template-columns:1fr 1fr;}
  .vm-grid{grid-template-columns:1fr;}
  .vm-card:first-child{border-right:none; border-bottom:1px solid var(--line);}
  .lead-grid{grid-template-columns:1fr; gap:24px;}
  .lead-card{flex-direction:column; text-align:center; align-items:center;}
  .cta-block{padding:80px 24px;}
  .btn-row{flex-direction:column; align-items:stretch;}
  .btn-row a{justify-content:center;}
  footer.site-footer{padding:50px 20px 24px;}
  .foot-grid{grid-template-columns:1fr 1fr; gap:32px 20px; padding-bottom:34px;}
  .foot-bottom{flex-direction:column; gap:8px; text-align:center;}
  .modal-panel{padding:36px 24px 40px; max-height:88vh;}
  .modal-overlay{padding:0;}
}

@media(max-width:560px){
  .hero-cta-row{flex-direction:column; align-items:stretch;}
  .hero-cta-row a{justify-content:center;}
  .hero-meta{display:grid; grid-template-columns:1fr 1fr; gap:20px 16px; flex-wrap:nowrap;}
  .hero-meta div{padding:14px 0 0 0; margin-right:0; border-right:none;}
  .ticker span{padding:0 14px; font-size:11px;}
  .strip-item{min-width:170px; height:220px;}
  .foot-grid{grid-template-columns:1fr;}
  .section-head{flex-direction:column; align-items:flex-start;}
  .section-head p{max-width:100%;}
  .ind-grid-cards{grid-template-columns:1fr;}
}
