/* =========================================================
   VR MART — Premium Light Theme (Orange + Green)
   File: style.css  (place in public_html/style.css)
   ========================================================= */

/* Google Font (premium, bold, retail-friendly) */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@500;600;700;800;900&display=swap');

:root{
  /* Brand */
  --orange:#ff7a00;   /* Primary */
  --green:#14b86a;    /* Secondary */

  /* Light theme */
  --bg:#ffffff;
  --bg-soft:#fff6ec;         /* soft orange tint */
  --bg-soft-2:#effff6;       /* soft green tint */
  --text:#101219;            /* near-black */
  --muted:#5b6270;
  --line:rgba(16,18,25,.10);

  /* UI */
  --radius:18px;
  --shadow: 0 14px 34px rgba(16,18,25,.08);
  --shadow-2: 0 18px 40px rgba(255,122,0,.12);
  --max:1180px;

  /* Type scale */
  --h1: clamp(44px, 5.6vw, 72px);
  --h2: clamp(26px, 3vw, 40px);
  --h3: 18px;
  --body: 16px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: "Montserrat", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  font-size: var(--body);
  color: var(--text);
  background:
    radial-gradient(900px 480px at 12% 0%, rgba(255,122,0,.14), transparent 60%),
    radial-gradient(900px 520px at 88% 6%, rgba(20,184,106,.12), transparent 62%),
    linear-gradient(180deg, #ffffff 0%, #ffffff 65%, #fbfbfd 100%);
  line-height: 1.6;
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 18px}

/* =========================
   Header / Nav
   ========================= */
.topbar{
  position:sticky; top:0; z-index:50;
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}

.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
  gap:12px;
}

.brand{
  display:flex; align-items:center; gap:12px;
}
.brand img{height:34px;width:auto}
.brand-name{
  font-weight: 900;
  letter-spacing: .6px;
  font-size: 22px;
  color: var(--orange); /* FULL VR MART ORANGE as requested */
  text-transform: uppercase;
}

.navlinks{
  display:flex; align-items:center; gap:18px;
  font-weight: 800;
}
.navlinks a{
  padding:10px 12px;
  border-radius: 14px;
  color: rgba(16,18,25,.78);
  transition: .18s ease;
}
.navlinks a:hover{
  background: rgba(255,122,0,.10);
  color: var(--text);
}
.navlinks a.active{
  background: rgba(255,122,0,.14);
  color: var(--text);
  border:1px solid rgba(255,122,0,.25);
}

.nav-right{display:flex; align-items:center; gap:10px}

/* Mobile menu */
.hamburger{
  display:none;
  width:44px;height:44px;border-radius:14px;
  border:1px solid var(--line);
  background:#fff;
  cursor:pointer;
}
.hamburger span{
  display:block;width:18px;height:2px;background: var(--text);
  margin:5px auto;border-radius:2px;opacity:.85;
}
.mobile-panel{
  display:none;
  padding:10px 0 16px;
  border-top:1px solid var(--line);
}
.mobile-panel a{
  display:block;
  padding:12px 10px;
  border-radius:14px;
  font-weight:800;
  color: rgba(16,18,25,.78);
}
.mobile-panel a:hover{background: rgba(255,122,0,.10); color: var(--text);}

/* =========================
   Buttons
   ========================= */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 16px;
  border-radius: 16px;
  border:1px solid var(--line);
  background:#fff;
  color: var(--text);
  font-weight: 900;
  letter-spacing:.2px;
  transition:.18s ease;
  box-shadow: 0 8px 18px rgba(16,18,25,.06);
  gap:10px;
}
.btn:hover{transform: translateY(-1px); box-shadow: 0 14px 28px rgba(16,18,25,.08)}
.btn.small{padding:10px 14px; border-radius:14px}

.btn.primary{
  border:none;
  background: linear-gradient(135deg, rgba(255,122,0,1), rgba(255,122,0,.78));
  color:#fff;
  box-shadow: var(--shadow-2);
}
.btn.primary:hover{filter:brightness(1.02)}

.btn.green{
  border:1px solid rgba(20,184,106,.28);
  background: rgba(20,184,106,.10);
  color: #0b4b2d;
}
.btn.green:hover{background: rgba(20,184,106,.14)}

/* =========================
   Sections
   ========================= */
.section{padding:34px 0}
.section h2{
  margin:0 0 12px;
  font-size: var(--h2);
  font-weight: 900;
  letter-spacing: -0.6px;
}
.section .subhead{
  margin:0 0 18px;
  color: var(--muted);
  font-weight: 600;
}

/* =========================
   Hero
   ========================= */
.hero{padding:42px 0 18px}
.hero-wrap{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:18px;
  align-items: stretch;
}

.hero-card{
  border:1px solid var(--line);
  background:
    linear-gradient(180deg, rgba(255,122,0,.06), rgba(255,255,255,1) 42%),
    linear-gradient(180deg, rgba(20,184,106,.05), transparent 35%);
  border-radius: var(--radius);
  padding:28px;
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}

