/* Memmotts Workshop Management — POC styling.
   Light, clean admin UI with Memmotts red accents. */

:root{
  --red:#e63946;
  --red-dark:#c1121f;
  --ink:#1a1a2e;
  --slate:#475569;
  --muted:#64748b;
  --line:#e2e8f0;
  --bg:#f1f5f9;
  --card:#ffffff;
  --green:#16a34a;
  --green-bg:#dcfce7;
  --amber:#b45309;
  --amber-bg:#fef3c7;
  --blue:#2563eb;
  --blue-bg:#dbeafe;
  --radius:12px;
  --shadow:0 1px 3px rgba(15,23,42,.08), 0 1px 2px rgba(15,23,42,.04);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--ink);line-height:1.55;font-size:14px;}
a{color:var(--red);text-decoration:none;}
a:hover{text-decoration:underline;}
code{background:#f1f5f9;padding:1px 6px;border-radius:5px;font-size:.85em;}
.mm-muted{color:var(--muted);font-size:.85em;}

/* ---- Auth screens (login / install) ---- */
.mm-auth-body{display:flex;align-items:center;justify-content:center;min-height:100vh;
  background:linear-gradient(135deg,#1a1a2e 0%,#16213e 60%,#0d0d1a 100%);padding:2rem;}
.mm-auth-card{background:var(--card);border-radius:16px;padding:2.5rem;max-width:420px;width:100%;
  box-shadow:0 20px 50px rgba(0,0,0,.35);position:relative;overflow:hidden;}
.mm-auth-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--red);}
.mm-auth-card h1{font-size:1.5rem;font-weight:800;margin:.25rem 0 1rem;}
.mm-auth-card .mm-brand{margin-bottom:1.25rem;}

/* ---- Brand ---- */
.mm-brand{font-size:1.15rem;font-weight:800;letter-spacing:-.02em;color:var(--ink);display:inline-block;}
.mm-brand span{color:var(--red);}
.mm-brand:hover{text-decoration:none;}

/* ---- Topbar / nav ---- */
.mm-app{display:flex;flex-direction:column;min-height:100vh;}
.mm-topbar{display:flex;align-items:center;gap:1.5rem;background:var(--card);border-bottom:1px solid var(--line);
  padding:0 1.5rem;height:60px;position:sticky;top:0;z-index:50;flex-wrap:wrap;}
.mm-nav{display:flex;align-items:center;gap:.25rem;flex:1;flex-wrap:wrap;}
.mm-nav a{color:var(--slate);font-weight:600;font-size:.86rem;padding:.45rem .75rem;border-radius:8px;}
.mm-nav a:hover{background:#f1f5f9;text-decoration:none;}
.mm-nav a.is-active{background:rgba(230,57,70,.1);color:var(--red);}
.mm-nav-group{display:flex;align-items:center;gap:.25rem;margin-left:.5rem;padding-left:.75rem;border-left:1px solid var(--line);}
.mm-user{display:flex;align-items:center;gap:.6rem;}
.mm-user-name{font-weight:600;font-size:.86rem;}
.mm-logout{font-size:.82rem;font-weight:600;color:var(--muted);}
.mm-main{flex:1;max-width:1160px;width:100%;margin:0 auto;padding:1.75rem 1.5rem;}
.mm-footer{max-width:1160px;width:100%;margin:0 auto;padding:1.25rem 1.5rem;display:flex;justify-content:space-between;
  gap:1rem;flex-wrap:wrap;color:var(--muted);font-size:.82rem;border-top:1px solid var(--line);}

/* ---- Page heading ---- */
.mm-page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;}
.mm-page-head h1{font-size:1.5rem;font-weight:800;letter-spacing:-.02em;}
.mm-page-head p{color:var(--muted);margin-top:.15rem;}

/* ---- Cards ---- */
.mm-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem;}
.mm-card + .mm-card{margin-top:1.25rem;}
.mm-card h2{font-size:1.05rem;font-weight:700;margin-bottom:1rem;}
.mm-card h3{font-size:.95rem;font-weight:700;margin-bottom:.75rem;}
.mm-grid{display:grid;gap:1.25rem;}
.mm-grid-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));}
.mm-grid-3{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));}
.mm-grid-4{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));}

/* ---- Stat tiles ---- */
.mm-stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem 1.25rem;box-shadow:var(--shadow);}
.mm-stat .n{font-size:1.9rem;font-weight:800;letter-spacing:-.03em;line-height:1;}
.mm-stat .l{color:var(--muted);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-top:.4rem;}
.mm-stat.is-accent{border-top:3px solid var(--red);}

/* ---- Tables ---- */
.mm-table{width:100%;border-collapse:collapse;font-size:.88rem;}
.mm-table th{text-align:left;color:var(--muted);font-weight:600;font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;
  padding:.6rem .75rem;border-bottom:1px solid var(--line);}
