:root{
    --ink:#1c1b18;
    --steel:#2e2c28;
    --steel-2:#39362f;
    --paper:#f3ede1;
    --paper-2:#e9e0cd;
    --amber:#f2a900;
    --amber-dim:#c98c00;
    --rust:#b23a2f;
    --moss:#4c7a52;
    --pencil:#4a463e;
    --pencil-soft:#787163;
    --line: rgba(28,27,24,.16);
  }
  *{box-sizing:border-box; margin:0; padding:0;}
  html{scroll-behavior:smooth;}
  body{
    background:var(--paper);
    color:var(--ink);
    font-family:'Inter', sans-serif;
    line-height:1.5;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  h1,h2,h3,.display{
    font-family:'Oswald', sans-serif;
    text-transform:uppercase;
    letter-spacing:.02em;
  }
  .mono{font-family:'Space Mono', monospace;}
  a{color:inherit;}
  img,svg{display:block;}
  .wrap{max-width:1180px; margin:0 auto; padding:0 28px;}

  /* ===== reduced motion ===== */
  @media (prefers-reduced-motion: reduce){
    *{animation-duration:.001ms !important; transition-duration:.001ms !important;}
  }

  /* ===== TOP BAR ===== */
  .topbar{
    position:sticky; top:0; z-index:50;
    background:var(--ink);
    color:var(--paper);
    border-bottom:3px solid var(--amber);
  }
  .topbar-inner{
    display:flex; align-items:center; justify-content:space-between;
    padding:14px 28px;
    max-width:1180px; margin:0 auto;
    position:relative;
  }
  .brandmark{display:flex; align-items:center; gap:12px;}
  .brandmark .gear{width:30px; height:30px; flex:none;}
  .brandmark .name{font-size:20px; font-weight:600; letter-spacing:.04em;}
  .brandmark .name span{color:var(--amber);}
  .topnav{display:flex; align-items:center; gap:28px; font-size:13px; letter-spacing:.06em; text-transform:uppercase;}
  .topnav a{text-decoration:none; opacity:.85; transition:opacity .15s;}
  .topnav a:hover{opacity:1; color:var(--amber);}
  .topnav .call-btn{
    background:var(--amber); color:var(--ink); padding:9px 18px;
    font-weight:700; border-radius:2px; opacity:1;
  }
  .topnav .call-btn:hover{background:#fff; color:var(--ink);}

  .menu-btn{
    display:none; background:none; border:none; color:var(--paper);
    width:38px; height:34px; cursor:pointer; padding:0;
    flex-direction:column; align-items:center; justify-content:center; gap:5px;
  }
  .menu-btn span{display:block; width:22px; height:2px; background:var(--paper); border-radius:2px; transition:transform .2s, opacity .2s;}
  .menu-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .menu-btn.open span:nth-child(2){opacity:0;}
  .menu-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

  @media(max-width:760px){
    .menu-btn{display:flex;}
    .topnav{
      position:absolute; top:100%; left:0; right:0;
      flex-direction:column; align-items:stretch; gap:0;
      background:var(--ink);
      border-bottom:3px solid var(--amber);
      max-height:0; overflow:hidden;
      transition:max-height .28s ease;
    }
    .topnav.open{max-height:420px;}
    .topnav a{font-size:14px;}
    .topnav a:not(.call-btn){
      display:block; width:100%; padding:16px 28px;
      border-bottom:1px solid rgba(243,237,225,.08);
      opacity:1;
    }
    .topnav a.active{background:rgba(242,169,0,.08);}
    .topnav .call-btn{
      display:block; text-align:center; margin:16px 28px;
    }
  }

  /* ===== HERO — work order ticket ===== */
  .hero{
    background:
      radial-gradient(ellipse at 75% 20%, rgba(242,169,0,.10), transparent 55%),
      var(--ink);
    color:var(--paper);
    padding:72px 28px 0;
    overflow:hidden;
    position:relative;
  }
  .hero-grid{
    max-width:1180px; margin:0 auto;
    display:grid; grid-template-columns:1.1fr .9fr; gap:48px;
    align-items:end;
  }
  .eyebrow{
    font-family:'Space Mono', monospace;
    font-size:12px; letter-spacing:.18em; text-transform:uppercase;
    color:var(--amber); margin-bottom:18px; display:flex; align-items:center; gap:10px;
  }
  .eyebrow::before{content:''; width:22px; height:2px; background:var(--amber); display:inline-block;}
  .hero h1{
    font-size:clamp(40px, 6vw, 76px);
    line-height:.96;
    font-weight:700;
    margin-bottom:22px;
  }
  .hero h1 em{font-style:normal; color:var(--amber);}
  .hero p.lead{
    font-size:17px; color:#c9c2b3; max-width:480px; margin-bottom:30px;
  }
  .hero-ctas{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:54px;}
  .btn{
    font-family:'Oswald', sans-serif; text-transform:uppercase; letter-spacing:.04em;
    font-weight:600; font-size:14px; padding:15px 26px; border-radius:2px;
    text-decoration:none; display:inline-flex; align-items:center; gap:10px;
    border:2px solid transparent; cursor:pointer; transition:transform .15s, background .15s, border-color .15s;
  }
  .btn-primary{background:var(--amber); color:var(--ink);}
  .btn-primary:hover{transform:translateY(-2px); background:#ffc233;}
  .btn-ghost{border-color:rgba(243,237,225,.35); color:var(--paper);}
  .btn-ghost:hover{border-color:var(--amber); color:var(--amber);}

  /* ticket card */
  .ticket{
    background:var(--paper);
    color:var(--ink);
    border-radius:4px;
    padding:26px 26px 22px;
    position:relative;
    box-shadow:0 30px 60px -20px rgba(0,0,0,.55);
    transform:rotate(1.4deg);
    margin-bottom:-26px;
  }
  .ticket::before{
    content:'';
    position:absolute; inset:10px;
    border:1.5px dashed rgba(28,27,24,.25);
    pointer-events:none;
  }
  .ticket-head{
    display:flex; justify-content:space-between; align-items:flex-start;
    border-bottom:2px solid var(--ink); padding-bottom:10px; margin-bottom:14px;
  }
  .ticket-head .t1{font-family:'Space Mono',monospace; font-size:11px; letter-spacing:.1em; color:var(--pencil-soft); text-transform:uppercase;}
  .ticket-head .t2{font-family:'Oswald',sans-serif; font-weight:700; font-size:15px;}
  .ticket-rows{font-family:'Space Mono', monospace; font-size:12.5px; display:grid; gap:7px; margin-bottom:16px;}
  .ticket-rows div{display:flex; justify-content:space-between; gap:10px; border-bottom:1px dotted var(--line); padding-bottom:6px;}
  .ticket-rows div b{font-weight:700;}
  .stamp{
    display:inline-block; font-family:'Oswald',sans-serif; font-weight:700; font-size:13px;
    text-transform:uppercase; letter-spacing:.08em; padding:5px 12px; border-radius:3px;
    transform:rotate(-3deg);
  }
  .stamp.ok{ color:var(--moss); border:2.5px solid var(--moss); }
  .rating-line{display:flex; align-items:center; gap:8px; font-size:13px; color:var(--pencil);}
  .stars{color:var(--amber-dim); letter-spacing:1px; font-size:14px;}

  /* hero bottom strip */
  .hero-strip{
    border-top:1px solid rgba(243,237,225,.18);
    padding:22px 0;
    display:grid; grid-template-columns:repeat(4,1fr); gap:18px;
    max-width:1180px; margin:0 auto;
  }
  .hero-strip .item{font-size:12.5px; color:#bdb6a5;}
  .hero-strip .item b{display:block; color:var(--paper); font-family:'Oswald',sans-serif; text-transform:uppercase; font-size:13px; letter-spacing:.03em; margin-bottom:3px;}
  @media(max-width:900px){
    .hero-grid{grid-template-columns:1fr; gap:30px;}
    .ticket{transform:rotate(0); margin-bottom:0;}
    .hero-strip{grid-template-columns:repeat(2,1fr);}
  }

  /* ===== SECTION HEADERS ===== */
  .section{padding:88px 0;}
  .section.tight{padding:60px 0;}
  .sec-head{display:flex; justify-content:space-between; align-items:flex-end; gap:24px; margin-bottom:42px; flex-wrap:wrap;}
  .sec-head .eyebrow{color:var(--rust);}
  .sec-head h2{font-size:clamp(30px,4vw,46px); font-weight:700;}
  .sec-head p{max-width:380px; color:var(--pencil-soft); font-size:14.5px;}

  /* ===== SERVICES — parts bin grid ===== */
  .services{
    display:grid; grid-template-columns:repeat(3,1fr); gap:1px;
    background:var(--ink); border:1px solid var(--ink);
  }
  .svc{
    background:var(--paper); padding:30px 26px; position:relative;
    transition:background .15s;
  }
  .svc:hover{background:var(--paper-2);}
  .svc .num{font-family:'Space Mono',monospace; font-size:12px; color:var(--rust); margin-bottom:14px; display:block;}
  .svc h3{font-size:19px; margin-bottom:9px; font-weight:600;}
  .svc p{font-size:13.5px; color:var(--pencil-soft); margin-bottom:14px;}
  .svc .price{font-family:'Space Mono',monospace; font-size:13px; font-weight:700; color:var(--ink); border-top:1px dashed var(--line); padding-top:12px;}
  @media(max-width:860px){ .services{grid-template-columns:1fr 1fr;} }
  @media(max-width:560px){ .services{grid-template-columns:1fr;} }

  /* ===== SCHEDULE — punch board (signature element) ===== */
  .board-wrap{
    background:var(--steel);
    border-radius:6px;
    padding:34px 30px 30px;
    box-shadow: inset 0 0 0 1px rgba(243,237,225,.06);
  }
  .board-top{display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; margin-bottom:24px;}
  .board-top h3{color:var(--paper); font-size:22px;}
  .legend{display:flex; gap:18px; font-size:12px; color:#cbc4b3; font-family:'Space Mono',monospace; text-transform:uppercase; letter-spacing:.04em;}
  .legend span{display:inline-flex; align-items:center; gap:7px;}
  .legend i{width:11px; height:11px; border-radius:2px; display:inline-block;}
  .legend i.free{background:var(--moss);}
  .legend i.busy{background:var(--rust);}

  .board-scroll{ overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .board{
    display:grid;
    grid-template-columns: 86px repeat(6, 1fr);
    gap:6px;
  }
  .board .corner{
    position:sticky; left:0; z-index:3; background:var(--steel);
  }
  .board .daylabel{
    font-family:'Oswald',sans-serif; text-transform:uppercase; font-weight:600;
    color:var(--paper); font-size:13px; text-align:center; padding:10px 4px 14px;
    border-bottom:2px solid var(--amber);
  }
  .board .daylabel small{display:block; font-family:'Space Mono',monospace; font-weight:400; font-size:10px; color:#9a9384; text-transform:none; margin-top:3px;}
  .board .timelabel{
    font-family:'Space Mono',monospace; font-size:12px; color:#9a9384;
    display:flex; align-items:center; padding-right:6px;
    position:sticky; left:0; z-index:3; background:var(--steel);
  }
  .slot{
    border:none; border-radius:3px; padding:11px 4px; cursor:pointer;
    font-family:'Space Mono',monospace; font-size:11px; font-weight:700; letter-spacing:.02em;
    text-transform:uppercase; text-align:center; transition:transform .12s, filter .12s;
    color:var(--paper);
  }
  .slot.free{ background:rgba(76,122,82,.28); color:#bfe2c4; box-shadow:inset 0 0 0 1.5px rgba(76,122,82,.7);}
  .slot.free:hover{ background:var(--moss); color:#fff; transform:translateY(-2px); }
  .slot.busy{ background:rgba(178,58,47,.22); color:#e7b3ac; box-shadow:inset 0 0 0 1.5px rgba(178,58,47,.55); cursor:pointer;}
  .slot.busy:hover{ filter:brightness(1.2); }
  .slot.pause{ background:transparent; color:#6b6457; box-shadow:inset 0 0 0 1px rgba(243,237,225,.08); cursor:default; font-style:italic;}
  .slot.closed{background:transparent; box-shadow:none; cursor:default;}

  /* Below 900px the grid no longer squeezes — it scrolls horizontally
     instead, so every label and stamp stays fully readable. */
  @media(max-width:900px){
    .board{
      grid-template-columns: 64px repeat(6, 108px);
      min-width:max-content;
      gap:5px;
    }
    .slot{font-size:11.5px; padding:13px 4px;}
    .board .daylabel{font-size:13px; padding:8px 4px 12px;}
    .board .timelabel{font-size:12px;}
  }
  @media(max-width:640px){
    .board-wrap{padding:20px 14px;}
    .board{grid-template-columns: 54px repeat(6, 92px);}
  }
  .board-scroll-hint{
    display:none; font-family:'Space Mono',monospace; font-size:11px;
    color:var(--amber); margin-bottom:12px; align-items:center; gap:8px;
  }
  @media(max-width:900px){ .board-scroll-hint{display:flex;} }

  .board-note{margin-top:18px; font-size:12.5px; color:#9a9384;}
  .board-note b{color:var(--amber);}

  /* ===== ABOUT / WHY ===== */
  .why{display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center;}
  .why-list{display:grid; gap:22px; margin-top:24px;}
  .why-item{display:flex; gap:16px;}
  .why-item .ix{font-family:'Space Mono',monospace; color:var(--rust); font-weight:700; font-size:13px; padding-top:3px;}
  .why-item h4{font-size:16px; margin-bottom:5px; font-weight:600;}
  .why-item p{font-size:13.5px; color:var(--pencil-soft);}
  .why-photo{
    background:var(--ink); border-radius:6px; aspect-ratio:4/5;
    display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden;
  }
  @media(max-width:860px){ .why{grid-template-columns:1fr;} .why-photo{order:-1; aspect-ratio:16/9;} }

  /* ===== REVIEWS ===== */
  .reviews{display:grid; grid-template-columns:repeat(3,1fr); gap:18px;}
  .review{background:var(--paper-2); border-radius:4px; padding:24px; border-left:3px solid var(--amber);}
  .review .stars{margin-bottom:10px;}
  .review p{font-size:13.5px; color:var(--pencil); margin-bottom:14px;}
  .review .who{font-family:'Oswald',sans-serif; font-size:12.5px; text-transform:uppercase; color:var(--pencil-soft); letter-spacing:.04em;}
  @media(max-width:860px){ .reviews{grid-template-columns:1fr;} }

  /* ===== CONTACT / FOOTER ===== */
  .contact{background:var(--ink); color:var(--paper);}
  .contact-grid{display:grid; grid-template-columns:1.2fr .8fr; gap:50px;}
  .contact h2{font-size:clamp(28px,3.6vw,40px); margin-bottom:16px;}
  .contact p.lead{color:#bdb6a5; max-width:420px; margin-bottom:26px; font-size:14.5px;}
  .contact-info{display:grid; gap:16px;}
  .contact-info div{display:flex; gap:14px; font-size:14px;}
  .contact-info b{font-family:'Oswald',sans-serif; text-transform:uppercase; font-size:12px; letter-spacing:.05em; color:var(--amber); min-width:110px;}
  .map-box{
    background:var(--steel); border-radius:6px; padding:22px; font-family:'Space Mono',monospace; font-size:12.5px; color:#cbc4b3;
  }
  .map-box .pin{color:var(--amber); font-weight:700; margin-bottom:10px; display:block;}
  .hours-table{width:100%; border-collapse:collapse; margin-top:10px;}
  .hours-table td{padding:6px 0; border-bottom:1px solid rgba(243,237,225,.1);}
  .hours-table td:last-child{text-align:right; font-weight:700;}
  @media(max-width:860px){ .contact-grid{grid-template-columns:1fr;} }

  .foot{border-top:1px solid rgba(243,237,225,.12); padding:22px 0; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; font-size:12px; color:#8d8676;}

  /* ===== NAV ACTIVE STATE ===== */
  .topnav a.active{color:var(--amber); opacity:1;}

  /* ===== SUB-PAGE HEADER (non-home pages) ===== */
  .page-head{
    background:var(--ink); color:var(--paper);
    padding:56px 28px 50px;
    position:relative;
  }
  .page-head .wrap{display:flex; flex-direction:column; gap:14px;}
  .page-head h1{font-size:clamp(34px,5vw,56px); font-weight:700;}
  .page-head p{color:#bdb6a5; max-width:520px; font-size:15px;}

  /* ===== MODAL ===== */
  .overlay{
    position:fixed; inset:0; background:rgba(17,16,14,.72);
    display:none; align-items:center; justify-content:center; z-index:100; padding:20px;
  }
  .overlay.show{display:flex;}
  .modal{
    background:var(--paper); border-radius:6px; max-width:420px; width:100%;
    padding:30px; position:relative;
    max-height:90vh; overflow-y:auto;
  }
  .modal h3{font-size:22px; margin-bottom:6px;}
  .modal .sub{font-family:'Space Mono',monospace; font-size:12.5px; color:var(--rust); margin-bottom:20px;}
  .modal label{display:block; font-size:12px; text-transform:uppercase; letter-spacing:.05em; color:var(--pencil-soft); margin-bottom:6px; margin-top:14px; font-family:'Oswald',sans-serif;}
  .modal input{
    width:100%; padding:11px 12px; border:1.5px solid var(--line); border-radius:3px;
    font-family:'Inter',sans-serif; font-size:16px; background:#fff;
  }
  @media(max-width:480px){ .modal{padding:22px 18px;} }
  .modal input:focus{outline:2px solid var(--amber); outline-offset:1px; border-color:var(--amber);}
  .modal .modal-actions{display:flex; gap:10px; margin-top:24px;}
  .modal .close-x{
    position:absolute; top:16px; right:16px; background:none; border:none; cursor:pointer;
    font-size:18px; color:var(--pencil-soft); line-height:1;
  }
  .confirm-msg{display:none; text-align:center; padding:10px 0;}
  .confirm-msg.show{display:block;}
  .confirm-msg .stamp{font-size:18px; margin-bottom:14px;}