.kicker{
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 12px;
  border-radius: 999px;
  background: rgba(255,122,0,.10);
  border: 1px solid rgba(255,122,0,.22);
  color: #7a3c00;
  font-weight: 900;
  font-size: 13px;
}
.kicker .dot{
  width:8px;height:8px;border-radius:99px;
  background: var(--orange);
  box-shadow: 0 0 0 6px rgba(255,122,0,.12);
}

h1{
  margin:14px 0 10px;
  font-size: var(--h1);
  font-weight: 900;
  letter-spacing: -1.2px;
  line-height: 1.04;
}
.brand-h1{
  color: var(--orange); /* FULL ORANGE VR MART */
  text-transform: uppercase;
}

.tagline{
  margin:0 0 10px;
  font-size: 18px;
  font-weight: 800;
  color: rgba(16,18,25,.86);
}
.tagline .green{color: var(--green)}
.lead{
  margin:0;
  color: var(--muted);
  font-weight: 600;
  max-width: 62ch;
}

.hero-actions{
  display:flex;
  gap:10px;
  flex-wrap: wrap;
  margin-top: 18px;
}

.trust-row{
  margin-top: 16px;
  display:flex;
  gap:10px;
  flex-wrap: wrap;
}
.pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: #fff;
  font-weight: 800;
  color: rgba(16,18,25,.78);
}
.pill .tick{
  width:18px;height:18px;border-radius:6px;
  background: rgba(20,184,106,.14);
  border: 1px solid rgba(20,184,106,.22);
  display:inline-flex; align-items:center; justify-content:center;
  font-weight: 900;
  color: #0b4b2d;
  line-height: 1;
}

/* Hero image card */
.hero-media{
  border:1px solid var(--line);
  background: linear-gradient(180deg, rgba(20,184,106,.06), rgba(255,255,255,1));
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow:hidden;
  position:relative;
  min-height: 320px;
}
.hero-media img{
  width:100%; height:100%;
  object-fit: cover;
}
.hero-media:after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(255,122,0,.08), transparent 42%);
  pointer-events:none;
}

/* =========================
   Cards / Grids
   ========================= */
.grid3{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px}
.grid4{display:grid; grid-template-columns: repeat(4, 1fr); gap:14px}

.card{
  border:1px solid var(--line);
  background: #fff;
  border-radius: var(--radius);
  padding:18px;
  box-shadow: var(--shadow);
}
.card h3{
  margin:0 0 8px;
  font-size: var(--h3);
  font-weight: 900;
  letter-spacing: -.2px;
}
.card p{
  margin:0;
  color: var(--muted);
  font-weight: 600;
}

/* Accent cards */
.card.orange{
  background: linear-gradient(180deg, rgba(255,122,0,.10), #fff 55%);
}
.card.green{
  background: linear-gradient(180deg, rgba(20,184,106,.10), #fff 55%);
}

/* =========================
   Category tiles (photo)
   ========================= */
.cats{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:14px;
}

.cat{
  border:1px solid var(--line);
  background:#fff;
  border-radius: 22px;
  overflow:hidden;
  box-shadow: var(--shadow);
  transition: .18s ease;
  position:relative;
}
.cat:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 40px rgba(16,18,25,.10);
}
.cat .img{
  aspect-ratio: 1 / 1;      /* square tile */
  background:#ffffff;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:10px;
}

.cat .img img{
  width:100%;
  height:100%;
  object-fit: contain;       /* no cutting */
  border-radius: 16px;
}

.cat .img:after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 35%, rgba(255,122,0,.14));
}
.cat .body{
  padding:14px 14px 16px;
}
.cat .title{
  margin:0;
  font-weight: 900;
  letter-spacing: -.2px;
  font-size: 15px;
}
.cat .hint{
  margin:6px 0 0;
  color: rgba(16,18,25,.62);
  font-weight: 600;
  font-size: 13px;
}

/* Make the 7 tiles look balanced */


/* =========================
   Info strip
   ========================= */
.info-strip{
  border:1px solid rgba(255,122,0,.22);
  background: linear-gradient(90deg, rgba(255,122,0,.10), rgba(20,184,106,.08));
  border-radius: 22px;
  padding:16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap: wrap;
}
.info-strip .left{
  display:flex; flex-direction:column; gap:4px;
}
.info-strip .left .strong{
  font-weight: 900;
}
.info-strip .left .small{
  color: rgba(16,18,25,.72);
  font-weight: 600;
  font-size: 13px;
}

/* =========================
   Forms
   ========================= */
