/* ============================================================================
   Consulate General of India, Dubai — Passport & Consular Services
   Clean, institutional, white. Navy primary, Indian tricolour accents.
   ========================================================================== */

:root{
  --navy:#0b3d91;          /* Indian government navy */
  --navy-dark:#082f6f;
  --saffron:#ff9933;       /* tricolour saffron */
  --green:#138808;         /* tricolour green */
  --ink:#1f2733;           /* body text */
  --muted:#5b6472;         /* secondary text */
  --line:#e2e6ec;          /* hairlines */
  --bg:#ffffff;            /* page background */
  --band:#f4f6f9;          /* light section band */
  --band-2:#eef2f7;
  --ok:#137333; --ok-bg:#e6f4ea;
  --err:#b3261e; --err-bg:#fce8e6;
  --warn:#8a5a00; --warn-bg:#fff4e0;
  --radius:10px;
  --radius-sm:8px;
  --shadow:0 1px 3px rgba(16,24,40,.08),0 1px 2px rgba(16,24,40,.06);
  --shadow-md:0 6px 18px -6px rgba(16,24,40,.18);
  --sans:-apple-system,"Segoe UI",Roboto,system-ui,"Helvetica Neue",Arial,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);
  min-height:100vh;-webkit-font-smoothing:antialiased;line-height:1.55;
}
a{color:var(--navy);text-decoration:none}
a:hover{text-decoration:underline}

/* ---- Tricolour strip + masthead --------------------------------------- */
.tricolour{display:flex;height:5px}
.tricolour span{flex:1}
.t-saffron{background:var(--saffron)}
.t-white{background:#fff}
.t-green{background:var(--green)}

.masthead{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.85rem 1.5rem;background:#fff;border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;box-shadow:var(--shadow);
}
.brand{display:flex;align-items:center;gap:.85rem;color:var(--ink)}
.brand:hover{text-decoration:none}
.ashoka{flex:none;display:block}
.brand-emblem{flex:none;display:block;height:48px;width:auto}
.brand-text{display:flex;flex-direction:column;line-height:1.2}
.brand-org{font-weight:700;font-size:1.1rem;color:var(--navy);letter-spacing:.2px}
.brand-sub{font-size:.82rem;color:var(--muted)}
.mast-nav{display:flex;align-items:center;gap:1.3rem}
.nav-link{color:var(--navy);font-weight:600;font-size:.92rem}
.nav-link:hover{text-decoration:underline}
.nav-admin{color:var(--muted)}
.who{color:var(--muted);font-size:.9rem;font-weight:600}

/* ---- Layout ----------------------------------------------------------- */
.container{max-width:960px;margin:0 auto;padding:2.2rem 1.5rem 3rem}
h1{font-size:clamp(1.7rem,3.4vw,2.15rem);font-weight:700;color:var(--navy);margin:.2rem 0 .6rem;line-height:1.2}
h2{font-size:1.3rem;font-weight:700;color:var(--ink);margin:2rem 0 .8rem;padding-bottom:.4rem;border-bottom:2px solid var(--line)}
h3{font-size:1.1rem;font-weight:600;color:var(--navy);margin:.1rem 0 .4rem}
.lead{color:var(--muted);font-size:1.05rem;max-width:65ch}
.muted{color:var(--muted)}
.eyebrow{display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--saffron);margin-bottom:.35rem}

/* ---- Buttons ---------------------------------------------------------- */
.cta{display:flex;gap:.75rem;flex-wrap:wrap;margin:1.4rem 0}
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.62rem 1.15rem;border-radius:var(--radius-sm);
  border:1px solid var(--navy);background:#fff;color:var(--navy);font:600 .96rem var(--sans);cursor:pointer;
  transition:background .15s,color .15s,box-shadow .15s}
.btn:hover{background:var(--band);text-decoration:none;box-shadow:var(--shadow)}
.btn.primary{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn.primary:hover{background:var(--navy-dark);color:#fff}
.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}

/* ---- Cards ------------------------------------------------------------ */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin-top:1rem}
.card{background:#fff;border:1px solid var(--line);border-top:3px solid var(--saffron);border-radius:var(--radius);
  padding:1.2rem;box-shadow:var(--shadow);transition:box-shadow .18s,transform .18s}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.card h3{margin-top:0}
.card .card-meta{color:var(--muted);font-size:.9rem;margin:.35rem 0 1rem;line-height:1.55}
.card-kicker{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--green);margin-bottom:.4rem}
.card-link{display:block;color:var(--ink);border-top-color:var(--navy)}
.card-link:hover{text-decoration:none}
.card-link .card-meta{margin-bottom:0;color:var(--navy);font-weight:600}

