/* ============================================================
   REDWOOD GLOBAL SUPPLY — single-file production stylesheet
   ============================================================ */

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;
  font-size:16px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit;padding:0}
img,svg{display:block;max-width:100%}

:root{
  --bg:#0F0E0C;
  --bg-2:#08070500;
  --line:#1F1D18;
  --line-2:#2C2A24;
  --text:#E8E5DC;
  --text-2:#8A8576;
  --text-3:#5F5C53;
  --accent:#C68B3E;
  --accent-2:#5DCAA5;
  --accent-3:#E24B4A;
  --marquee-bg:#000;
  --nav-bg:rgba(15,14,12,.92);
  --hover:#15130F;
  --mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  --max-w:1280px;
  --pad:32px;
}

html[data-theme="light"]{
  --bg:#F2EEE3;
  --line:#D9D3C2;
  --text:#1A1815;
  --text-2:#5F5C53;
  --text-3:#8A8576;
  --accent:#9A6420;
  --accent-2:#0F6E56;
  --accent-3:#A32D2D;
  --marquee-bg:#F2EEE3;
  --nav-bg:rgba(242,238,227,.92);
  --hover:#EAE4D6;
}

/* Layout primitives */
.wrap{max-width:var(--max-w);margin:0 auto}
.row{padding:0 var(--pad)}
.section{border-bottom:1px solid var(--line)}

/* ============================================================
   MARQUEE (top ticker)
   ============================================================ */
.marquee{
  background:var(--marquee-bg);
  border-bottom:1px solid var(--line);
  padding:10px 0;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.12em;
  color:var(--text-2);
  overflow:hidden;
  white-space:nowrap;
}
.marquee-track{
  display:inline-flex;
  gap:48px;
  animation:rwd-marquee 50s linear infinite;
  will-change:transform;
}
.marquee-track > span{flex-shrink:0}
@keyframes rwd-marquee{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.dot-orange{color:var(--accent)}
.sep{color:var(--text-3)}
.t-light{color:var(--text)}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  padding:18px var(--pad);
  display:flex;
  justify-content:space-between;
  align-items:center;
  border-bottom:1px solid var(--line);
  position:sticky;
  top:0;
  z-index:50;
  background:var(--nav-bg);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.15em;
}
.brand-mark{
  width:20px;
  height:20px;
  display:block;
}
.brand-name{color:var(--text)}
.brand-tag{color:var(--text-3)}
.nav-links{
  display:flex;
  gap:28px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.12em;
  color:var(--text-2);
}
.nav-links a{transition:color .15s ease}
.nav-links a:hover{color:var(--accent)}
.nav-toggle{display:none}
.theme-toggle{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.12em;
  color:var(--text-2);
  border:1px solid var(--line-2);
  padding:10px 14px;
  transition:all .15s ease;
}
.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}

/* ============================================================
   HERO
   ============================================================ */
.hero{padding:64px var(--pad) 48px}
.hero-eyebrow{
  font-family:var(--mono);
  font-size:11px;
  color:var(--text-3);
  letter-spacing:.2em;
  margin-bottom:24px;
}
.hero-title{
  font-size:clamp(44px,9vw,112px);
  font-weight:500;
  line-height:.92;
  letter-spacing:-.04em;
  color:var(--text);
  margin:0;
}
.hero-title .accent{color:var(--accent)}
.hero-bottom{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  margin-top:32px;
  gap:32px;
  flex-wrap:wrap;
}
.hero-lede{
  max-width:420px;
  font-size:15px;
  color:var(--text-2);
  line-height:1.6;
  margin:0;
}
.hero-cta{
  display:flex;
  gap:12px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.12em;
  flex-shrink:0;
}
.btn{
  border:1px solid var(--line-2);
  color:var(--text-2);
  padding:14px 22px;
  transition:all .15s ease;
  display:inline-block;
}
.btn:hover{border-color:var(--accent);color:var(--accent)}
.btn-primary{
  border-color:var(--accent);
  color:var(--accent);
}
.btn-primary:hover{background:var(--accent);color:var(--bg)}

/* ============================================================
   SECTION HEAD
   ============================================================ */
.sec-head{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  margin-bottom:24px;
  flex-wrap:wrap;
  gap:8px;
}
.sec-num{
  font-family:var(--mono);
  font-size:10px;
  color:var(--text-3);
  letter-spacing:.2em;
}

/* ============================================================
   GEOGRAPHY
   ============================================================ */