.form{display:grid; gap:10px}
label{
  font-weight: 900;
  font-size: 13px;
  color: rgba(16,18,25,.82);
}
input, textarea{
  width:100%;
  border-radius: 16px;
  border:1px solid var(--line);
  background:#fff;
  padding:12px 12px;
  font-family: inherit;
  font-weight: 600;
  outline:none;
}
input:focus, textarea:focus{
  border-color: rgba(255,122,0,.42);
  box-shadow: 0 0 0 5px rgba(255,122,0,.10);
}
textarea{min-height:130px; resize:vertical}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:10px}
.helper{font-size:13px; color: rgba(16,18,25,.62); font-weight: 600}

/* =========================
   Legal pages
   ========================= */
.legal h1{
  font-size: clamp(32px, 3.2vw, 44px);
  font-weight: 900;
  letter-spacing: -0.8px;
}
.legal h2{
  font-size: 18px;
  font-weight: 900;
  margin-top: 18px;
}
.legal p, .legal li{
  color: rgba(16,18,25,.74);
  font-weight: 600;
}
.small{font-size:13px; color: rgba(16,18,25,.62); font-weight: 600}

/* =========================
   Footer
   ========================= */
.footer{
  margin-top:34px;
  border-top:1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,122,0,.05), rgba(20,184,106,.05));
  padding:22px 0;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr 1fr;
  gap:18px;
}
.footer h4{
  margin:0 0 10px;
  font-size: 14px;
  font-weight: 900;
  letter-spacing:.2px;
}
.footer a{color: rgba(16,18,25,.74); font-weight: 700}
.footer a:hover{color: var(--orange)}
.copy{
  margin-top:14px;
  padding-top:12px;
  border-top:1px solid var(--line);
  display:flex;
  justify-content:space-between;
  gap:10px;
  flex-wrap: wrap;
}
.copy .small{font-weight:700}

/* =========================
   Responsive
   ========================= */
@media (max-width: 980px){
  .hero-wrap{grid-template-columns: 1fr}
  .grid3{grid-template-columns: 1fr}
  .grid4{grid-template-columns: 1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .cats{grid-template-columns: 1fr 1fr}
  .cats .cat:nth-child(1),
  .cats .cat:nth-child(2){grid-column: span 2;}
  .form-row{grid-template-columns:1fr}
  .navlinks{display:none}
  .hamburger{display:block}
  .mobile-panel{display:block}
}

@media (max-width: 560px){
  .cats{grid-template-columns: 1fr}
  .cats .cat:nth-child(1),
  .cats .cat:nth-child(2){grid-column: span 1;}
  .grid4{grid-template-columns: 1fr}
}
/* ===== Mobile menu behavior fix (does not affect desktop) ===== */
.mobile-panel{
  display:none;
}
.mobile-panel.open{
  display:block;
}
@media (min-width: 981px){
  .mobile-panel{ display:none !important; }
}
/* ===========================
   MOBILE RESPONSIVE PACK (ADD AT END)
   =========================== */

/* Mobile menu hidden by default */
.mobile-panel{ display:none; }
.mobile-panel.open{ display:block; }

/* Smooth anchor scrolling (Categories page) */
html{ scroll-behavior: smooth; }

/* ---------- Tablet & Mobile (<= 980px) ---------- */
@media (max-width: 980px){

  /* Layout spacing */
  .container{ padding: 0 14px; }
  .section{ padding: 26px 0; }
  .hero{ padding: 28px 0 14px; }

  /* Header */
  .nav{ padding: 12px 0; }
  .navlinks{ display:none; }          /* hide desktop menu */
  .hamburger{ display:block; }        /* show hamburger */

  /* Hero stacks */
  .hero-wrap{ grid-template-columns: 1fr; }
  .hero-card{ padding: 20px; }
  .hero-media{ min-height: 220px; }

  /* Grids become 2 columns */
  .grid4{ grid-template-columns: 1fr 1fr; }
  .grid3{ grid-template-columns: 1fr; } /* cards look better 1 per row */

  /* Categories grid */
  .cats{ grid-template-columns: 1fr 1fr; }

  /* Forms */
  .form-row{ grid-template-columns: 1fr; }

  /* Footer */
  .footer-grid{ grid-template-columns: 1fr; }
}

/* ---------- Small Mobile (<= 560px) ---------- */
@media (max-width: 560px){

  /* Typography */
  h1{ font-size: 44px; line-height: 1.05; }
  .tagline{ font-size: 16px; }

  /* Categories become 1 column */
  .cats{ grid-template-columns: 1fr; }

  /* Make action strips wrap nicely */
  .info-strip{ gap: 10px; padding: 14px; }
  .info-strip .right{
    width:100%;
    display:flex;
    gap:10px;
    flex-wrap:wrap;
  }
  .info-strip .right .btn{
    flex:1;
    min-width: 140px;
    justify-content:center;
  }

  /* Buttons comfortable on mobile */
  .btn{ padding: 12px 14px; border-radius: 16px; }
  .btn.small{ padding: 10px 12px; border-radius: 14px; }
}

/* Desktop safety: never show mobile panel */
@media (min-width: 981px){
  .mobile-panel{ display:none !important; }
}