/* ---- Forms ------------------------------------------------------------ */
.form{max-width:560px;display:flex;flex-direction:column;gap:1rem;margin-top:1.4rem}
.form label{display:flex;flex-direction:column;gap:.35rem;font-weight:600;font-size:.92rem;color:var(--ink)}
.form .hint{font-weight:400;font-size:.8rem;color:var(--muted);margin-top:-.1rem}
.form input,.form select,.manual input{
  padding:.62rem .75rem;border:1px solid #c7ced8;border-radius:var(--radius-sm);
  background:#fff;color:var(--ink);font:400 1rem var(--sans);transition:border-color .15s,box-shadow .15s}
.form input:focus,.form select:focus,.manual input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(11,61,145,.15)}
.form input::placeholder{color:#9aa3af}
fieldset{border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem;margin:0;background:var(--band)}
legend{font-weight:700;padding:0 .45rem;color:var(--navy)}

/* ---- Flash ------------------------------------------------------------ */
.flash{padding:.8rem 1rem;border-radius:var(--radius-sm);margin-bottom:1.3rem;font-weight:500;border:1px solid transparent}
.flash.error{background:var(--err-bg);color:var(--err);border-color:#f6c4c0}
.flash.ok{background:var(--ok-bg);color:var(--ok);border-color:#b7dfc4}
.flash.warn{background:var(--warn-bg);color:var(--warn);border-color:#f2d79a}

/* ---- Calendar --------------------------------------------------------- */
.calendar{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:.5rem;margin-top:.6rem}
.day{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.6rem .4rem;
  border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;cursor:pointer;font:inherit;color:var(--ink);
  transition:border-color .15s,background .15s}
.day .dow{font-size:.72rem;color:var(--muted);text-transform:uppercase}
.day .dnum{font-size:1.35rem;font-weight:700;line-height:1;color:var(--navy)}
.day .rem{font-size:.68rem;color:var(--green);font-weight:600}
.day.open:hover{border-color:var(--navy);background:var(--band)}
.day.selected{border-color:var(--navy);background:#eaf0fb;box-shadow:0 0 0 2px rgba(11,61,145,.2)}
.day.closed,.day.full,.day.holiday,.day.notopen{opacity:.5;cursor:default}
.day.notopen{opacity:.4;border-style:dashed}
.day.holiday{background:#fff7ed;border-color:#fdba74}
.day.holiday .rem{color:#b45309;font-weight:600}
/* Fully-booked day: red number on a mild red background */
.day.full{opacity:1;background:var(--err-bg);border-color:#f0b3ae}
.day.full .dnum,.day.full .rem{color:var(--err)}
/* Weekends (Sat/Sun) are shown in red — placed last so red wins over the
   dimmed "closed" styling weekend days otherwise pick up. */
.day.weekend{opacity:1}
.day.weekend .dow,.day.weekend .dnum,.day.weekend .rem{color:var(--err)}

.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(112px,1fr));gap:.5rem;margin-top:.5rem}
.slot{padding:.6rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;cursor:pointer;
  font:600 .95rem var(--sans);text-align:center;color:var(--ink);transition:border-color .15s,background .15s}
.slot .rem{display:block;font-size:.68rem;color:var(--muted);font-weight:400;margin-top:.15rem}
.slot:hover{border-color:var(--navy);background:var(--band)}
.slot.selected{border-color:var(--navy);background:#eaf0fb}
.slot.full{opacity:.45;cursor:default}

/* ---- Ticket / confirmation -------------------------------------------- */
.ticket{max-width:560px;margin:0 auto;text-align:center;background:#fff;color:var(--ink);
  border:1px solid var(--line);border-top:4px solid var(--saffron);border-radius:var(--radius);
  padding:2rem;box-shadow:var(--shadow-md);position:relative}
.ticket h1{font-size:1.65rem;margin-top:0;color:var(--green)}
.ticket .lead{color:var(--muted);margin:0 auto 1.2rem}
.qrbox{display:inline-block;padding:.9rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.stamp{display:none} /* no decorative stamp in the official look */
.details{width:100%;border-collapse:collapse;margin:1.3rem 0 .6rem;text-align:left}
.details th{width:38%;color:var(--muted);padding:.55rem .2rem;border-bottom:1px solid var(--line);font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em}
.details td{padding:.55rem .2rem;border-bottom:1px solid var(--line);color:var(--ink);font-weight:600}
.ticket .cta{justify-content:center}
.ticket .notes{text-align:left;margin-top:1.3rem;padding:1rem 1.15rem;border:1px solid var(--line);border-left:4px solid var(--saffron);border-radius:var(--radius-sm);background:var(--band)}
.ticket .notes-title{margin:0 0 .5rem;font-weight:700;color:var(--navy);font-size:.95rem}
.ticket .notes ol{margin:0;padding-left:1.2rem;color:var(--ink)}
.ticket .notes li{margin:.35rem 0;line-height:1.5;font-size:.94rem}
.ticket .notes strong{color:var(--navy)}
.ticket .muted{color:var(--muted)}

/* ---- Tables (admin) --------------------------------------------------- */
table.grid{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.92rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
table.grid th,table.grid td{padding:.65rem .7rem;border-bottom:1px solid var(--line);text-align:left}
table.grid th{background:var(--band);color:var(--navy);font-weight:700;text-transform:uppercase;font-size:.74rem;letter-spacing:.05em}
table.grid tr:last-child td{border-bottom:none}
table.grid tr:hover td{background:var(--band)}
.row{display:flex;gap:1rem;flex-wrap:wrap}
.row>*{flex:1;min-width:130px}
.pill{display:inline-flex;align-items:center;gap:.3rem;padding:.15rem .55rem;border-radius:999px;font-size:.75rem;font-weight:600}
.pill::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.pill.on{background:var(--ok-bg);color:var(--ok)}
.pill.off{background:var(--band,#eef1f6);color:var(--muted)}

/* ---- Account / MFA ---------------------------------------------------- */
.mfa-method{padding:1rem 0;border-top:1px solid var(--line)}
.mfa-method:first-of-type{border-top:none;padding-top:.4rem}
.mfa-head{display:flex;align-items:center;gap:.6rem;margin-bottom:.35rem}
.mfa-head strong{font-size:1rem;color:var(--ink)}
.mfa-qr{margin:.8rem 0;padding:.7rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);display:inline-block}
.mfa-qr img{display:block}
.mfa-nudge a{font-weight:600;white-space:nowrap}

/* ---- Footer ----------------------------------------------------------- */
.foot{border-top:1px solid var(--line);background:var(--band);margin-top:2.5rem}
.foot-inner{max-width:960px;margin:0 auto;padding:1.6rem 1.5rem;text-align:center}
.foot-org{font-weight:700;color:var(--navy);margin:0 0 .3rem}
.foot-note{color:var(--muted);font-size:.82rem;margin:0;max-width:70ch;margin-left:auto;margin-right:auto;line-height:1.6}
.foot-links{display:flex;flex-wrap:wrap;justify-content:center;gap:.4rem 1.1rem;margin:0 0 1rem;font-size:.82rem}
.foot-links a{color:var(--navy)}
.prose{max-width:75ch}
.prose h1{margin-bottom:1rem}
.prose h3{margin:1.5rem 0 .4rem;color:var(--navy);font-size:1.05rem}
.prose p{margin:.7rem 0;line-height:1.7}
.prose ul{margin:.7rem 0 .7rem 1.2rem;line-height:1.7}
.prose li{margin:.25rem 0}
.prose a{color:var(--navy)}

/* subtle staggered reveal on load */
.reveal>*{opacity:0;transform:translateY(8px);animation:rise .45s ease forwards}
.reveal>*:nth-child(1){animation-delay:.03s}.reveal>*:nth-child(2){animation-delay:.09s}
.reveal>*:nth-child(3){animation-delay:.15s}.reveal>*:nth-child(4){animation-delay:.21s}
.reveal>*:nth-child(5){animation-delay:.27s}.reveal>*:nth-child(6){animation-delay:.33s}
@keyframes rise{to{opacity:1;transform:none}}

@media (max-width:640px){
  .masthead{padding:.7rem 1rem;flex-wrap:wrap}
  .brand-org{font-size:1rem}
  .container{padding:1.6rem 1.1rem 2.5rem}
  .mast-nav{gap:1rem}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important}}

/* ---- Admin dashboard: overview stat cards ---- */
.stats{margin:.25rem 0 1.5rem}
.stats-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:.8rem}
.stats-actions{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.stats-actions .muted{font-size:.8rem;white-space:nowrap}
.stats-actions .btn{padding:.45rem .8rem;font-size:.85rem}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(148px,1fr));gap:.85rem}
.stat-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1.15rem;box-shadow:var(--shadow);transition:box-shadow .15s ease}
.stat-card:hover{box-shadow:var(--shadow-md)}
.stat-num{font-size:2rem;font-weight:700;line-height:1.05;color:var(--navy);font-variant-numeric:tabular-nums}
.stat-num.ok{color:#137333}
.stat-num.warn{color:#b45309}
.stat-lbl{margin-top:.45rem;font-size:.72rem;font-weight:600;letter-spacing:.4px;text-transform:uppercase;color:var(--muted)}
