@font-face {
  font-family: 'BabelStoneModern';
  src: url('../fonts/BabelStoneModern.ttf') format('truetype');
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}


/* (Load Roboto Mono in HTML, e.g. <link href="https://fonts.googleapis.com/css2?family=Roboto+Mono:wght@400;700&display=swap" rel="stylesheet">) */

/* ======= Reset ======= */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html,
body {
    height: 100%;
}

html {
    font-size: 16px;
    /* 1rem = 16px */
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}


body {
    font-family: 'BabelStoneModern', sans-serif;
    background: var(--clr-bg-app);
    color: var(--clr-secondary-light);
    margin: 0;
    padding: 0 2rem 2rem;
    /* top 0, sides 2rem, bottom 2rem */
    background-image: url('https://rampnerd.s3.us-east-1.amazonaws.com/productimg/rampnerd_bglogo.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-attachment: fixed;
    background-size: contain;
}

/* ======= Tokens ======= */
:root {
    /* Colors (as provided) */
    --clr-bg-body: #151515;
    --clr-text: #f4f4f4;
    --clr-primary: #b58335;
    --clr-primary-dark: #1f1f1f;
    --clr-secondary-dark: #414141;
    --clr-mid-dark: #8e8e8e;
    --clr-primary-light: #f4f4f4;
    --clr-secondary-light: #dfdfdf;
    --clr-inactivep-light: #737373;
    --clr-accent: #d69134;
    --clr-nav-bg: #222;
    --clr-nav-text: #eaeaea;
    --clr-dc-text: #5a3f00;
        --clr-legal: #00eeff;

    /* App */
    --clr-bg-app: #2a2a2a;
    --glass-50: rgba(42, 42, 42, 0.5);
    --glass-70: rgba(37, 36, 34, 0.80);
    --slider-track: rgba(83, 83, 83, 0.9);
    --shadow-35: rgba(0, 0, 0, 0.55);

    /* Categories */
    --clr-catcolor-Surface: #55F978;
    --clr-catcolor-screws: #B3DDDC;
    --clr-catcolor-coping: #A75CFF;
    --clr-catcolor-finish: #3EA3FF;
    --clr-catcolor-foundation: #7c7c7c;
    --clr-catcolor-structure: #d74f22;
    --clr-catcolor-generic: #d2d2d28b;

    /* Typography */
    --font-heading: 'BabelStoneModern', sans-serif;
    /* headings / UI */
    --font-body: 'Roboto Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
    /* body */

    --fs-body: .8rem;
    --lh-body: 1.85;
    --fs-small: .65rem;

    --fw-regular: 400;
    --fw-bold: 700;

    --ls-uc: .12em;
    /* uppercase headings */
    --ls-uc-tight: .08em;
    /* tighter variant */

    /* Layout */
    --radius: .5rem;
    --gutter-header: 1.5rem;
    --gutter-content: 4rem;
    --max-width: 960px;
    --section-space: 10rem;
    --header-height: 82px;

    --nav-gap: 32px;
    /* space between nav and text */
    --nav-top-offset: 24px;
    /* more space on top; tweak if needed */
    --card-left: 0px;
    /* set by JS below */
    --nav-w-actual: 360px;
    /* set by JS below */
}

.midspacer { height: 2.5rem;}

.bigspacer { height: 5.5rem;}

.megaspacer { height: 35.5rem;}

/* ======= Optional brand background (toggle with .has-bg-logo on body) ======= */
body.has-bg-logo {
    background-image: url('https://rampnerd.s3.us-east-1.amazonaws.com/productimg/rampnerd_bglogo.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-attachment: fixed;
    background-size: contain;
}

/* ======= Typography ======= */
h1,
.heading,
.label,
.nav,
.menu-title {
    font-family: var(--font-heading);
    text-transform: uppercase;
    letter-spacing: var(--ls-uc);
    color: var(--clr-primary-light);
    margin: 0 0 .6rem 0;
}

h2 {
    font-family: var(--font-heading);
    text-transform: uppercase;
    letter-spacing: var(--ls-uc);
    color: var(--clr-primary-light);
    margin: 0 0 .6rem 0;
    padding: 2rem 0rem 0.5rem;
    /* bottom padding for row 2 */

}

h3,
h4,
h5,
h6,
.heading,
.label,
.nav,
.menu-title {
    font-family: var(--font-heading);
    text-transform: uppercase;
    letter-spacing: var(--ls-uc);
    color: var(--clr-secondary-light);
    margin: 0 0 .6rem 0;
}

h1 {
    font-size: 2rem;
}

h2 {
    font-size: 1.0rem;
}

h3 {
    font-size: 1.0rem;
}

h4 {
    font-size: .9rem;
}

h5 {
    font-size: .8rem;
}

h6 {
    font-size: .8rem;
    letter-spacing: var(--ls-uc-tight);
}

p,
li,
dd,
dt,
small,
code,
pre {
    font-family: var(--font-body);
    font-size: var(--fs-body);
    line-height: var(--lh-body);
    letter-spacing: 0;
}






small,
.text-small {
    font-size: var(--fs-small);
}

/* Utilities */
.text-body {
    font-family: var(--font-body);
    font-size: var(--fs-body);
    line-height: var(--lh-body);
}

.text-body--bold {
    font-family: var(--font-body);
    font-size: var(--fs-body);
    line-height: var(--lh-body);
    font-weight: var(--fw-bold);
}

.text-small--bold {
    font-family: var(--font-body);
    font-size: var(--fs-small);
    line-height: var(--lh-body);
    font-weight: var(--fw-bold);
}

.text-heading-uc {
    font-family: var(--font-heading);
    text-transform: uppercase;
    letter-spacing: var(--ls-uc);
}

.text-heading-uc-tight {
    font-family: var(--font-heading);
    text-transform: uppercase;
    letter-spacing: var(--ls-uc-tight);
}

/* Links */
a {
    color: var(--clr-primary-light);
    text-decoration: underline;
}

.nav a,
.legal-nav a {
  text-decoration: none;
}

a:hover {
    text-decoration: none;
}




/* ======= Layout ======= */
.container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 1.25rem;
}

.section {
    padding: 2rem 0;
}

.section--tight {
    padding: 1rem 0;
}

.grid {
    display: grid;
    gap: 1rem;
}

.grid-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 860px) {

    .grid-2,
    .grid-3 {
        grid-template-columns: 1fr;
    }
}

