/* ============================================================
   ONE SHOT SHOVEL — oneshotshovel.com rebuild
   Palette: hammered steel + hi-vis fiberglass yellow
   ============================================================ */

:root{
  --coal:      #17181b;   /* hammered-steel charcoal        */
  --coal-2:    #1f2125;   /* raised panel on charcoal       */
  --steel:     #eceded;   /* powder-coat light grey         */
  --steel-2:   #ffffff;   /* card white                     */
  --hivis:     #f2c400;   /* fiberglass-handle yellow       */
  --hivis-dk:  #d9ad00;
  --ink:       #212327;   /* body text on light             */
  --ink-soft:  #55585f;
  --line:      #d6d8d9;
  --wing: polygon(0 0, calc(100% - 26px) 0, 100% 26px, 100% 100%, 0 100%);
  --wing-sm: polygon(0 0, calc(100% - 16px) 0, 100% 16px, 100% 100%, 0 100%);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}

body{
  font-family:'Barlow',system-ui,sans-serif;
  font-size:1.0625rem;
  line-height:1.65;
  color:var(--ink);
  background:var(--steel);
}

img{max-width:100%;height:auto;display:block}
a{color:inherit}

.display{
  font-family:'Anton',sans-serif;
  font-weight:400;
  text-transform:uppercase;
  line-height:.95;
  letter-spacing:.01em;
}
.eyebrow{
  font-family:'Barlow Semi Condensed',sans-serif;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.8rem;
  color:var(--hivis-dk);
  display:inline-flex;
  align-items:center;
  gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:3px;background:var(--hivis);transform:skewX(-30deg)}

.wrap{max-width:1120px;margin:0 auto;padding:0 24px}

:focus-visible{outline:3px solid var(--hivis);outline-offset:2px}

/* ---------- header ---------- */
.topbar{
  background:var(--coal);
  color:#cfd1d4;
  font-family:'Barlow Semi Condensed',sans-serif;
  font-size:.85rem;
  letter-spacing:.06em;
  border-bottom:1px solid #2c2e33;
}
.topbar .wrap{display:flex;justify-content:space-between;gap:16px;padding-top:7px;padding-bottom:7px;flex-wrap:wrap}
.topbar a{color:#fff;text-decoration:none}
.topbar a:hover{color:var(--hivis)}

header.site{
  background:var(--coal);
  position:sticky;top:0;z-index:50;
  border-bottom:3px solid var(--hivis);
}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;padding-top:12px;padding-bottom:12px}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none;color:#fff}
.brand img{width:56px;height:56px}
.brand b{font-family:'Anton',sans-serif;font-weight:400;font-size:1.35rem;text-transform:uppercase;letter-spacing:.03em;line-height:1}
.brand small{display:block;font-family:'Barlow Semi Condensed',sans-serif;font-size:.72rem;letter-spacing:.28em;color:var(--hivis);margin-top:3px}
nav.main{display:flex;gap:4px;flex-wrap:wrap}
nav.main a{
  font-family:'Barlow Semi Condensed',sans-serif;
  font-weight:600;text-transform:uppercase;letter-spacing:.12em;font-size:.88rem;
  color:#e8e9ea;text-decoration:none;padding:9px 14px;
}
nav.main a:hover{color:var(--hivis)}
nav.main a[aria-current="page"]{
  color:var(--coal);background:var(--hivis);
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,0 100%);
}