.mm-table td{padding:.7rem .75rem;border-bottom:1px solid var(--line);vertical-align:middle;}
.mm-table tr:last-child td{border-bottom:none;}
.mm-table tr:hover td{background:#fafbfc;}
.mm-table .num{text-align:right;font-variant-numeric:tabular-nums;}
.mm-empty{text-align:center;color:var(--muted);padding:2.5rem 1rem;}

/* ---- Badges ---- */
.mm-badge{display:inline-block;padding:.2rem .6rem;border-radius:100px;font-size:.72rem;font-weight:700;letter-spacing:.02em;white-space:nowrap;}
.mm-badge-role{background:#ede9fe;color:#6d28d9;}
.mm-badge-loc{background:var(--blue-bg);color:var(--blue);}
.mm-st-new{background:var(--blue-bg);color:var(--blue);}
.mm-st-contacted{background:#e0e7ff;color:#4338ca;}
.mm-st-scheduled{background:var(--amber-bg);color:var(--amber);}
.mm-st-in_progress{background:#ffedd5;color:#c2410c;}
.mm-st-completed{background:var(--green-bg);color:var(--green);}
.mm-st-cancelled{background:#f1f5f9;color:var(--muted);}

/* ---- Buttons ---- */
.mm-btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;font-family:inherit;font-size:.86rem;font-weight:700;
  padding:.55rem 1.1rem;border-radius:9px;border:1px solid var(--line);background:var(--card);color:var(--ink);cursor:pointer;
  transition:background .15s,border-color .15s,transform .05s;text-decoration:none;}
.mm-btn:hover{background:#f8fafc;text-decoration:none;}
.mm-btn:active{transform:translateY(1px);}
.mm-btn-primary{background:var(--red);border-color:var(--red);color:#fff;}
.mm-btn-primary:hover{background:var(--red-dark);border-color:var(--red-dark);}
.mm-btn-sm{padding:.35rem .7rem;font-size:.78rem;}
.mm-btn-block{width:100%;}
.mm-btn:disabled,.mm-btn.is-disabled{opacity:.55;cursor:not-allowed;}
.mm-btn-ghost{background:transparent;border-color:transparent;color:var(--muted);}

/* ---- Forms ---- */
.mm-form label{display:block;font-weight:600;font-size:.82rem;margin-bottom:.9rem;}
.mm-form input,.mm-form select,.mm-form textarea{display:block;width:100%;margin-top:.3rem;font-family:inherit;font-size:.9rem;
  padding:.55rem .7rem;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);}
.mm-form input:focus,.mm-form select:focus,.mm-form textarea:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(230,57,70,.12);}
.mm-form textarea{min-height:90px;resize:vertical;}
.mm-form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:0 1rem;}
.mm-inline-form{display:flex;gap:.5rem;align-items:flex-end;flex-wrap:wrap;}
.mm-checks{display:flex;gap:1.25rem;flex-wrap:wrap;margin-top:.3rem;}
.mm-checks label{display:flex;align-items:center;gap:.4rem;font-weight:600;margin:0;}
.mm-checks input{width:auto;margin:0;}

/* ---- Alerts ---- */
.mm-alert{padding:.8rem 1rem;border-radius:9px;margin-bottom:1.25rem;font-size:.88rem;border:1px solid transparent;}
.mm-alert-info{background:var(--blue-bg);color:#1e40af;border-color:#bfdbfe;}
.mm-alert-success{background:var(--green-bg);color:#15803d;border-color:#bbf7d0;}
.mm-alert-error{background:#fee2e2;color:#b91c1c;border-color:#fecaca;}
.mm-alert-warn{background:var(--amber-bg);color:var(--amber);border-color:#fde68a;}

/* ---- Xero / integration card ---- */
.mm-integration{display:flex;gap:1rem;align-items:flex-start;}
.mm-integration .ico{font-size:1.6rem;line-height:1;}
.mm-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:.4rem;vertical-align:middle;}
.mm-dot-ready{background:var(--amber);}
.mm-dot-on{background:var(--green);}

.mm-checklist{list-style:none;margin:1rem 0;display:flex;flex-direction:column;gap:.4rem;}
.mm-checklist li{color:var(--green);font-weight:600;font-size:.88rem;}

.mm-meta{display:grid;grid-template-columns:auto 1fr;gap:.4rem 1rem;font-size:.88rem;}
.mm-meta dt{color:var(--muted);font-weight:600;}
.mm-meta dd{font-weight:500;}

.mm-back{display:inline-block;color:var(--muted);font-weight:600;font-size:.82rem;margin-bottom:1rem;}
.mm-row-actions{display:flex;gap:.4rem;flex-wrap:wrap;}

@media(max-width:720px){
  .mm-topbar{height:auto;padding:.75rem 1rem;}
  .mm-nav-group{margin-left:0;padding-left:0;border-left:none;}
}