/* Cards / Surfaces */
.card,
.panel,
.shared-container,
.par-container {
    background: var(--glass-70);
    border-radius: 12px;
    box-shadow: 0 12px 60px var(--shadow-35);
    overflow: hidden;
}

.card {
    padding: 1rem 1.25rem;
}

.shared-container,
.par-container {
    max-width: var(--max-width);
    margin: 0 auto 2rem;
}

/* AppBar / Header Bar */
.appbar {
    max-width: var(--max-width);
    margin: 0 auto 1rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: .75rem 1rem;
    background: var(--glass-70);
    border-radius: 12px;
    box-shadow: 0 8px 28px var(--shadow-35);
}

.appbar .spacer {
    margin-left: auto;
}

/* ======= Buttons ======= */
.btn,
.actions .act {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .6rem;
    min-width: 9.3rem;
    height: 2.8rem;
    padding: 0 1rem;
    border: 0;
    border-radius: .5rem;
    cursor: pointer;
    font-family: var(--font-heading);
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: var(--ls-uc);
    background: var(--glass-70);
    color: var(--clr-primary-light);
    box-shadow: 0 4px 12px var(--shadow-35);
    transition: background .4s ease, transform .4s ease, box-shadow .4s ease;
    -webkit-backdrop-filter: blur(4px) saturate(120%);
    backdrop-filter: blur(4px) saturate(100%);
}

.btn:hover,
.actions .act:hover {
    transform: scale(1.1);
    box-shadow: 0 8px 24px var(--shadow-35);
}

.btn--primary {
    background: var(--clr-catcolor-coping);
    color: var(--clr-mid-dark);
}

