/* ============ Charleston Film Rental — site styles ============ */
:root{
  --cream:#F8EFDE;      /* page background (brand off-white) */
  --cream-2:#FFFBF2;    /* card surface */
  --ink:#2A1A12;        /* primary text */
  --ink-soft:#6B5645;   /* secondary text */
  --brown:#53311E;      /* core brand brown */
  --brown-deep:#3F2516;
  --espresso:#251110;
  --warm:#5A3018;
  --tan:#B99C7E;
  --tan-line:#E4D7C0;   /* hairline borders */
  --terra:#B5764A;      /* product image tile */
  --terra-2:#9d6038;
  --grad:linear-gradient(120deg, #5A3018 0%, #7C4827 52%, #A3683D 100%); /* shared header/hero/footer */
  --radius:14px;
  --shadow:0 1px 2px rgba(37,17,16,.06), 0 8px 24px rgba(37,17,16,.06);
  --maxw:1180px;
}
*{box-sizing:border-box}
button{-webkit-appearance:none;appearance:none;font-family:inherit;outline:none;box-shadow:none}
button:focus,button:focus-visible{outline:none}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;
  -webkit-text-size-adjust:100%;overflow-x:hidden;-webkit-tap-highlight-color:transparent;
  display:flex;flex-direction:column;min-height:100vh;  /* sticky footer */
}
input,select,textarea{font-size:16px}  /* 16px min prevents iOS zoom-on-focus */
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
h1,h2,h3,.cond{font-family:"Barlow Condensed","Oswald",Impact,sans-serif;font-weight:700;letter-spacing:.01em;line-height:1.05}

/* ---------- header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;background:transparent;
  transition:background .25s ease,border-color .25s ease}
.site-header.solid{background:var(--grad);border-bottom:1px solid rgba(255,255,255,.08)}
.brand .logo-on-dark{display:block}
.brand .logo-on-light{display:none}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:74px;gap:20px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:42px;width:auto}
.nav{display:flex;align-items:center;gap:28px}
.nav a{font-weight:600;font-size:14px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);opacity:.8}
.nav a:hover{opacity:1;color:var(--brown)}
.cart-link{display:inline-flex;align-items:center;gap:8px;background:var(--cream);color:var(--brown)!important;
  padding:9px 16px;border-radius:999px;opacity:1!important;font-weight:700}
.cart-link:hover{background:#fff}
.cart-badge{background:var(--brown);color:var(--cream);font-weight:700;border-radius:999px;
  min-width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;font-size:12px;padding:0 5px}

/* ---------- hero ---------- */
.hero{position:relative;min-height:380px;display:flex;align-items:center;background:var(--grad)}
.hero-inner{padding:48px 24px}
.hero h1{font-size:clamp(40px,6.5vw,84px);color:var(--cream);margin:0 0 14px;text-transform:uppercase}
.hero p{font-size:clamp(16px,1.7vw,20px);color:#ECDCC1;max-width:440px;margin:0}
@media(max-width:680px){.hero{min-height:340px}.hero h1{font-size:42px}.hero p{color:#F1E4CC}}
.btn{display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:none;font:inherit;
  font-weight:600;letter-spacing:.03em;text-transform:uppercase;font-size:14px;
  background:var(--grad);color:var(--cream);padding:13px 26px;border-radius:999px;transition:.15s}
.btn:hover{filter:brightness(.93);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--brown);border:1.5px solid var(--brown)}
.btn.ghost:hover{background:var(--grad);color:var(--cream)}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none}

/* ---------- filter toggles ---------- */
.toolbar{position:sticky;top:74px;z-index:40;background:var(--cream);padding:18px 0 14px;border-bottom:1px solid var(--tan-line)}
.toolbar .wrap{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{cursor:pointer;border:1px solid var(--tan-line);background:var(--cream-2);color:var(--ink);
  padding:8px 16px;border-radius:999px;font-size:13px;font-weight:600;letter-spacing:.03em;
  text-transform:uppercase;transition:.15s;white-space:nowrap}
.chip:hover{border-color:var(--tan)}
.chip.active{background:var(--grad);color:var(--cream);border-color:transparent}
.search{display:flex;align-items:center;gap:8px;border:1.5px solid var(--tan-line);background:var(--cream-2);
  border-radius:999px;padding:8px 16px;min-width:230px}
.search input{border:none;background:none;outline:none;font:inherit;font-size:16px;width:100%;color:var(--ink)}

/* ---------- gear grid ---------- */
.section-label{font-size:13px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--terra-2);margin:38px 0 14px}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;padding:8px 0 10px}
.card{background:var(--cream-2);border:1px solid var(--tan-line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow);transition:.18s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-3px);box-shadow:0 2px 4px rgba(37,17,16,.08),0 16px 36px rgba(37,17,16,.12)}
.card .thumb{aspect-ratio:1/1;background:var(--terra);display:flex;align-items:center;justify-content:center;overflow:hidden}
.card .thumb img{width:100%;height:100%;object-fit:cover}
.card .body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:6px;flex:1}
.card .cat{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--tan)}
.card .name{font-family:"Barlow Condensed",sans-serif;font-weight:600;font-size:21px;line-height:1.1;color:var(--ink)}
.card .rate{margin-top:auto;font-weight:700;color:var(--brown);font-size:15px}
.card .rate small{font-weight:500;color:var(--ink-soft)}
.empty{grid-column:1/-1;text-align:center;color:var(--ink-soft);padding:60px 0}