/* ---------- hero ---------- */
.hero{
  background:
    repeating-linear-gradient(115deg,transparent 0 90px,rgba(255,255,255,.018) 90px 91px),
    radial-gradient(1000px 500px at 85% -10%, #26282d 0%, transparent 60%),
    var(--coal);
  color:#fff;
  overflow:hidden;
}
.hero .wrap{
  display:grid;grid-template-columns:1.25fr .75fr;gap:48px;align-items:center;
  padding-top:84px;padding-bottom:92px;
}
.hero h1{font-size:clamp(2.9rem,7vw,5.4rem);color:#fff}
.hero h1 .yell{color:var(--hivis)}
.hero p.lead{margin:22px 0 34px;max-width:34em;color:#c9cbce;font-size:1.15rem}
.hero .badge{justify-self:center;position:relative}
.hero .badge img{width:min(300px,60vw);filter:drop-shadow(0 18px 40px rgba(0,0,0,.55));transform:rotate(-6deg)}
.hero .badge::after{
  content:"PATENTED WINGED DESIGN";
  position:absolute;left:50%;bottom:-34px;transform:translateX(-50%) skewX(-12deg);
  background:var(--hivis);color:var(--coal);
  font-family:'Barlow Semi Condensed',sans-serif;font-weight:700;letter-spacing:.16em;
  font-size:.75rem;padding:6px 16px;white-space:nowrap;
}

.btn{
  display:inline-block;text-decoration:none;
  font-family:'Barlow Semi Condensed',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:.92rem;
  padding:15px 28px;
  clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,0 100%);
  transition:transform .15s ease, background .15s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-y{background:var(--hivis);color:var(--coal)}
.btn-y:hover{background:#ffd722}
.btn-ghost{background:transparent;color:#fff;box-shadow:inset 0 0 0 2px #46484d}
.btn-ghost:hover{box-shadow:inset 0 0 0 2px var(--hivis);color:var(--hivis)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap}

/* hazard divider — the wing stripe */
.hazard{
  height:14px;
  background:repeating-linear-gradient(115deg,var(--hivis) 0 22px,var(--coal) 22px 44px);
}

/* ---------- sections ---------- */
section{padding:76px 0}
section h2{font-size:clamp(1.9rem,4vw,2.8rem);margin:10px 0 18px}
.sub{color:var(--ink-soft);max-width:46em}

.sec-dark{background:var(--coal);color:#e8e9ea}
.sec-dark h2{color:#fff}
.sec-dark .sub{color:#b9bbbf}

/* video cards */
.video-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:40px}
.video-card{background:var(--coal-2);clip-path:var(--wing);padding:14px 14px 20px;border:1px solid #2c2e33}
.video-card .frame{position:relative;aspect-ratio:16/9;background:#000}
.video-card iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-card h3{
  font-family:'Barlow Semi Condensed',sans-serif;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;font-size:1rem;color:#fff;margin:16px 4px 2px;
}
.video-card p{color:#a9abaf;font-size:.95rem;margin:2px 4px 0}
.video-card h3 .tag{color:var(--hivis)}
.video-card .yt-link{
  display:inline-block;margin:12px 4px 0;color:var(--hivis);text-decoration:none;
  font-family:'Barlow Semi Condensed',sans-serif;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;font-size:.82rem;
}
.video-card .yt-link:hover{text-decoration:underline}

/* about split */
.split{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center}
.split .pic{clip-path:var(--wing)}
.split .pic img{width:100%}
.credit{margin-top:26px;padding:18px 22px;background:var(--steel-2);border-left:5px solid var(--hivis);font-size:.98rem}
.credit a{font-weight:600}

/* feature cards (The Shovel) */
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;margin-top:44px}
.feat{
  background:var(--steel-2);
  clip-path:var(--wing);
  border:1px solid var(--line);
  display:flex;flex-direction:column;
}
.feat .pic{aspect-ratio:4/3;overflow:hidden;background:#dfe0e1}
.feat .pic img{width:100%;height:100%;object-fit:cover}
.feat .txt{padding:26px 28px 32px}
.feat h3{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;font-size:1.35rem;letter-spacing:.02em;margin-bottom:10px}
.feat h3::after{content:"";display:block;width:44px;height:4px;background:var(--hivis);margin-top:10px;transform:skewX(-30deg)}
.feat p{color:var(--ink-soft)}

.spec{padding:40px;background:var(--steel-2);clip-path:var(--wing);border:1px solid var(--line);margin-top:48px;text-align:center}
.spec img{margin:18px auto 0;width:min(720px,100%)}
.spec figcaption{font-family:'Barlow Semi Condensed',sans-serif;letter-spacing:.14em;text-transform:uppercase;font-size:.85rem;color:var(--ink-soft);margin-top:14px}

.warranty{
  margin-top:52px;background:var(--coal);color:#e8e9ea;clip-path:var(--wing);
  padding:44px 48px;display:grid;grid-template-columns:auto 1fr;gap:30px;align-items:center;
}
.warranty .mark{
  width:84px;height:84px;border-radius:50%;background:var(--hivis);color:var(--coal);
  display:grid;place-items:center;font-family:'Anton',sans-serif;font-size:.8rem;text-align:center;line-height:1.1;
  text-transform:uppercase;
}
.warranty h3{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;font-size:1.5rem;color:#fff;margin-bottom:8px}
.warranty p{color:#b9bbbf}

/* gallery */
.masonry{columns:3;column-gap:22px;margin-top:44px}
.masonry a{
  display:block;margin:0 0 22px;clip-path:var(--wing-sm);
  break-inside:avoid;background:var(--steel-2);border:1px solid var(--line);
}
.masonry img{width:100%;transition:transform .25s ease,filter .25s ease}
.masonry a:hover img{transform:scale(1.03);filter:brightness(1.05)}

dialog.lightbox{
  border:0;padding:0;background:transparent;max-width:min(94vw,1000px);
}
dialog.lightbox::backdrop{background:rgba(10,10,12,.9)}
dialog.lightbox img{width:100%;max-height:88vh;object-fit:contain}
dialog.lightbox button{
  position:fixed;top:18px;right:22px;background:var(--hivis);color:var(--coal);border:0;
  font-family:'Barlow Semi Condensed',sans-serif;font-weight:700;letter-spacing:.1em;
  padding:10px 18px;cursor:pointer;text-transform:uppercase;
}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;margin-top:44px;align-items:start}
.c-card{background:var(--steel-2);border:1px solid var(--line);clip-path:var(--wing);padding:38px 40px}
.c-card h3{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;font-size:1.3rem;margin-bottom:20px}
.c-list{list-style:none}
.c-list li{
  display:flex;gap:16px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--line);
}
.c-list li:last-child{border-bottom:0}
.c-list .k{
  font-family:'Barlow Semi Condensed',sans-serif;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;font-size:.78rem;color:var(--ink-soft);width:86px;flex:none;padding-top:4px;
}
.c-list .v{font-size:1.12rem;font-weight:500}
.c-list .v a{text-decoration:none}
.c-list .v a:hover{color:var(--hivis-dk);text-decoration:underline}
.patent-badges{display:flex;gap:20px;flex-wrap:wrap;margin-top:34px}
.p-badge{
  display:flex;align-items:center;gap:14px;
  background:var(--coal);color:#fff;
  clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,0 100%);
  padding:16px 26px 16px 20px;border-bottom:4px solid var(--hivis);
}
.p-badge .flag{font-size:1.7rem;line-height:1}
.p-badge .lbl{
  font-family:'Barlow Semi Condensed',sans-serif;font-weight:700;text-transform:uppercase;
  letter-spacing:.14em;font-size:.95rem;
}
.p-badge .lbl::after{
  content:"Protected Design";display:block;font-weight:600;letter-spacing:.2em;
  font-size:.62rem;color:var(--hivis);margin-top:3px;
}

.patent-fig{background:var(--steel-2);border:1px solid var(--line);clip-path:var(--wing);padding:30px;text-align:center}
.patent-fig img{margin:0 auto;width:min(300px,100%)}
.patent-fig figcaption{font-family:'Barlow Semi Condensed',sans-serif;letter-spacing:.14em;text-transform:uppercase;font-size:.82rem;color:var(--ink-soft);margin-top:16px}

/* footer */
footer.site{background:var(--coal);color:#a9abaf;border-top:3px solid var(--hivis)}
footer.site .wrap{
  display:grid;grid-template-columns:auto 1fr auto;gap:36px;align-items:center;
  padding-top:44px;padding-bottom:44px;
}
footer.site img{width:74px}
footer.site nav{display:flex;gap:22px;flex-wrap:wrap;justify-content:center}
footer.site nav a{
  color:#e8e9ea;text-decoration:none;font-family:'Barlow Semi Condensed',sans-serif;
  text-transform:uppercase;letter-spacing:.12em;font-size:.85rem;
}
footer.site nav a:hover{color:var(--hivis)}
footer.site .legal{font-size:.85rem;text-align:right}
footer.site .legal a{color:#e8e9ea;text-decoration:none}
footer.site .legal a:hover{color:var(--hivis)}

/* page banner (inner pages) */
.banner{
  background:
    repeating-linear-gradient(115deg,transparent 0 90px,rgba(255,255,255,.018) 90px 91px),
    var(--coal);
  color:#fff;padding:64px 0 58px;
}
.banner h1{font-size:clamp(2.4rem,5.5vw,4rem);color:#fff}
.banner p{color:#b9bbbf;max-width:44em;margin-top:14px;font-size:1.1rem}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .hero .wrap{grid-template-columns:1fr;padding-top:60px;padding-bottom:70px}
  .hero .badge{order:-1}
  .hero .badge img{width:180px}
  .split{grid-template-columns:1fr;gap:36px}
  .video-grid{grid-template-columns:1fr}
  .feat-grid{grid-template-columns:1fr}
  .masonry{columns:2}
  .contact-grid{grid-template-columns:1fr}
  footer.site .wrap{grid-template-columns:1fr;text-align:center;justify-items:center}
  footer.site .legal{text-align:center}
}
@media (max-width:560px){
  .masonry{columns:1}
  .warranty{grid-template-columns:1fr;text-align:center;justify-items:center;padding:36px 26px}
  header.site .wrap{flex-direction:column;gap:8px}
}