.btn--ghost {
    background: var(--glass-70);
    color: var(--clr-primary-light);
}

.btn--active {
    background: var(--clr-nav-bg);
    color: var(--clr-accent);
    box-shadow: 0 8px 24px var(--shadow-35);
}

.icon-btn,
.share-button,
.print-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.8rem;
    height: 2.8rem;
    border-radius: 30%;
    border: none;
    cursor: pointer;
    background: var(--glass-70);
    color: var(--clr-primary-light);
    box-shadow: 0 4px 12px var(--shadow-35);
    transition: background .4s ease, transform .4s ease, box-shadow .4s ease;
    -webkit-backdrop-filter: blur(4px) saturate(120%);
    backdrop-filter: blur(4px) saturate(100%);
}

.icon-btn:hover,
.share-button:hover,
.print-button:hover {
    transform: scale(1.1);
    box-shadow: 0 8px 24px var(--shadow-35);
}

.icon-btn img,
.share-button img,
.print-button img {
    width: 1.2rem;
    height: 1.2rem;
    display: block;
    filter: brightness(0) invert(1);
}

/* Download actions vertical stack (alias) */
.dl-actions {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.25rem;
}

/* ======= Category Header ======= */
.category-header {
    --cat-color: var(--clr-catcolor-generic);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 2.5rem;
    background: var(--cat-color);
    color: var(--clr-bg-body);
    font-family: var(--font-heading);
    font-size: 1.5rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

/* Category color hooks (reused globally) */
.Surface {
    --cat-color: var(--clr-catcolor-Surface);
}

.frame-platform {
    --cat-color: var(--clr-catcolor-structure);
}

.screws {
    --cat-color: var(--clr-catcolor-screws);
}

.finish {
    --cat-color: var(--clr-catcolor-finish);
}

.coping {
    --cat-color: var(--clr-catcolor-coping);
}

.foundation {
    --cat-color: var(--clr-catcolor-foundation);
}

.downloadcontainer {
    --cat-color: var(--clr-secondary-light);
}

.generic {
    --cat-color: var(--clr-catcolor-generic);
}

/* Collapse toggle */
.cat-toggle {
    margin-left: auto;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 30%;
    border: 0;
    padding: 0;
    color: var(--clr-primary-light);
    background: var(--glass-70);
    box-shadow: 0 4px 12px var(--shadow-35);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform .3s ease;
}

.cat-toggle svg {
    width: 22px;
    height: 22px;
    display: block;
}

.cat-toggle svg path {
    fill: currentColor;
    stroke: none;
}

/* ======= Tables ======= */
table {
    width: 100%;
    background: transparent;
    border-collapse: collapse;
    box-shadow: none;
    margin: 0 16px;
}

th,
td {
    padding: .5rem .5rem;
    text-align: left;
}

th {
    font-family: var(--font-heading);
    font-size: 0.9rem;
    text-transform: uppercase;
    color: var(--clr-secondary-light);
    letter-spacing: 0.15em;
}

td {
    font-family: var(--font-body);
}

td img {
    width: 90px;
    border-radius: 10px;
    display: block;
}

.product-name {
    font-family: var(--font-heading);
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: .12em;
    margin-bottom: .25rem;
    color: var(--clr-primary-light);
}

.tag,
.product-tag {
    display: inline-block;
    background: var(--clr-secondary-dark);
    color: var(--clr-catcolor-Surface);
    font-family: var(--font-heading);
    font-size: 0.75rem;
    padding: 0.2rem 0.5rem;
    border-radius: 8px;
    margin-bottom: 0.4rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

/* Price currency micro */
.user-cur {
    font-size: 0.55em;
    margin-right: 4px;
    color: var(--clr-primary);
    text-align: right;
}

/* Finish image overlay wrapper */
.finish-img-wrap {
    position: relative;
    display: inline-block;
    border-radius: 12px;
}

.finish-img-wrap .paint-plane {
    position: absolute;
    inset: 0;
    border-radius: inherit;
    z-index: 1;
}

.finish-img-wrap img {
    position: relative;
    z-index: 2;
    display: block;
    width: 100%;
    height: auto;
    border-radius: inherit;
}

table td .finish-img-wrap {
    width: 90px;
}

/* ======= Forms / Selects ======= */
.select,
#buildHeader .rn-select {
    padding: .75rem 2.2em .75rem 1em;
    border: none;
    border-radius: var(--radius);
    background: var(--glass-70);
    color: var(--clr-primary-light);
    box-shadow: 0 4px 12px var(--shadow-35);
    appearance: none;
    -webkit-appearance: none;
    background-image:
        url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='%23b7b7b7'><path d='M7 10l5 5 5-5z'/></svg>");
    background-repeat: no-repeat;
    background-position: right .9em center;
    background-size: 1.1em 1.1em;
    font-family: var(--font-heading);
    text-transform: uppercase;
    letter-spacing: .1em;
}

.select:hover,
#buildHeader .rn-select:hover {
    transform: translateZ(0) scale(1.03);
    box-shadow: 0 8px 24px var(--shadow-35);
}
:focus {
  outline: none;
}