/* ---------- item page ---------- */
.crumbs{padding:96px 0 0;font-size:13px;color:var(--ink-soft)}
.crumbs a:hover{color:var(--brown)}
.item{display:grid;grid-template-columns:1.05fr 1fr;gap:48px;padding:26px 0 60px;align-items:start}
.item .photo{background:var(--terra);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.item .photo img{width:100%;height:auto;display:block}
.gallery{display:flex;flex-direction:column;gap:12px}
.thumbs{display:flex;gap:10px;flex-wrap:wrap}
.thumb-btn{width:74px;height:74px;border-radius:10px;overflow:hidden;border:2px solid var(--tan-line);
  background:var(--terra);cursor:pointer;padding:0;transition:.15s}
.thumb-btn img{width:100%;height:100%;object-fit:cover}
.thumb-btn:hover{border-color:var(--tan)}
.thumb-btn.active{border-color:var(--brown)}
.item .cat{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--terra-2)}
.item h1{font-size:clamp(32px,4.5vw,52px);margin:8px 0 6px;color:var(--ink);text-transform:uppercase}
.item .price{font-size:26px;font-weight:700;color:var(--brown);margin:10px 0 18px}
.item .price small{font-size:15px;color:var(--ink-soft);font-weight:500}
.item .desc{color:var(--ink-soft);font-size:16px;margin-bottom:26px}
.opt{margin-bottom:22px}
.opt label{display:block;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);margin-bottom:8px}
.opt select,.qty input{font:inherit;padding:12px 14px;border:1.5px solid var(--tan-line);border-radius:10px;
  background:var(--cream-2);color:var(--ink);min-width:240px}
.actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.qty{display:flex;align-items:center;gap:8px}
.qty input{min-width:0;width:70px;text-align:center}

/* ---------- cart ---------- */
.page-head{padding:108px 0 6px}
.page-head h1{font-size:clamp(30px,4vw,48px);color:var(--brown);text-transform:uppercase;margin:0}
.cart-layout{display:grid;grid-template-columns:1.6fr 1fr;gap:36px;padding:20px 0 70px;align-items:start}
.cart-list{display:flex;flex-direction:column;gap:14px}
.cart-row{display:grid;grid-template-columns:84px 1fr auto;gap:16px;align-items:center;
  background:var(--cream-2);border:1px solid var(--tan-line);border-radius:var(--radius);padding:12px}
.cart-row .ph{width:84px;height:84px;border-radius:10px;background:var(--terra);overflow:hidden}
.cart-row .ph img{width:100%;height:100%;object-fit:cover}
.cart-row .nm{font-family:"Barlow Condensed",sans-serif;font-weight:600;font-size:20px;line-height:1.1}
.cart-row .meta{font-size:13px;color:var(--ink-soft)}
.cart-row .ln{text-align:right;font-weight:700;color:var(--brown)}
.cart-row .rm{background:none;border:none;color:var(--ink-soft);cursor:pointer;font-size:13px;text-decoration:underline;padding:0}
.cart-row .rm:hover{color:var(--warm)}
.qtybox{display:inline-flex;align-items:center;gap:10px;margin-top:8px}
.qbtn{width:26px;height:26px;border:1.5px solid var(--tan-line);background:var(--cream);border-radius:7px;cursor:pointer;
  font-size:16px;line-height:1;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;transition:.12s}