.geo-block{padding:48px var(--pad)}
.geo-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
}
.geo-cell{
  background:var(--bg);
  padding:20px 16px;
  transition:background .2s ease;
}
.geo-cell:hover{background:var(--hover)}
.geo-cell-tag{
  font-family:var(--mono);
  font-size:10px;
  color:var(--accent);
  letter-spacing:.15em;
}
.geo-cell-name{
  font-size:16px;
  color:var(--text);
  margin-top:8px;
}
.geo-cell-ports{
  font-size:10px;
  color:var(--text-3);
  font-family:var(--mono);
  margin-top:4px;
}

/* ============================================================
   LIVE COUNTER
   ============================================================ */
.counter{
  margin-top:24px;
  padding:32px;
  border:1px solid var(--line-2);
  position:relative;
}
.counter-live{
  position:absolute;
  top:14px;right:18px;
  display:flex;
  align-items:center;
  gap:6px;
  font-family:var(--mono);
  font-size:10px;
  color:var(--accent-2);
  letter-spacing:.15em;
}
.counter-live .pulse{
  display:inline-block;
  width:6px;height:6px;
  background:var(--accent-2);
  border-radius:50%;
  animation:rwd-pulse 1.5s ease-in-out infinite;
}
@keyframes rwd-pulse{
  0%,100%{opacity:1}
  50%{opacity:.3}
}
.counter-label{
  font-family:var(--mono);
  font-size:10px;
  color:var(--text-3);
  letter-spacing:.2em;
}
.counter-value{
  font-family:var(--mono);
  font-size:clamp(32px,6vw,64px);
  font-weight:500;
  color:var(--text);
  letter-spacing:-.02em;
  margin-top:8px;
  line-height:1;
  font-variant-numeric:tabular-nums;
  font-feature-settings:"tnum";
}
.counter-foot{
  margin-top:14px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-family:var(--mono);
  font-size:11px;
  color:var(--text-2);
  flex-wrap:wrap;
  gap:8px;
}
.counter-foot .accent{color:var(--accent)}
.counter-foot .muted{color:var(--text-3)}

/* ============================================================
   CONTENT PAGES
   ============================================================ */
.content-page{
  padding:56px var(--pad);
  border-bottom:1px solid var(--line);
}
.content-wrap{
  max-width:960px;
  margin:0 auto;
}
.content-eyebrow{
  font-family:var(--mono);
  font-size:11px;
  color:var(--text-3);
  letter-spacing:.18em;
  margin-bottom:18px;
}
.content-title{
  margin:0 0 24px;
  font-size:clamp(32px,6vw,52px);
  letter-spacing:-.02em;
  line-height:1.05;
}
.content-block{
  margin:0 0 24px;
  padding:22px;
  border:1px solid var(--line);
  background:#11100D;
}
.content-block h2{
  margin:0 0 10px;
  font-size:22px;
  font-weight:500;
}
.content-block p{
  margin:0 0 12px;
  color:var(--text-2);
  line-height:1.7;
}
.content-block p:last-child{margin-bottom:0}
.content-cta{
  margin-top:30px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

/* ============================================================
   ABOUT + STATS
   ============================================================ */
.about-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
}
.about-left{
  padding:48px var(--pad);
  border-right:1px solid var(--line);
}
.about-right{
  padding:48px var(--pad);
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  font-family:var(--mono);
}
.about-title{
  font-size:clamp(20px,2.4vw,26px);
  font-weight:500;
  line-height:1.3;
  color:var(--text);
  margin:0;
}
.stat-num{
  font-size:32px;
  color:var(--accent);
  font-weight:500;
  line-height:1;
}
.stat-lab{
  font-size:10px;
  color:var(--text-3);
  letter-spacing:.15em;
  margin-top:6px;
}

/* ============================================================
   PRODUCTS
   ============================================================ */
.products{padding:48px var(--pad)}
.products-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
}
.product{
  background:var(--bg);
  padding:28px;
  transition:background .2s ease;
}
.product:hover{background:var(--hover)}
.product-tag{
  font-family:var(--mono);
  font-size:11px;
  color:var(--accent);
}
.product-name{
  font-size:22px;
  margin:14px 0 8px;
  color:var(--text);
  font-weight:500;
}
.product-desc{
  font-size:13px;
  color:var(--text-2);
  line-height:1.6;
  margin:0;
}

/* ============================================================
   LEGAL
   ============================================================ */