.select:focus {
    outline: 0;
}

select option {
    background: var(--clr-bg-app);
    color: var(--clr-primary-light);
    letter-spacing: .1em;
    text-transform: uppercase;
}

/* ======= Switch ======= */
.switch {
    position: relative;
    display: inline-block;
    width: 3rem;
    height: 1.6rem;
}

.switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.switch .slider {
    position: absolute;
    inset: 0;
    cursor: pointer;
    border: none;
    border-radius: .66rem;
    background: var(--slider-track);
    transition: background .3s;
}

.switch .slider::before,
.switch .slider::after {
    position: absolute;
    top: 0;
    height: 104%;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 30%;
    border: none;
    font-family: var(--font-heading);
    box-shadow: 0 4px 12px var(--shadow-35);
    -webkit-backdrop-filter: blur(4px) saturate(120%);
    backdrop-filter: blur(4px) saturate(100%);
}

.switch .slider::before {
    content: 'OFF';
    left: 0;
    width: 52%;
    font-size: .5rem;
    background: var(--clr-secondary-light);
    color: var(--clr-bg-body);
    transition: transform .4s ease, opacity .3s;
}

.switch .slider::after {
    content: 'ON';
    right: 0;
    width: 52%;
    font-size: .6rem;
    background: var(--clr-nav-bg);
    color: var(--clr-primary-light);
    opacity: 0;
    transition: transform .4s ease, opacity .3s;
}

.switch--mode .slider::before {
    content: 'MAN';
}

.switch--mode .slider::after {
    content: 'CNC';
}

.switch input:checked+.slider {
    background: var(--clr-accent);
}

.switch input:checked+.slider::before {
    opacity: 0;
}

.switch input:checked+.slider::after {
    opacity: 1;
}

/* ======= Iframes / Embeds ======= */
.embed,
.embedded-layout {
    width: 100%;
    border: 0;
    display: block;
    min-height: 400px;
}

.svgembedded-layout {
    max-width: 100%;
}

.svgembedded-layout svg {
    display: block;
    width: 100%;
    height: auto;
}

/* ======= Misc / Helpers ======= */
.hidden {
    display: none !important;
}

.center {
    display: grid;
    place-items: center;
}

.mt-0 {
    margin-top: 0 !important;
}

.mb-0 {
    margin-bottom: 0 !important;
}

.mt-1 {
    margin-top: .5rem;
}

.mb-1 {
    margin-bottom: .5rem;
}

.mt-2 {
    margin-top: 1rem;
}

.mb-2 {
    margin-bottom: 1rem;
}

/* ======= Responsive tweaks ======= */

/* ======= Legal page (sidebar + content) ======= */


.legal-wrap {
    position: relative;
}

.legal-content {
    margin-left: 0 !important;
    padding: 5rem 0em 5rem 0em;

}

.legal-doc {
    padding-left: calc(var(--nav-w-actual) + (var(--nav-gap) * 2));
    padding-top: 22px;
    /* subtle breathing room */
}

