/* === Avery-style theme === */

/* Make every container identical so nothing can "shift" */
.topbar .container,
.site-header .container,
.container {
  max-width: 1200px;     /* match header */
  margin: 0 auto;
  padding: 0 16px;       /* match header */
}

/* Keep layout stable whether the page scrolls or not */
html { scrollbar-gutter: stable; }           /* or: stable both-edges */


/* Brand palette (tweak as needed) */
:root{
  --purple:#6b3a8b;           /* top bar */
  --purple-dark:#5a2f74;
  --accent:#f0b429;            /* warm accent if you want */
  --text:#0f172a;
  --muted:#475569;
  --bg:#ffffff;
  --card:#ffffff;
  --border:#e5e7eb;
}

/* Base */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color:var(--text);
  background:var(--bg);
  font:16px/1.45 system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}
img{max-width:100%;height:auto;display:block}



/* ---------- Top purple bar ---------- */
.topbar{
  background:var(--purple);
  color:#fff;
  font-size:14px;
}
.topbar .container{
  display:flex;
  min-height:40px;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.topbar .left,
.topbar .center,
.topbar .right{display:flex;align-items:center;gap:10px;white-space:nowrap}
.topbar .center{justify-content:center;flex:1}
.topbar .right img{height:20px; width:auto;}

/* ---------- Site header (logo + nav) ---------- */
.site-header{
  background:#fff;
  border-bottom:1px solid var(--border);
}
.site-header .container{
  display:flex;
  align-items:center;
  gap:28px;
  min-height:86px;
}
.logo{display:inline-flex;align-items:center;gap:10px;text-decoration:none}
.logo img{height:62px; width:auto}          /* adjust if your logo needs smaller/larger */
.logo span{display:none}                    /* keep text accessible if you like */

.main-nav{margin-left:auto}
.main-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:28px;align-items:center}

/* ---- Unified nav link + center-out underline (hover + active) ---- */
.site-header .main-nav a{
  position:relative;
  display:inline-block;
  text-decoration:none;
  color:#4b5563;            /* subtle grey like Avery */
  padding:8px 2px 10px;     /* bottom padding = room for underline */
  transition:color .2s ease;
  font-weight:500;
}
.site-header .main-nav a:hover{ color:var(--purple); }
.site-header .main-nav a.is-active,
.site-header .main-nav a[aria-current="page"]{ color:var(--purple); }

.site-header .main-nav a::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:0;                 /* same vertical position for hover + active */
  width:100%;
  height:2px;
  background: currentColor; /* matches link color automatically */
  transform: translateX(-50%) scaleX(0);
  transform-origin: 50% 50%;
  transition: transform .25s ease;
  opacity:.9;
}

/* show line on hover/focus and keep it for the active page */
.site-header .main-nav a:hover::after,
.site-header .main-nav a:focus-visible::after,
.site-header .main-nav a.is-active::after,
.site-header .main-nav a[aria-current="page"]::after{
  transform: translateX(-50%) scaleX(1);
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;
  padding:10px 14px;
  border-radius:10px;
  background:var(--purple);
  color:#fff; text-decoration:none;
  border:1px solid transparent;
  cursor:pointer;
}
.btn:hover{filter:brightness(1.05)}
.btn.secondary{background:#fff;color:var(--purple);border-color:var(--border)}

/* ---------- Cards / tables (for dashboard) ---------- */
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:16px;
  box-shadow:0 4px 10px rgba(0,0,0,.03);
  margin:20px 0;
}
.table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  overflow:hidden;
  border:1px solid var(--border);
  border-radius:12px;
}
.table thead th{
  background:#f8fafc;
  text-align:left;
  font-weight:600;
  padding:10px;
  border-bottom:1px solid var(--border);
}
.table tbody td{
  padding:10px;
  border-bottom:1px solid var(--border);
}
.table tbody tr:last-child td{border-bottom:none}


/* Status badges */
.badge{
  display:inline-block;
  padding:4px 8px;
  border-radius:999px;
  font-size:12px;
  border:1px solid var(--border);
  background:#f8fafc;
}
.badge.complete{background:#dcfce7;border-color:#16a34a;color:#065f46}
.badge.booked{background:#e0f2fe;border-color:#0284c7;color:#075985}
.badge.quoted{background:#fef9c3;border-color:#ca8a04;color:#713f12}
.badge.received{background:#f1f5f9;border-color:#475569;color:#0f172a}
.badge.logged{background:#f8fafc;border-color:#cbd5e1;color:#334155}

/* NEW: On hold */
.badge--on-hold   { background:#fff7ed; border:1px solid #fed7aa; color:#9a3412; }

/* Optional: unknown fallback */
.badge--unknown   { background:#f3f4f6; border:1px solid #e5e7eb; color:#374151; }

/* ---------- Login card ---------- */
.fullscreen-center{min-height:calc(100vh - 126px);display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{width:100%;max-width:460px;padding:26px}
.login-card h1{margin:0 0 6px;font-size:22px}
.login-card p{margin:0 0 16px;color:var(--muted)}
.form-row{margin-bottom:12px}
label{display:block;margin-bottom:6px;color:var(--muted);font-size:14px}
input[type="email"],input[type="password"]{
  width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:10px;outline:none;
}
input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(240,180,41,.25)}

/* ---------- Responsive tweaks ---------- */
@media (max-width: 980px){
  .topbar .center{display:none}           /* hide center blurb on small screens */
  .site-header .container{gap:16px; min-height:74px}
  .logo img{height:48px}
  .main-nav ul{gap:18px}
}
@media (max-width: 720px){
  .main-nav ul{gap:14px;flex-wrap:wrap}
}

@media (max-width: 760px){
  .main-nav ul{ flex-wrap:wrap; gap:8px }
  .main-nav a{ padding:6px 10px; display:inline-block }
  .topbar .container { flex-direction:column; gap:6px }
}

/* ---------- Footer ---------- */
.site-footer {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: #7c3aed; /* violet theme */
  color: #fff;
  text-align: center;
  padding: 8px 12px;
  font-size: 14px;
  font-weight: 500;
  z-index: 999;
  box-shadow: 0 -2px 6px rgba(0,0,0,.1);
}
body {
  padding-bottom: 50px; /* prevent content being hidden behind footer */
}
