:root{
  --bg:#ffffff;
  --text:#121314;
  --muted:#5a6068;
  --line:#e2e8f2;
  --card:#f4f7fb;
  --shadow: 0 1px 0 rgba(60, 90, 140, .04), 0 10px 30px rgba(60, 90, 140, .08);
  --radius:16px;
  --max:1140px;
  --pad: clamp(18px, 3vw, 34px);

  --h1: clamp(34px, 5vw, 56px);
  --h2: clamp(22px, 3vw, 32px);
  --h3: 18px;
  --body: 16px;
  --small: 13.5px;

  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Inter, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--sans);}
a{color:inherit}
p{line-height:1.65;margin:0 0 14px}
.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad);}
.section{padding: clamp(52px, 6vw, 86px) 0;border-top:1px solid var(--line);}
.section:first-of-type{border-top:none}
.kicker{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
h1{font-size:var(--h1);letter-spacing:-.03em;line-height:1.03;margin:12px 0 12px}
h2{font-size:var(--h2);letter-spacing:-.015em;margin:0 0 16px}
h3{font-size:18px;margin:0 0 8px}
ul{margin:0}
.muted{color:var(--muted)}
.small{font-size:var(--small);color:var(--muted)}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 16px;border:1px solid #d7dae1;border-radius:999px;
  text-decoration:none;font-size:14px;background:#fff;
  box-shadow:var(--shadow);
}
.btn:hover{border-color:#c8ccd6}
.header{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);
  backdrop-filter: blur(10px); border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px var(--pad);max-width:var(--max);margin:0 auto;}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand img{height:34px;width:auto}
.nav{display:flex;gap:18px;align-items:center}
.nav a{font-size:14px;text-decoration:none;color:var(--muted)}
.nav a:hover{color:var(--text)}

