/* =====================================================================
   Murugan Temple — stylesheet
   Palette: saffron / maroon / gold on warm cream
   ===================================================================== */
:root{
  --saffron:#e8761a;
  --saffron-dark:#c85e0c;
  --maroon:#7a1f1f;
  --maroon-dark:#5c1414;
  --gold:#d4af37;
  --cream:#fff8ec;
  --cream-2:#fdeed6;
  --ink:#2b1d12;
  --muted:#7c6a58;
  --line:#ecd9bc;
  --green:#2e7d32;
  --red:#c62828;
  --amber:#ef6c00;
  --shadow:0 6px 22px rgba(122,31,31,.12);
  --radius:14px;
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:'Poppins','Noto Sans Tamil',system-ui,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.55;
}
:lang(ta), [lang="ta"]{font-family:'Noto Sans Tamil','Poppins',sans-serif;}
a{color:var(--maroon);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{font-weight:700;line-height:1.2;margin:.2em 0 .5em}

/* ---------- generic layout ---------- */
.container{max-width:1120px;margin:0 auto;padding:24px 18px}

/* ---------- buttons ---------- */
.btn{display:inline-block;border:none;cursor:pointer;border-radius:10px;
  padding:11px 20px;font:inherit;font-weight:600;color:#fff;
  background:linear-gradient(135deg,var(--saffron),var(--saffron-dark));
  box-shadow:0 3px 10px rgba(200,94,12,.3);transition:.15s}
.btn:hover{transform:translateY(-1px);text-decoration:none;filter:brightness(1.05)}
.btn.ghost{background:transparent;color:var(--maroon);border:1.5px solid var(--maroon);box-shadow:none}
.btn.green{background:linear-gradient(135deg,#43a047,#2e7d32);box-shadow:0 3px 10px rgba(46,125,50,.3)}
.btn.red{background:linear-gradient(135deg,#e53935,#c62828);box-shadow:0 3px 10px rgba(198,40,40,.3)}
.btn.block{display:block;width:100%;text-align:center}
.btn.sm{padding:6px 14px;font-size:.85rem}

/* =====================================================================
   PUBLIC SITE
   ===================================================================== */
.site-header{background:linear-gradient(135deg,var(--maroon),var(--maroon-dark));color:#fff}
.site-top{max-width:1120px;margin:0 auto;display:flex;align-items:center;
  justify-content:space-between;padding:14px 18px;gap:14px;flex-wrap:wrap}
.site-top .logo{display:flex;align-items:center;gap:12px}
.site-top .om-badge{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 30% 30%,var(--gold),var(--saffron-dark));
  font-size:1.8rem;color:var(--maroon-dark);box-shadow:0 0 0 3px rgba(212,175,55,.5)}
.site-top h1{margin:0;font-size:1.25rem}
.site-top .sub{font-size:.8rem;opacity:.85}
.site-top .top-actions{display:flex;gap:10px;align-items:center}
.langbtn{border:1.5px solid var(--gold);color:#fff;border-radius:8px;padding:6px 12px;font-weight:600;font-size:.85rem}
.langbtn:hover{background:var(--gold);color:var(--maroon-dark);text-decoration:none}

.site-nav{background:var(--saffron)}
.site-nav ul{max-width:1120px;margin:0 auto;display:flex;flex-wrap:wrap;
  list-style:none;padding:0 10px;gap:2px}
.site-nav a{display:block;color:#fff;padding:12px 18px;font-weight:600;font-size:.92rem}
.site-nav a:hover{background:var(--saffron-dark);text-decoration:none}

.hero{position:relative;background:
  linear-gradient(rgba(92,20,20,.55),rgba(92,20,20,.65)),
  repeating-linear-gradient(45deg,#8a2a12,#8a2a12 26px,#7a1f1f 26px,#7a1f1f 52px);
  color:#fff;text-align:center;padding:74px 18px}
.hero .om{font-size:3rem;color:var(--gold)}
.hero h2{font-size:2.1rem;margin:.2em 0}
.hero p{max-width:680px;margin:0 auto 22px;font-size:1.05rem;opacity:.95}

.cards{max-width:1120px;margin:-40px auto 0;padding:0 18px;display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;position:relative;z-index:10;}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow)}
.card h3{color:var(--maroon);display:flex;align-items:center;gap:8px}
.card .icon{font-size:1.4rem}

.section{max-width:1120px;margin:40px auto;padding:0 18px}
.section h2{color:var(--maroon);border-bottom:3px solid var(--gold);
  display:inline-block;padding-bottom:6px}
.about-box{background:var(--cream-2);border-left:5px solid var(--saffron);
  border-radius:8px;padding:20px 24px}

.site-footer{background:var(--maroon-dark);color:#f3dcc0;margin-top:50px;
  text-align:center;padding:24px 18px;font-size:.9rem}

/* =====================================================================
   STAFF APP
   ===================================================================== */
.topbar{background:linear-gradient(135deg,var(--maroon),var(--maroon-dark));
  color:#fff;display:flex;align-items:center;gap:20px;padding:10px 22px;flex-wrap:wrap}
.topbar .brand{display:flex;align-items:center;gap:10px}
.topbar .om{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 30% 30%,var(--gold),var(--saffron-dark));
  font-size:1.4rem;color:var(--maroon-dark)}
.topbar .brand strong{display:block;font-size:1rem}
.topbar .brand small{opacity:.8;font-size:.72rem}
.topnav{display:flex;gap:4px;margin-left:8px;flex-wrap:wrap}
.topnav a{color:#fff;padding:8px 14px;border-radius:8px;font-weight:600;font-size:.9rem}
.topnav a:hover,.topnav a.active{background:rgba(255,255,255,.15);text-decoration:none}
.usermenu{margin-left:auto;display:flex;align-items:center;gap:12px;font-size:.85rem}
.usermenu .who{opacity:.9}
.usermenu .logout{color:#ffd9a8;font-weight:600}

.appfoot{text-align:center;color:var(--muted);padding:24px;font-size:.85rem}

/* ---------- stat cards ---------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 20px;box-shadow:var(--shadow)}
.stat .label{color:var(--muted);font-size:.82rem}
.stat .value{font-size:1.7rem;font-weight:700;color:var(--maroon)}
.stat.amber .value{color:var(--amber)}
.stat.green .value{color:var(--green)}
.stat.red .value{color:var(--red)}

/* ---------- panels & tables ---------- */
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:22px;margin-bottom:22px}
.panel h2{color:var(--maroon);margin-top:0;font-size:1.2rem}
table{width:100%;border-collapse:collapse;font-size:.92rem}
th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:top}
th{color:var(--maroon);font-weight:600;background:var(--cream-2)}
tr:hover td{background:var(--cream)}
.right{text-align:right}

/* ---------- status pills ---------- */
.pill{display:inline-block;padding:3px 11px;border-radius:999px;font-size:.78rem;font-weight:600}
.pill.pending{background:#fff3e0;color:var(--amber)}
.pill.approved{background:#e8f5e9;color:var(--green)}
.pill.rejected{background:#ffebee;color:var(--red)}
.pill.method{background:#ede7f6;color:#5e35b1}

/* ---------- forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
label{font-weight:600;font-size:.88rem;color:var(--ink)}
input,select,textarea{font:inherit;padding:10px 12px;border:1.5px solid var(--line);
  border-radius:9px;background:#fffdf8;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--saffron)}
textarea{resize:vertical;min-height:70px}
.form-actions{display:flex;gap:12px;margin-top:18px}

/* ---------- AI toolbar (voice + scan) ---------- */
.ai-bar{display:flex;gap:12px;flex-wrap:wrap;background:var(--cream-2);
  border:1px dashed var(--saffron);border-radius:12px;padding:14px;margin-bottom:20px}
.ai-status{flex-basis:100%;font-size:.88rem;color:var(--maroon);min-height:1.2em}
.mic.recording{animation:pulse 1s infinite}
@keyframes pulse{0%,100%{filter:none}50%{filter:brightness(1.3)}}
.hint{font-size:.82rem;color:var(--muted)}

/* ---------- login ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--maroon),var(--maroon-dark))}
.login-card{background:#fff;border-radius:18px;padding:34px;width:min(380px,92vw);
  box-shadow:0 18px 50px rgba(0,0,0,.3);text-align:center}
.login-card .om{font-size:2.6rem;color:var(--saffron)}
.login-card h1{color:var(--maroon);font-size:1.3rem}
.login-card .field{text-align:left;margin-bottom:14px}
.alert{padding:11px 14px;border-radius:9px;margin-bottom:16px;font-size:.9rem}
.alert.error{background:#ffebee;color:var(--red)}
.alert.ok{background:#e8f5e9;color:var(--green)}
.alert.info{background:#fff3e0;color:var(--amber)}
.demo-note{font-size:.78rem;color:var(--muted);margin-top:18px;line-height:1.7}

@media(max-width:680px){
  .form-grid{grid-template-columns:1fr}
  .site-top h1{font-size:1.05rem}
}