.legal-nav {
    position: fixed;
    z-index: 9999;
    /* above the content card */
    top: calc(var(--header-height) + var(--nav-top-offset));
    left: calc(var(--card-left) + var(--nav-gap));

    pointer-events: auto;
}

.legal-nav nav {
    background: var(--glass-70);
    border-radius: 12px;
    box-shadow: 0 12px 60px var(--shadow-35);
      padding: 22px 22px;
}

/* links = TEXT ONLY highlight (no per-link bg/outline) */
.legal-nav a {
    display: block;
    padding: 12px 22px;
    text-align: right;
    color: var(--clr-primary-light);
    font-family: var(--font-heading);
    text-transform: uppercase;
    letter-spacing: var(--ls-uc);
    background: transparent;
}

.legal-nav a {
    background: transparent;
    color: var(--clr-primary-light);
}

.legal-nav a:hover,
.legal-nav a.is-active,
.legal-nav a:focus-visible {
    color: var(--clr-primary);
    box-shadow: none;
}


.legal-section {
    background: var(--glass-70);
    border-radius: 12px;
    box-shadow: 0 12px 60px var(--shadow-55);
    padding: 22px;
    margin-bottom: 100px;
    scroll-margin-top: calc(var(--header-height) + 20px);
}

.legal-section h2 {
    font-size: 1.5rem;
    margin: 0 0 12px;
}

.legal-section h3 {
    font-size: 1rem;
    margin: 18px 0 10px;
}

.stamp {
    color: var(--clr-secondary-light);
    font-size: var(--fs-small);
}

.legal-menu-btn {
    /* optional hamburger, keep hidden unless you wire it up */
    position: fixed;
    left: 16px;
    top: calc(var(--header-height) + 12px);
    z-index: 80;
    width: 40px;
    height: 34px;
    background: var(--glass-70);
    border: 0;
    border-radius: 10px;
    display: none;
    align-items: center;
    justify-content: center;
    gap: 5px;
}

.legal-menu-btn span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--clr-primary-light);
}
/* ===== MOBILE OVERRIDES: no left padding on card; left gutter on text only; square burger ===== */
@media (max-width: 860px){

  /* Card hugs edges; ZERO left padding on the CARD */
  .legal-doc{
    margin: 6px 6px 24px;
    width: calc(100vw - 12px);
    border-radius: 10px;
    padding: 10px 0 24px 0 !important;   /* ← no left or right padding */
    box-shadow: 0 12px 60px var(--shadow-35);
  }

  /* LEFT gutter for TEXT ONLY (sections inside the card) */
  .legal-doc .legal-block{
    padding-left: 68px !important;       /* ← requested text gutter */
  }

  /* Square hamburger with drop shadow */
  .legal-menu-btn{
    position: fixed;
    left: 24px; top: 24px;
    width: 48px !important;
    height: 48px !important;             /* ← perfect square */
    padding: 0 !important;
    display: grid !important;
    place-items: center;
    border: 0;
    border-radius: 0 !important;         /* square corners */
    background: var(--glass-70);
    box-shadow: 0 12px 40px var(--shadow-35) !important;
    z-index: 10001;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
  }
  .legal-menu-btn span{
    width: 22px; height: 2px;
    background: var(--clr-primary-light);
    display: block;
  }

  /* Fixed off-canvas nav (does NOT scroll with the card) */
  .legal-nav{
    position: fixed;
    top: 0; left: 0;
    height: 100vh;
    width: min(86vw, 360px);
    padding: 72px 18px 18px;
    background: var(--glass-70);
    box-shadow: 0 18px 80px var(--shadow-35);
    -webkit-backdrop-filter: blur(6px) saturate(120%);
            backdrop-filter: blur(6px) saturate(120%);
    transform: translateX(-110%);
    transition: transform .28s ease;
    z-index: 10000;
    pointer-events: none;                 /* blocked until opened */
  }
  .legal-nav.is-open{ transform: translateX(0); pointer-events: auto; }

  .legal-nav nav{ padding:0; background:transparent; border-radius:0; box-shadow:none; }
  .legal-nav a{ padding:12px 10px; text-align:left; }
}