.legal{padding:48px var(--pad)}
.legal-table{
  font-family:var(--mono);
  font-size:13px;
  color:var(--text-2);
  line-height:1.9;
}
.legal-row{
  display:grid;
  grid-template-columns:200px 1fr;
  border-bottom:1px dashed var(--line);
  padding:8px 0;
  gap:16px;
}
.legal-row:last-child{border-bottom:0}
.legal-key{color:var(--text-3)}
.legal-val{color:var(--text);word-break:break-all}
.legal-val.accent{color:var(--accent)}
.legal-val.ok{color:var(--accent-2)}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{padding:64px var(--pad)}
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
}
.contact-h{
  font-size:clamp(28px,4.5vw,52px);
  font-weight:500;
  line-height:1;
  color:var(--text);
  letter-spacing:-.02em;
  margin:0 0 16px;
}
.contact-sub{
  font-size:14px;
  color:var(--text-2);
  line-height:1.6;
  max-width:420px;
}
.form{
  display:flex;
  flex-direction:column;
  gap:14px;
  font-family:var(--mono);
}
.form label{
  font-size:10px;
  color:var(--text-3);
  letter-spacing:.2em;
  margin-bottom:4px;
  display:block;
}
.form input,
.form select,
.form textarea{
  width:100%;
  background:transparent;
  border:0;
  border-bottom:1px solid var(--line-2);
  color:var(--text);
  padding:10px 0;
  font-family:var(--mono);
  font-size:13px;
  transition:border-color .15s ease;
  outline:none;
  border-radius:0;
}
.form input:focus,
.form select:focus,
.form textarea:focus{border-bottom-color:var(--accent)}
.form textarea{resize:vertical;min-height:80px}
.form select{
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%238A8576' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 4px center;
  padding-right:24px;
}
.form select option{background:var(--bg);color:var(--text)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.form-submit{
  margin-top:8px;
  align-self:flex-start;
  border:1px solid var(--accent);
  color:var(--accent);
  padding:14px 28px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.15em;
  transition:all .15s ease;
  background:none;
}
.form-submit:hover{background:var(--accent);color:var(--bg)}
.form-status{
  font-size:11px;
  color:var(--accent-2);
  letter-spacing:.1em;
  margin-top:4px;
  min-height:14px;
}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{padding:40px var(--pad);display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
.foot-info{
  font-family:var(--mono);
  font-size:12px;
  color:var(--text-2);
  line-height:1.9;
}
.foot-mail{color:var(--accent);transition:opacity .15s ease}
.foot-mail:hover{opacity:.7}
.foot-addr{margin-top:14px;color:var(--text-3)}
.foot-bottom{
  border-top:1px solid var(--line);
  padding:18px var(--pad);
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-family:var(--mono);
  font-size:10px;
  color:var(--text-3);
  letter-spacing:.15em;
  flex-wrap:wrap;
  gap:8px;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px){
  :root{--pad:20px}
  .nav-links{display:none}
  .nav-toggle{
    display:flex;
    flex-direction:column;
    gap:4px;
    padding:6px;
  }
  .nav-toggle span{
    width:22px;height:1.5px;background:var(--text);transition:transform .2s ease;
  }
  .nav.open .nav-links{
    display:flex;
    position:absolute;
    top:100%;left:0;right:0;
    flex-direction:column;
    background:var(--bg);
    border-bottom:1px solid var(--line);
    padding:20px var(--pad);
    gap:16px;
  }
  .geo-grid{grid-template-columns:repeat(3,1fr)}
  .products-grid{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .about-left{border-right:0;border-bottom:1px solid var(--line)}
  .about-right{grid-template-columns:1fr 1fr;gap:20px}
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .foot{grid-template-columns:1fr;gap:24px}
  .legal-row{grid-template-columns:130px 1fr;gap:12px;font-size:12px}
  .form-row{grid-template-columns:1fr;gap:14px}
  .hero-bottom{flex-direction:column;align-items:flex-start;gap:24px}
  .hero-cta{width:100%}
  .btn{flex:1;text-align:center}
  .counter{padding:20px}
  .counter-live{position:static;margin-bottom:8px}
}
@media (max-width:480px){
  .geo-grid{grid-template-columns:repeat(2,1fr)}
  .legal-row{grid-template-columns:1fr;gap:2px;padding:10px 0}
  .legal-key{font-size:10px;letter-spacing:.1em}
  .marquee{font-size:10px}
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  .marquee-track{animation:none}
  .counter-live .pulse{animation:none}
  *{transition:none !important}
}

/* Print */
@media print{
  body{background:#fff;color:#000}
  .marquee,.nav,.hero-cta,.form{display:none}
  *{color:#000 !important;background:#fff !important;border-color:#999 !important}
}