.hero{
  position:relative;overflow:hidden;
  padding: clamp(58px, 8vw, 120px) 0 54px;
}
.hero::before{
  content:""; position:absolute; inset:0;
  background: radial-gradient(900px 500px at 20% 10%, rgba(0,0,0,.05), rgba(0,0,0,0)),
              radial-gradient(700px 450px at 80% 0%, rgba(0,0,0,.04), rgba(0,0,0,0));
  pointer-events:none;
}
.hero-bg{
  position:absolute; inset:0; pointer-events:none; opacity:.28;
  background-image: url("assets/hero-uinta.jpg");
  background-size: cover;
  background-position: center;
  filter: grayscale(100%) contrast(92%) brightness(1.05);
  display:none;
}
.hero.has-image .hero-bg{display:block; opacity:.22}
.hero-ridge{
  position:absolute; left:0; right:0; top:0;
  height:320px; opacity:.11; pointer-events:none;
  background-image: url("assets/ridge.svg");
  background-repeat:no-repeat;
  background-position: center 28px;
  background-size: 1400px auto;
}
.hero-inner{position:relative}
.hero-grid{display:grid;grid-template-columns: 1.15fr .85fr;gap:34px;align-items:center}
.logo-lockup{display:flex;flex-direction:column;gap:18px}
.logo-lockup img{max-width:360px;width:100%;height:auto}
.meta{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px}
.meta span{font-size:12px;color:var(--muted);border:1px solid var(--line);padding:7px 10px;border-radius:999px;background:#fff}

.panel{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px;
  box-shadow:var(--shadow);
}

/* Hero card buttons: keep them side-by-side when space allows */
.panel-actions{
  margin-top:16px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.panel-actions .btn{
  flex:0 0 auto;
}
.note{font-size:13px;color:var(--muted);max-width:74ch}

.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.stack{display:flex;flex-direction:column;gap:12px}

.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:var(--shadow);
}
.tag{font-size:12px;color:var(--muted);border:1px solid var(--line);padding:6px 10px;border-radius:999px;background:#fff;white-space:nowrap}
.card .title{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}

.divider{
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  background: linear-gradient(180deg, #f2f3f4, #eef0f2);
}
.divider img{width:100%;display:block;height:auto;opacity:.98}

.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px}
.product{
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:#fff;
  box-shadow:var(--shadow);
}
.product img{
  width:100%; display:block; aspect-ratio: 4/3; object-fit:cover;
  filter: grayscale(8%) contrast(98%);
}
.product .img-placeholder{
  aspect-ratio: 4/3;
  background: linear-gradient(180deg, #f3f4f6, #eceff1);
  display:grid; place-items:center;
  font-size:12px; color:var(--muted); letter-spacing:.08em; text-transform:uppercase;
}
.product .body{padding:14px 14px 16px}
.product h3{margin:0 0 6px;font-size:16px}
.product p{margin:0;color:var(--muted);font-size:14px;line-height:1.5}
.product .meta2{margin-top:10px;display:flex;gap:10px;flex-wrap:wrap}

.contact-box{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:18px; border:1px solid var(--line); border-radius:var(--radius); background:#fff;
}
.contact-box a{font-family:var(--mono);text-decoration:none}

.footer{padding:32px 0;color:var(--muted);border-top:1px solid var(--line);}

@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr;gap:18px}
  .grid-2{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:1fr}
  .nav{display:none}
}



/* === V6 VISIBILITY AMPLIFICATION (TEMP) === */
.hero {
  min-height: 520px;
}

.hero-ridge-inline {
  opacity: 0.35;        /* was ~0.11 */
  top: 40px;
}

.hero-ridge-inline svg {
  width: 1600px;        /* larger */
}

.logo-inline svg {
  max-width: 520px;     /* larger hero logo */
}

.brand .logo-inline svg {
  height: 42px;         /* header logo slightly larger */
}

/* === V7: LOGO FIX + CLEAR VISIBILITY === */
.brand img{height:42px;width:auto;display:block}
.hero-logo{max-width:520px;width:100%;height:auto;display:block}

.hero{min-height:520px;}
.hero-ridge-inline{opacity:0.35; top:40px;}
.hero-ridge-inline svg{width:1600px;height:auto;margin-top:28px;display:block;}

/* === V9: PHOTO BAND (replaces ridgeline) === */
.photo-band{
  height: 200px; /* Option B */
  width: 100%;
  background-image:
    linear-gradient(rgba(255,255,255,0.02), rgba(255,255,255,0.02)),
    url('assets/uinta-band.jpg');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border-top: 1px solid rgba(15,17,20,0.08);
  border-bottom: 1px solid rgba(15,17,20,0.10);
}

/* Ensure the hero stays clean/white under the photo band */
.hero{
  background: transparent !important;
  min-height: auto;
}

/* Hide any ridgeline element if present */
.hero-ridge-inline{display:none !important;}

/* === V10: ensure logo has no container background === */
.brand img, .hero-logo { background: transparent !important; box-shadow: none !important; }

/* Portfolio expander behaviour */
.product { cursor: pointer; }
.product:focus { outline: 2px solid rgba(0,0,0,0.12); outline-offset: 4px; }
.product .details-link { background: none; border: none; color: #2b2f36; font-weight: 600; padding: 0; margin-top: 10px; text-decoration: underline; cursor: pointer; }
.product .details-link:hover { opacity: 0.85; }

.portfolio-grid.is-expanded .product:not(.is-active) {
  opacity: 0.35;
  filter: grayscale(25%);
}

.portfolio-grid.is-expanded .product.is-active {
  opacity: 1;
  filter: none;
}

.product-detail {
  margin-top: 18px;
  border: 1px solid rgba(20,30,45,0.10);
  border-radius: 18px;
  background: rgba(220, 232, 246, 0.25);
  padding: 18px 18px 16px;
  box-shadow: 0 16px 40px rgba(0,0,0,0.06);
}

.product-detail-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.product-detail h3 { margin: 0 0 4px 0; font-size: 22px; }
.product-detail .muted { color: #5a6575; margin: 0 0 10px 0; }

.close-button {
  border: 1px solid rgba(20,30,45,0.18);
  background: rgba(255,255,255,0.85);
  border-radius: 999px;
  padding: 8px 12px;
  font-weight: 600;
  cursor: pointer;
}

.close-button:hover { opacity: 0.9; }

.detail-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 18px;
}

.detail-block h4 { margin: 14px 0 8px; font-size: 15px; letter-spacing: 0.06em; text-transform: uppercase; color: #3b4555; }
.detail-block ul { margin: 0; padding-left: 18px; }
.detail-block li { margin: 6px 0; }

@media (max-width: 860px) {
  .detail-grid { grid-template-columns: 1fr; }
}



/* V27 simple portfolio cards + product detail pages */
.product-link-card{
  display:block;
  color:inherit;
  text-decoration:none;
  height:100%;
}
.product-card{
  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.product-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 34px rgba(17,24,39,.08);
  border-color:#d5dce8;
}
.product-thumb{
  width:100%;
  height:260px;
  object-fit:cover;
  display:block;
  background:#fff;
}
.card-cta{
  margin-top:14px;
  font-weight:650;
  color:#26384c;
}
.product-muted .img-placeholder{
  height:260px;
}
.product-detail{
  max-width:1100px;
  margin:0 auto;
  padding:64px 24px 84px;
}
.product-detail .back-link{
  display:inline-block;
  margin-bottom:24px;
  color:#526274;
  text-decoration:none;
  font-weight:600;
}
.product-detail .detail-hero{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:34px;
  align-items:center;
  margin-bottom:42px;
}
.product-detail .detail-hero img{
  width:100%;
  border-radius:18px;
  border:1px solid var(--line, #e5e7eb);
  background:#fff;
  display:block;
}
.product-detail h1{
  margin:0 0 12px;
  font-size:clamp(34px, 4vw, 54px);
  line-height:1.02;
}
.product-detail .lede{
  font-size:clamp(18px, 2vw, 22px);
  color:#56616f;
  line-height:1.55;
}
.detail-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:18px;
  margin-top:24px;
}
.detail-card{
  border:1px solid var(--line, #e5e7eb);
  border-radius:18px;
  padding:24px;
  background:var(--card, #f6f8fb);
}
.detail-card.full{
  grid-column:1 / -1;
}
.detail-card h2{
  font-size:20px;
  margin:0 0 12px;
}
.detail-card p{
  color:#4f5b68;
}
.detail-card ul{
  margin:12px 0 0 20px;
  color:#4f5b68;
  line-height:1.7;
}
.detail-cta{
  margin-top:28px;
}
@media (max-width: 850px){
  .product-detail .detail-hero,
  .detail-grid{ grid-template-columns:1fr; }
}




/* ===== V29 Visual Consistency Pass ===== */

/* Global rhythm */
section{
  scroll-margin-top: 90px;
}

.container{
  max-width: 1180px;
}

/* More breathing room */
.hero{
  padding-top: 120px;
  padding-bottom: 110px;
}

.section{
  padding-top: 88px;
  padding-bottom: 88px;
}

/* Typography rhythm */
h1, h2, h3{
  letter-spacing: -0.02em;
}

p{
  line-height: 1.72;
}

.lead,
.hero p,
.section p{
  max-width: 760px;
}

/* Buttons */
.btn,
.btn-secondary,
.card-cta{
  transition: all .16s ease;
}

.btn:hover,
.btn-secondary:hover{
  transform: translateY(-1px);
}

/* Portfolio cards */
.portfolio-grid{
  gap: 28px;
  align-items: stretch;
}

.product-card{
  overflow: hidden;
  border-radius: 22px;
}

.product-card .body{
  padding: 26px;
  display: flex;
  flex-direction: column;
  min-height: 250px;
}

.product-card h3{
  margin-bottom: 12px;
  line-height: 1.2;
}

.product-card p{
  flex-grow: 1;
}

.product-thumb{
  height: 300px;
  object-fit: cover;
  object-position: center;
  background: #f7f8fa;
}

/* Tags */
.meta2{
  margin-top: 18px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.tag{
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 12px;
  letter-spacing: .02em;
}

/* CTA alignment */
.card-cta{
  margin-top: 22px;
  font-weight: 700;
}

/* Product pages */
.product-detail{
  padding-top: 54px;
}

.product-detail .detail-hero{
  gap: 52px;
  margin-bottom: 54px;
}

.product-detail .detail-hero img{
  border-radius: 22px;
}

.detail-card{
  padding: 30px;
  border-radius: 22px;
}

.detail-card p,
.detail-card li{
  line-height: 1.75;
}

/* Back link polish */
.back-link{
  opacity: .82;
  transition: opacity .15s ease;
}

.back-link:hover{
  opacity: 1;
}

/* Footer */
.footer{
  padding-top: 34px;
  padding-bottom: 34px;
}

/* Mobile refinement */
@media (max-width: 768px){

  .hero{
    padding-top: 92px;
    padding-bottom: 82px;
  }

  .section{
    padding-top: 68px;
    padding-bottom: 68px;
  }

  .portfolio-grid{
    gap: 22px;
  }

  .product-thumb{
    height: 240px;
  }

  .product-card .body{
    min-height: auto;
  }

  .product-detail .detail-hero{
    gap: 30px;
  }
}




/* ===== V30 Nav + Mountain Band Polish ===== */

/* Slightly stronger top navigation */
.nav a{
  font-size: 16.5px;
  font-weight: 600;
  color: #2f3946;
  letter-spacing: -0.005em;
}

.nav a:hover{
  color: #111827;
}

/* Header contact button gets a touch more presence */
.header .btn,
.header-inner .btn{
  font-weight: 600;
  color: #111827;
}

/* Give the mountain band a little more presence without turning it into a full hero */
.photo-band{
  height: 240px;
  background-position: center 45%;
}

/* If a prior build uses hero-band or mountain-band naming, support those too */
.hero-band,
.mountain-band{
  height: 240px;
  background-position: center 45%;
}

/* Tighten the transition from image band to main content slightly */
.photo-band + .hero,
.hero-band + .hero,
.mountain-band + .hero{
  padding-top: 96px;
}

/* Mobile: keep mountain band proportional */
@media (max-width: 768px){
  .photo-band,
  .hero-band,
  .mountain-band{
    height: 190px;
  }

  .nav a{
    font-size: 15.5px;
    font-weight: 600;
  }
}




/* ===== V31 Positioning Card Refinement ===== */

/* Keep the POSITIONING label, but make it feel more intentional */
.kicker,
.eyebrow,
.positioning .kicker,
.positioning .eyebrow,
.panel .kicker,
.panel .eyebrow{
  color: #4c5663;
  letter-spacing: 0.11em;
  font-weight: 650;
}

/* Give the primary positioning card slightly more definition */
.panel,
.positioning,
.sky-card{
  border-color: #d6dfeb !important;
  box-shadow: 0 14px 36px rgba(38, 56, 76, 0.075);
}

/* If the card border is defined directly, strengthen without making it heavy */
.panel{
  border-width: 1.25px;
}

/* Keep the refinement subtle on mobile */
@media (max-width: 768px){
  .panel,
  .positioning,
  .sky-card{
    box-shadow: 0 10px 26px rgba(38, 56, 76, 0.065);
  }
}




/* ===== V32 Final Desktop Micro-Polish ===== */

/* Slightly more intentional overall content rhythm */
.section{
  padding-top: 94px;
  padding-bottom: 94px;
}

/* Refine hero spacing balance */
.hero{
  padding-top: 104px;
  padding-bottom: 92px;
}

/* Better paragraph rhythm */
p{
  line-height: 1.78;
}

/* Product grid alignment */
.portfolio-grid{
  align-items: stretch;
}

/* Product card refinement */
.product-card{
  transition: transform .18s ease, box-shadow .18s ease;
}

.product-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 40px rgba(26, 40, 56, 0.08);
}

/* More intentional image treatment */
.product-thumb{
  background: #f3f5f8;
  border-bottom: 1px solid #edf1f5;
}

/* Tighten text rhythm inside cards */
.product-card h3{
  margin-top: 2px;
  margin-bottom: 10px;
}

.product-card p{
  margin-bottom: 18px;
}

/* Refine CTA feel */
.card-cta{
  opacity: .92;
  transition: opacity .16s ease;
}

.product-card:hover .card-cta{
  opacity: 1;
}

/* Product detail pages */
.detail-card ul{
  padding-left: 22px;
}

.detail-card li{
  margin-bottom: 10px;
}

/* Footer refinement */
.footer{
  border-top: 1px solid #edf1f5;
  opacity: .92;
}

/* Slightly cleaner button consistency */
.btn,
.btn-secondary{
  min-height: 52px;
}

/* Mobile restraint */
@media (max-width: 768px){

  .section{
    padding-top: 72px;
    padding-bottom: 72px;
  }

  .hero{
    padding-top: 82px;
    padding-bottom: 72px;
  }

  .product-card:hover{
    transform: none;
  }
}




/* ===== V33 Mobile Optimization Pass ===== */
/* Mobile-only changes. Desktop remains unchanged. */

@media (max-width: 768px){

  /* Header: keep mobile simple and intentional */
  .header,
  header{
    min-height: 92px;
  }

  .header-inner{
    padding: 18px 28px;
    min-height: 92px;
  }

  .brand img,
  .logo-small{
    max-width: 58px;
    height: auto;
  }

  /* Hide desktop nav links on mobile, keep logo + Contact */
  .nav{
    display: none !important;
  }

  .header .btn,
  .header-inner .btn{
    min-height: 52px;
    padding: 0 28px;
    font-size: 18px;
    border-radius: 999px;
  }

  /* Mountain band: reduce height on mobile */
  .photo-band,
  .hero-band,
  .mountain-band{
    height: 155px !important;
    background-position: center center;
  }

  /* Hero: compress vertical space */
  .hero{
    padding-top: 54px !important;
    padding-bottom: 56px !important;
  }

  .hero-logo,
  .hero .logo,
  .hero img.logo{
    max-width: 210px;
    margin-bottom: 32px;
  }

  .hero h1{
    font-size: clamp(42px, 12vw, 56px);
    line-height: 1.04;
    letter-spacing: -0.045em;
    margin-bottom: 22px;
  }

  .hero p,
  .hero .subhead{
    font-size: 22px;
    line-height: 1.55;
    margin-bottom: 26px;
  }

  .hero .pills,
  .pills{
    gap: 10px;
    margin-top: 24px;
  }

  .pill,
  .tag{
    font-size: 15px;
    padding: 8px 13px;
  }

  /* Positioning card mobile compression */
  .panel,
  .positioning,
  .sky-card{
    padding: 42px 36px !important;
    border-radius: 22px;
  }

  .panel h2,
  .positioning h2,
  .sky-card h2{
    font-size: clamp(36px, 10vw, 46px);
    line-height: 1.12;
    margin-bottom: 26px;
  }

  .panel p,
  .positioning p,
  .sky-card p{
    font-size: 20px;
    line-height: 1.62;
  }

  .cta-row,
  .button-row,
  .actions{
    display: flex;
    flex-direction: column;
    gap: 14px;
    align-items: flex-start;
  }

  .cta-row .btn,
  .button-row .btn,
  .actions .btn,
  .cta-row .btn-secondary,
  .button-row .btn-secondary,
  .actions .btn-secondary{
    min-height: 54px;
    padding: 0 28px;
    font-size: 18px;
  }

  /* Section rhythm: less vertical fatigue */
  .section{
    padding-top: 58px !important;
    padding-bottom: 58px !important;
  }

  section{
    scroll-margin-top: 94px;
  }

  .section h2,
  main h2{
    font-size: clamp(34px, 9vw, 42px);
    line-height: 1.12;
    margin-bottom: 22px;
  }

  .section p,
  main p{
    font-size: 20px;
    line-height: 1.62;
  }

  /* Content cards */
  .info-card,
  .principle-card,
  .service-card,
  .what-card{
    padding: 32px !important;
    border-radius: 22px;
  }

  .info-card h3,
  .principle-card h3,
  .service-card h3,
  .what-card h3{
    font-size: 26px;
    line-height: 1.18;
  }

  .info-card p,
  .principle-card p,
  .service-card p,
  .what-card p,
  .info-card li,
  .principle-card li,
  .service-card li,
  .what-card li{
    font-size: 19px;
    line-height: 1.58;
  }

  /* Portfolio intro */
  #portfolio h2,
  .portfolio h2{
    font-size: clamp(36px, 10vw, 46px);
    line-height: 1.12;
  }

  #portfolio .section-intro,
  .portfolio .section-intro{
    font-size: 20px;
    line-height: 1.62;
    margin-bottom: 30px;
  }

  /* Product cards: shorter images, tighter cards */
  .portfolio-grid{
    gap: 24px;
  }

  .product-thumb{
    height: 205px !important;
    object-fit: cover;
    object-position: center;
  }

  .product-card{
    border-radius: 22px;
  }

  .product-card .body{
    padding: 28px !important;
    min-height: auto !important;
  }

  .product-card h3{
    font-size: 25px;
    line-height: 1.18;
    margin-bottom: 12px;
  }

  .product-card p{
    font-size: 19px;
    line-height: 1.55;
    margin-bottom: 18px;
  }

  .meta2{
    gap: 9px;
    margin-top: 14px;
  }

  .card-cta{
    margin-top: 18px;
    font-size: 20px;
  }

  /* Product detail pages */
  .product-detail{
    padding: 38px 28px 64px !important;
  }

  .product-detail .back-link{
    font-size: 16px;
    margin-bottom: 20px;
  }

  .product-detail .detail-hero{
    gap: 28px;
    margin-bottom: 34px;
  }

  .product-detail h1{
    font-size: clamp(36px, 11vw, 48px);
    line-height: 1.05;
  }

  .product-detail .lede{
    font-size: 20px;
    line-height: 1.56;
  }

  .product-detail .detail-hero img{
    max-height: 260px;
    object-fit: cover;
  }

  .detail-card{
    padding: 28px !important;
    border-radius: 22px;
  }

  .detail-card h2{
    font-size: 24px;
  }

  .detail-card p,
  .detail-card li{
    font-size: 18.5px;
    line-height: 1.62;
  }

  .detail-card li{
    margin-bottom: 8px;
  }

  /* Footer */
  .footer{
    padding: 28px 24px;
  }
}

@media (max-width: 420px){

  .header-inner{
    padding-left: 24px;
    padding-right: 24px;
  }

  .header .btn,
  .header-inner .btn{
    font-size: 17px;
    padding: 0 24px;
  }

  .hero{
    padding-top: 46px !important;
  }

  .hero h1{
    font-size: clamp(38px, 12vw, 50px);
  }

  .panel,
  .positioning,
  .sky-card{
    padding: 36px 28px !important;
  }

  .product-thumb{
    height: 190px !important;
  }

  .product-card .body{
    padding: 24px !important;
  }
}




/* ===== V34 Mobile Products Navigation + Hero Compression ===== */
/* Mobile-only refinements. Desktop remains unchanged. */

/* Hide mobile Products button on desktop */
.mobile-products-btn{
  display: none;
}

@media (max-width: 768px){

  /* Mobile header layout: logo left, Products + Contact right */
  .header-inner{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 16px 24px !important;
    min-height: 86px !important;
  }

  .brand{
    flex: 0 0 auto;
  }

  .brand img,
  .logo-small{
    max-width: 54px !important;
    height: auto;
  }

  .nav{
    display: none !important;
  }

  .mobile-products-btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 18px;
    border: 1px solid #d7dee9;
    border-radius: 999px;
    background: #fff;
    color: #111827;
    text-decoration: none;
    font-size: 16px;
    font-weight: 650;
    letter-spacing: -0.01em;
    box-shadow: 0 8px 20px rgba(17,24,39,.055);
    margin-left: auto;
  }

  .header .btn,
  .header-inner .btn{
    min-height: 48px !important;
    padding: 0 20px !important;
    font-size: 16px !important;
    font-weight: 650;
    white-space: nowrap;
    margin-left: 0;
  }

  /* Mountain band: slightly shorter for faster mobile momentum */
  .photo-band,
  .hero-band,
  .mountain-band{
    height: 138px !important;
    background-position: center center !important;
  }

  /* Hero compression: reduce dead space and large centered logo */
  .hero{
    padding-top: 32px !important;
    padding-bottom: 42px !important;
  }

  .hero-logo,
  .hero .logo,
  .hero img.logo{
    max-width: 150px !important;
    margin-bottom: 24px !important;
  }

  /* If the large logo is displayed through a non-logo class/image, cap hero images softly */
  .hero > img{
    max-width: 155px;
  }

  .hero h1{
    margin-top: 0;
    margin-bottom: 18px !important;
  }

  .hero p,
  .hero .subhead{
    margin-bottom: 20px !important;
  }

  /* Bring the positioning card closer after the hero */
  .hero + .section,
  .hero + section{
    padding-top: 46px !important;
  }

  /* Keep cards from feeling overly tall on mobile */
  .panel,
  .positioning,
  .sky-card{
    padding-top: 32px !important;
    padding-bottom: 34px !important;
  }
}

@media (max-width: 420px){

  .header-inner{
    padding-left: 22px !important;
    padding-right: 22px !important;
    gap: 9px;
  }

  .brand img,
  .logo-small{
    max-width: 50px !important;
  }

  .mobile-products-btn{
    min-height: 46px;
    padding: 0 15px;
    font-size: 15.5px;
  }

  .header .btn,
  .header-inner .btn{
    min-height: 46px !important;
    padding: 0 17px !important;
    font-size: 15.5px !important;
  }

  .photo-band,
  .hero-band,
  .mountain-band{
    height: 132px !important;
  }

  .hero{
    padding-top: 28px !important;
    padding-bottom: 38px !important;
  }

  .hero-logo,
  .hero .logo,
  .hero img.logo,
  .hero > img{
    max-width: 138px !important;
  }
}
