/* =====================================================
   PAN Seva Kendra — Stylesheet
   Aesthetic: official / trustworthy — deep ink navy with
   warm gold accents, crisp document-like surfaces.
   ===================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Hanken+Grotesk:wght@400;500;600;700;800&display=swap');

:root{
  --ink:#0d1f3c;
  --ink-2:#13284a;
  --ink-soft:#33486b;
  --paper:#f5f1e8;
  --paper-2:#fbf8f1;
  --card:#ffffff;
  --gold:#bf9340;
  --gold-deep:#9a722a;
  --gold-soft:#f3e7c8;
  --line:#e3ddcf;
  --ok:#1f7a4d;
  --ok-bg:#e3f3ea;
  --warn:#9a6a12;
  --warn-bg:#fbf0d4;
  --bad:#a52727;
  --bad-bg:#fae0e0;
  --muted:#6c7891;
  --radius:14px;
  --shadow:0 18px 40px -24px rgba(13,31,60,.45);
  --shadow-sm:0 6px 16px -10px rgba(13,31,60,.4);
  --font-display:'Fraunces',Georgia,serif;
  --font-body:'Hanken Grotesk',system-ui,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:
    radial-gradient(1200px 600px at 110% -10%, rgba(191,147,64,.10), transparent 60%),
    radial-gradient(900px 500px at -10% 0%, rgba(13,31,60,.06), transparent 55%),
    var(--paper);
  min-height:100vh;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}

/* ---------- Top bar ---------- */
.topbar{
  background:var(--ink);
  color:#fff;
  position:sticky;top:0;z-index:50;
  border-bottom:3px solid var(--gold);
  overflow:hidden;
}
.topbar .wrap{
  max-width:none;margin:0;padding:0 26px;
  height:66px;display:flex;align-items:center;justify-content:space-between;
}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-display);font-weight:600;font-size:1.35rem;letter-spacing:.2px}
.brand .seal{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(145deg,var(--gold),var(--gold-deep));
  display:grid;place-items:center;color:var(--ink);font-weight:800;font-family:var(--font-body);
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.35);
  flex:none;
}
.brand .brand-logo{height:46px;width:auto;max-width:200px;object-fit:contain;background:#fff;border-radius:10px;padding:5px 10px;box-shadow:0 1px 5px rgba(0,0,0,.18);flex:none;display:block}
.brand .brand-name{font-family:var(--font-display);font-weight:700;font-size:1.2rem;color:#fff;white-space:nowrap;line-height:1.1}
@media (max-width:560px){
  .brand .brand-name{display:none}
  .brand .brand-logo{height:40px;max-width:150px}
}
.nav-links{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.nav-links a{
  padding:8px 14px;border-radius:9px;font-weight:600;font-size:.92rem;color:#dfe6f1;transition:.18s;
}
.nav-links a:hover{background:rgba(255,255,255,.1);color:#fff}
.nav-links a.cta{background:var(--gold);color:var(--ink)}
.nav-links a.cta:hover{background:#d6a84c}

/* ---------- Layout ---------- */
.container{max-width:1760px;margin:0 auto;padding:34px 26px 70px}
.narrow{max-width:560px}
.grid{display:grid;gap:22px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:820px){.cols-2,.cols-3{grid-template-columns:1fr}}

/* ---------- Cards ---------- */
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;box-shadow:var(--shadow-sm);
}
.card h2,.card h3{font-family:var(--font-display);font-weight:600;letter-spacing:.2px}
.card-pad-lg{padding:34px}

.section-title{font-family:var(--font-display);font-size:1.9rem;font-weight:600;margin-bottom:4px}
.section-sub{color:var(--muted);margin-bottom:26px}

/* ---------- Hero ---------- */
.hero{
  background:linear-gradient(150deg,var(--ink),var(--ink-2));
  color:#fff;border-radius:20px;padding:54px 46px;position:relative;overflow:hidden;
  box-shadow:var(--shadow);
}
.hero::after{
  content:"";position:absolute;inset:auto -60px -120px auto;width:340px;height:340px;
  background:radial-gradient(circle,rgba(191,147,64,.35),transparent 70%);
}
.hero .kicker{color:var(--gold-soft);font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:.74rem}
.hero h1{font-family:var(--font-display);font-size:2.9rem;line-height:1.08;margin:12px 0 14px;max-width:18ch}
.hero p{color:#cdd6e6;max-width:52ch;font-size:1.05rem}
.hero .actions{margin-top:28px;display:flex;gap:14px;flex-wrap:wrap}
@media(max-width:620px){.hero{padding:38px 26px}.hero h1{font-size:2.1rem}}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;justify-content:center;
  padding:12px 22px;border-radius:11px;font-weight:700;font-size:.95rem;cursor:pointer;
  border:1px solid transparent;transition:.18s;font-family:var(--font-body);
}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:#d2a247;transform:translateY(-1px)}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{background:var(--ink-2);transform:translateY(-1px)}
.btn-ghost{background:transparent;border-color:rgba(255,255,255,.4);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-outline{background:#fff;border-color:var(--line);color:var(--ink)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold-deep)}
.btn-sm{padding:8px 14px;font-size:.85rem;border-radius:9px}
.btn-block{width:100%}
.btn-danger{background:var(--bad-bg);color:var(--bad);border-color:#f0c4c4}
.btn-danger:hover{background:#f6d2d2}
.btn-success{background:var(--ok);color:#fff;border-color:var(--ok)}
.btn-success:hover{background:#176a41;transform:translateY(-1px)}
.btn-reject{background:var(--bad,#c0392b);color:#fff;border-color:var(--bad,#c0392b)}
.btn-reject:hover{background:#9c2b20;transform:translateY(-1px)}

/* ---------- Forms ---------- */
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;margin-bottom:7px;font-size:.9rem;color:var(--ink-soft)}
.field .req{color:var(--bad)}
input[type=text],input[type=email],input[type=password],input[type=tel],
input[type=number],input[type=file],select,textarea{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:11px;
  font-family:var(--font-body);font-size:.96rem;background:var(--paper-2);color:var(--ink);transition:.16s;
}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--gold);background:#fff;box-shadow:0 0 0 4px rgba(191,147,64,.16);
}
input[type=file]{padding:9px 12px;background:#fff}
.hint{font-size:.8rem;color:var(--muted);margin-top:5px}

/* ---------- Alerts ---------- */
.alert{padding:13px 16px;border-radius:11px;margin-bottom:18px;font-weight:600;font-size:.92rem;border:1px solid}
.alert-ok{background:var(--ok-bg);color:var(--ok);border-color:#bfe3cd}
.alert-bad{background:var(--bad-bg);color:var(--bad);border-color:#f0c4c4}
.alert-info{background:#e7eefb;color:#234b9c;border-color:#c6d6f4}
.alert-warn{background:var(--warn-bg);color:var(--warn);border-color:#eed8a3}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:#fff}
table{width:100%;border-collapse:collapse;font-size:.92rem}
thead th{
  background:var(--ink);color:#fff;text-align:left;padding:13px 16px;font-weight:600;
  font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;
}
tbody td{padding:13px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--paper-2)}

/* ---------- Badges ---------- */
.badge{display:inline-block;padding:4px 11px;border-radius:999px;font-size:.76rem;font-weight:700;letter-spacing:.02em}
.badge-pending{background:var(--warn-bg);color:var(--warn)}
.badge-processing{background:#e7eefb;color:#234b9c}
.badge-completed{background:var(--ok-bg);color:var(--ok)}
.badge-rejected{background:var(--bad-bg);color:var(--bad)}

/* ---------- Stats ---------- */
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;position:relative;overflow:hidden}
.stat .n{font-family:var(--font-display);font-size:2.3rem;font-weight:600;line-height:1}
.stat .l{color:var(--muted);font-weight:600;font-size:.88rem;margin-top:6px}
.stat::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--gold)}

/* ---------- Auth pages ---------- */
.auth-shell{min-height:calc(100vh - 66px);display:grid;place-items:center;padding:40px 18px}
.auth-card{width:100%;max-width:440px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:38px;box-shadow:var(--shadow)}
.auth-card .head{text-align:center;margin-bottom:26px}
.auth-card .head h1{font-family:var(--font-display);font-size:1.7rem;font-weight:600}
.auth-card .head p{color:var(--muted);font-size:.92rem;margin-top:4px}
.auth-foot{text-align:center;margin-top:18px;font-size:.9rem;color:var(--muted)}
.auth-foot a{color:var(--gold-deep);font-weight:700}

/* ---------- Service cards ---------- */
.svc{border:1px solid var(--line);border-radius:var(--radius);padding:22px;background:#fff;transition:.18s;cursor:pointer;position:relative}
.svc:hover{border-color:var(--gold);box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.svc .price{font-family:var(--font-display);font-size:1.6rem;font-weight:600;color:var(--gold-deep)}
.svc h3{margin-bottom:6px}
.svc.selected{border-color:var(--gold);box-shadow:0 0 0 3px rgba(191,147,64,.2)}

/* ---------- Misc ---------- */
.flex{display:flex;align-items:center}
.between{justify-content:space-between}
.gap{gap:12px}
.wrap-gap{flex-wrap:wrap;gap:10px}
.mt{margin-top:18px}.mt-lg{margin-top:28px}.mb{margin-bottom:18px}
.muted{color:var(--muted)}
.text-c{text-align:center}
.pill{display:inline-flex;align-items:center;gap:7px;background:var(--gold-soft);color:var(--gold-deep);padding:6px 13px;border-radius:999px;font-weight:700;font-size:.8rem}
.divider{height:1px;background:var(--line);margin:22px 0}
.thumb{width:54px;height:54px;border-radius:9px;object-fit:cover;border:1px solid var(--line);background:#fff}
.thumb-sig{width:90px;height:46px;object-fit:contain;border:1px solid var(--line);border-radius:8px;background:#fff;padding:3px}
.kv{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px dashed var(--line);font-size:.95rem}
.kv:last-child{border-bottom:none}
.kv .k{color:var(--muted);font-weight:600}
.kv .v{font-weight:600;text-align:right}
.preview-box{display:flex;gap:16px;flex-wrap:wrap;margin-top:8px}
.preview-box .pv{border:1px dashed var(--line);border-radius:10px;padding:8px;text-align:center;font-size:.78rem;color:var(--muted)}
.preview-box img{display:block;border-radius:6px}
footer.site{background:var(--ink);color:#9fb0cb;text-align:center;padding:22px;font-size:.85rem;border-top:3px solid var(--gold)}

/* ===== Sidebar (dark, full-height, fixed) ===== */
.app-shell{max-width:none;margin:0;display:block;padding:0 26px 0 264px;width:100%}
.app-content{min-width:0}
.app-content .container{padding-left:0;padding-right:0}
.app-content .container:not(.narrow){max-width:100%;margin:0}
.app-content .container.narrow{max-width:560px;margin:0 auto}
.sidebar{
  position:fixed;left:0;top:69px;width:240px;height:calc(100vh - 69px);
  background:#15203c;border:0;border-radius:0;padding:14px 12px;
  overflow-y:auto;overscroll-behavior:contain;z-index:40;
  display:flex;flex-direction:column;gap:3px;
}
.sidebar::-webkit-scrollbar{width:6px}
.sidebar::-webkit-scrollbar-track{background:transparent}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:3px}
.sidebar:hover::-webkit-scrollbar-thumb{background:rgba(255,255,255,.30)}
.sidebar-title{font-family:var(--font-display);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.6px;color:#6b7894;margin:12px 8px 6px}
.side-nav{display:flex;flex-direction:column;gap:3px}
.side-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:9px;font-weight:600;font-size:.92rem;color:#c5cee0;text-decoration:none;transition:.15s}
.side-link:hover{background:rgba(255,255,255,.08);color:#fff}
.side-link.active{background:#fff;color:#15203c}
.cat{border-radius:9px;overflow:hidden}
.cat-head{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:9px;cursor:pointer;font-weight:600;font-size:.92rem;color:#c5cee0;background:transparent;transition:.15s;user-select:none}
.cat-head:hover{background:rgba(255,255,255,.08);color:#fff}
.cat.open>.cat-head{color:#fff}
.cat-arrow{transition:transform .2s;font-size:.8rem;opacity:.7}
.cat .submenu{max-height:0;overflow:hidden;transition:max-height .25s ease;display:flex;flex-direction:column}
.cat:hover .submenu,.cat.open .submenu{max-height:600px}
.cat:hover .cat-arrow,.cat.open .cat-arrow{transform:rotate(180deg)}
.submenu-link{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 12px 8px 22px;font-size:.86rem;color:#97a2bd;text-decoration:none;border-left:2px solid transparent;transition:.15s}
.submenu-link:hover{background:rgba(255,255,255,.05);color:#fff}
.submenu-link.active{background:rgba(255,255,255,.10);border-left-color:var(--gold);color:#fff;font-weight:700}
.submenu-link .price{font-size:.74rem;color:#7e8aa6;font-weight:700;white-space:nowrap}
.sidebar-foot{margin-top:auto;padding-top:8px;border-top:1px solid rgba(255,255,255,.08)}
.sidebar-foot .side-link{color:#ff9a9a}
.sidebar-foot .side-link:hover{background:rgba(255,80,80,.16);color:#fff}
@media (max-width:860px){
  .app-shell{padding:0 14px;display:block}
  .sidebar{position:static;width:100%;height:auto;max-height:none;border-radius:14px;margin-bottom:14px}
}

/* ===== Colorful dashboard cards ===== */
.dash-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:8px}
.gcard{border-radius:14px;padding:18px 20px;color:#fff;box-shadow:0 6px 18px rgba(0,0,0,.10);position:relative;overflow:hidden}
.gcard .gc-amt{font-size:1.7rem;font-weight:800;line-height:1.15}
.gcard .gc-label{font-size:.92rem;font-weight:600;opacity:.97;margin-top:2px}
.gcard .gc-sub{font-size:.78rem;opacity:.9;margin-top:10px;display:inline-block;background:rgba(255,255,255,.18);padding:2px 8px;border-radius:6px}
.gcard .gc-icon{position:absolute;right:16px;top:16px;font-size:1.7rem;opacity:.4}
.g-teal{background:linear-gradient(135deg,#1abc9c,#16a085)}
.g-pink{background:linear-gradient(135deg,#ee5a6f,#f29263)}
.g-blue{background:linear-gradient(135deg,#2980b9,#6dd5fa)}
.g-green{background:linear-gradient(135deg,#56ab2f,#a8e063)}
.g-indigo{background:linear-gradient(135deg,#4568dc,#b06ab3)}
.g-red{background:linear-gradient(135deg,#cb2d3e,#ef473a)}
.g-orange{background:linear-gradient(135deg,#f7971e,#f5b342);color:#fff}
.g-dark{background:linear-gradient(135deg,#232526,#414345)}
.dash-section-title{font-family:var(--font-display);font-weight:700;font-size:1.05rem;margin:20px 0 10px;color:var(--ink);display:flex;align-items:center;gap:8px}
.quick-links{display:flex;flex-wrap:wrap;gap:10px;margin:6px 0 4px}
.qlink{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:10px;color:#fff;font-weight:700;text-decoration:none;font-size:.92rem;box-shadow:0 3px 10px rgba(0,0,0,.10);transition:.15s}
.qlink:hover{transform:translateY(-2px)}

/* ===== Services Catalog (icon grid) ===== */
.catalog-head{display:flex;align-items:center;justify-content:space-between;margin:6px 0 12px}
.catalog-head h3{display:flex;align-items:center;gap:8px;margin:0}
.catalog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:14px}
.svc-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 10px;text-align:center;text-decoration:none;color:var(--ink);display:flex;flex-direction:column;align-items:center;gap:8px;transition:.16s;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.svc-card:hover{transform:translateY(-3px);box-shadow:0 8px 20px rgba(0,0,0,.10);border-color:var(--gold)}
.svc-ic{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;font-size:26px;background:#eef2ff;box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)}
.svc-name{font-weight:700;font-size:.86rem;line-height:1.25;min-height:2.1em;display:flex;align-items:center}
.svc-cat{font-size:.68rem;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:#9aa0aa}
.svc-price{font-size:.78rem;font-weight:800;color:var(--gold-deep)}

/* ===== Services Catalog (icon cards) ===== */
.catalog-head{display:flex;align-items:center;justify-content:space-between;margin:6px 0 12px}
.catalog-head h3{display:flex;align-items:center;gap:8px;margin:0}
.catalog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px}
.svc-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:18px 12px;background:#fff;border:1px solid var(--line);border-radius:14px;text-decoration:none;color:var(--ink);transition:.18s;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.svc-card:hover{transform:translateY(-4px);box-shadow:0 10px 22px rgba(0,0,0,.10);border-color:var(--gold)}
.svc-ico{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;font-size:1.7rem;background:linear-gradient(135deg,#eef2ff,#e0e7ff);box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)}
.svc-name{font-weight:700;font-size:.9rem;line-height:1.2}
.svc-cat{font-size:.7rem;text-transform:uppercase;letter-spacing:.4px;color:#8a8f98;font-weight:700}
.svc-price{font-size:.78rem;font-weight:800;color:var(--gold-deep)}

/* ===== Professional full-width form layout ===== */
.form-shell{display:grid;grid-template-columns:1fr 330px;gap:22px;align-items:start}
.form-aside .aside-card{position:sticky;top:90px}
.aside-card .bal{font-size:1.5rem;font-weight:800;color:var(--ink)}
.aside-card .row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px dashed var(--line)}
.aside-card .row:last-child{border-bottom:0}
@media(max-width:980px){
  .form-shell{grid-template-columns:1fr}
  .form-aside .aside-card{position:static}
}
/* catalog: 6 per row, double line */
.catalog-grid{grid-template-columns:repeat(6,1fr)}
@media(max-width:1200px){.catalog-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:760px){.catalog-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.catalog-grid{grid-template-columns:repeat(2,1fr)}}