.qbtn:hover:not(:disabled){border-color:var(--brown);color:var(--brown)}
.qbtn:disabled{opacity:.35;cursor:not-allowed}
.qval{min-width:18px;text-align:center;font-weight:600}
.summary{background:var(--cream-2);border:1px solid var(--tan-line);border-radius:var(--radius);padding:24px;position:sticky;top:96px}
.summary h3{font-size:24px;text-transform:uppercase;margin:0 0 16px;color:var(--ink)}
.field{margin-bottom:16px}
.field label{display:block;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);margin-bottom:6px}
.field input{width:100%;font:inherit;padding:11px 12px;border:1.5px solid var(--tan-line);border-radius:10px;background:var(--cream);color:var(--ink)}
.dates{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.line{display:flex;justify-content:space-between;padding:8px 0;font-size:15px;color:var(--ink-soft)}
.line.total{border-top:1px solid var(--tan-line);margin-top:6px;padding-top:14px;font-size:20px;font-weight:700;color:var(--ink)}
.note{font-size:12.5px;color:var(--ink-soft);margin-top:14px;line-height:1.5}
.confirm{background:#23502f;color:#eafff1;border-radius:var(--radius);padding:22px;margin-top:18px;display:none}
.confirm.show{display:block}
.confirm strong{display:block;font-size:18px;margin-bottom:4px}

/* ---------- footer ---------- */
.site-footer{background:var(--grad);color:var(--cream);margin-top:auto}  /* auto pushes footer to bottom on short pages */
.site-footer .wrap{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:30px;padding:42px 24px}
.site-footer img{height:54px}
.site-footer .tag{font-family:"Barlow Condensed",sans-serif;font-size:22px;letter-spacing:.02em;color:var(--cream);text-align:center}
.site-footer .sm{font-size:13px;color:var(--cream);opacity:.85;text-align:right}
.footer-seo{padding:2px 24px 34px;text-align:center;font-size:12.5px;color:var(--cream);opacity:.6;line-height:1.6;max-width:900px;margin:0 auto}
.site-footer a{color:inherit;text-decoration:underline;text-underline-offset:3px}
.site-footer a:hover{opacity:.75}
.note a{color:var(--brown);text-decoration:underline}
@media(max-width:680px){.site-footer .wrap{grid-template-columns:1fr;justify-items:center;text-align:center}.site-footer .sm{text-align:center}}

/* ---------- toast ---------- */
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(120%);
  background:var(--ink);color:var(--cream);padding:14px 22px;border-radius:999px;font-weight:600;
  box-shadow:var(--shadow);transition:.3s;z-index:80}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .grid{grid-template-columns:repeat(3,1fr)}
  .item{grid-template-columns:1fr;gap:28px}
  .cart-layout{grid-template-columns:1fr}
  .summary{position:static}
}
@media(max-width:680px){
  .wrap{padding:0 18px}
  .grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .nav{gap:14px}
  /* toolbar: swipeable chip row + full-width search */
  .toolbar{padding:14px 0 12px}
  .toolbar .wrap{flex-direction:column;align-items:stretch;gap:12px}
  .chips{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px;scrollbar-width:none}
  .chips::-webkit-scrollbar{display:none}
  .chip{padding:9px 16px}
  .search{min-width:0;width:100%}
  /* hero */
  .hero-inner{padding:40px 20px}
  /* item page: full-width controls + stacked CTAs */
  .crumbs{padding-top:90px}
  .opt select{width:100%;max-width:100%}
  .actions{flex-direction:column;align-items:stretch}
  .actions .btn{width:100%;justify-content:center}
}
@media(max-width:560px){
  .dates{grid-template-columns:1fr}
  .cart-row{grid-template-columns:64px 1fr;gap:6px 14px}
  .cart-row .ph{width:64px;height:64px}
  .cart-row .ln{grid-column:2;text-align:left;margin-top:4px}
  .qbtn{width:30px;height:30px}
  .summary{padding:20px}
}
