/* ===========================================================
   Deepsikha Social Help Organisation — shared theme
   Tricolor recolor of the reference design system.
   Used by public site + member panel + admin panel.
   =========================================================== */
:root{
  --saffron:#f57c00; --saffron-d:#e65100;
  --green:#2e9e4f;   --green-d:#1e7e3a;
  --blue:#1f5fae;    --blue-d:#0d3f80;
  --ink:#1b2330; --muted:#5b6675; --bg:#f5f8fc; --line:#e7ecf5;
  --shadow:0 18px 40px rgba(13,63,128,.12);
}
*{font-family:'Inter','Segoe UI',sans-serif;}
h1,h2,h3,h4,h5,.fw-head{font-family:'Montserrat',sans-serif;}
body{color:var(--ink);background:#fff;}

.text-saffron{color:var(--saffron)!important;}
.text-green{color:var(--green)!important;}
.text-blue{color:var(--blue)!important;}
.bg-soft{background:var(--bg);}

a{text-decoration:none;}

/* Buttons */
.btn-saffron{background:var(--saffron);color:#fff;font-weight:700;border-radius:50px;padding:9px 22px;border:none;transition:.2s;}
.btn-saffron:hover{background:var(--saffron-d);color:#fff;transform:translateY(-2px);}
.btn-green{background:var(--green);color:#fff;font-weight:700;border-radius:50px;padding:9px 22px;border:none;transition:.2s;}
.btn-green:hover{background:var(--green-d);color:#fff;transform:translateY(-2px);}
.btn-outline-blue{border:2px solid var(--blue);color:var(--blue);font-weight:700;border-radius:50px;padding:8px 20px;background:#fff;}
.btn-outline-blue:hover{background:var(--blue);color:#fff;}

/* Sections */
.section{padding:70px 0;}
.section-label{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--saffron);margin-bottom:8px;}
.section-title{font-size:clamp(24px,3.2vw,36px);font-weight:900;color:var(--blue);margin-bottom:6px;}
.section-title span{color:var(--saffron);}

/* Public navbar */
.ds-nav{background:#fff;box-shadow:0 2px 16px rgba(0,0,0,.08);padding:6px 0;position:sticky;top:0;z-index:1000;}
.ds-nav .navbar-brand{display:flex;align-items:center;gap:10px;font-weight:900;color:var(--blue);}
.ds-nav .navbar-brand img{height:50px;width:auto;}
.ds-nav .nav-link{font-weight:600;color:#222!important;letter-spacing:.01em;}
.ds-nav .nav-link:hover{color:var(--saffron)!important;}

/* Hero slider */
.hero-slider .carousel-item{height:560px;}
.hero-slider .carousel-item img{width:100%;height:560px;object-fit:cover;}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(13,63,128,.86) 0%,rgba(31,95,174,.55) 50%,rgba(245,124,0,.35) 100%);display:flex;align-items:center;}
.hero-text{color:#fff;max-width:680px;padding:0 12px;}
.hero-text .badge-tag{display:inline-block;background:var(--saffron);color:#fff;font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:5px 16px;border-radius:30px;margin-bottom:16px;}
.hero-text h1{font-size:clamp(28px,4.4vw,54px);font-weight:900;line-height:1.12;text-shadow:0 2px 12px rgba(0,0,0,.35);margin-bottom:16px;}
.hero-text p{font-size:16px;opacity:.92;max-width:560px;margin-bottom:26px;}
.carousel-indicators [data-bs-target]{width:10px;height:10px;border-radius:50%;}
.carousel-indicators .active{background:var(--saffron);}

/* Cards */
.feature-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px 24px;height:100%;transition:.25s;}
.feature-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--saffron);}
.feature-ic{width:62px;height:62px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:28px;color:#fff;margin-bottom:16px;background:linear-gradient(135deg,var(--saffron),var(--saffron-d));}
.feature-ic.green{background:linear-gradient(135deg,var(--green),var(--green-d));}
.feature-ic.blue{background:linear-gradient(135deg,var(--blue),var(--blue-d));}
.feature-card h5{font-weight:800;color:var(--blue);margin-bottom:8px;}
.feature-card p,.feature-card li{color:var(--muted);font-size:14px;}

.about-card{background:linear-gradient(135deg,var(--blue) 0%,var(--blue-d) 100%);border-radius:20px;color:#fff;overflow:hidden;}
.about-photo{background:radial-gradient(circle at 50% 30%,rgba(245,124,0,.35),transparent 70%);display:flex;align-items:flex-end;justify-content:center;min-height:300px;padding:18px;}
.about-photo img{max-height:320px;width:auto;}

.activity-card{border-radius:16px;overflow:hidden;background:#fff;border:1px solid var(--line);height:100%;transition:.25s;}
.activity-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.activity-card .ac-img{height:210px;overflow:hidden;}
.activity-card .ac-img img{width:100%;height:100%;object-fit:cover;transition:.5s;}
.activity-card:hover .ac-img img{transform:scale(1.07);}
.activity-card .ac-body{padding:18px 20px;}

/* Plan table */
.plan-table{width:100%;border-collapse:separate;border-spacing:0;}
.plan-table th{background:var(--blue);color:#fff;font-size:12px;letter-spacing:.05em;text-transform:uppercase;padding:12px 16px;}
.plan-table td{padding:11px 16px;border-bottom:1px solid var(--line);font-size:14px;}
.plan-table tr:hover td{background:#fff7ee;}

.stat-pill{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;text-align:center;}
.stat-pill h3{font-weight:900;color:var(--saffron);margin:0;font-size:26px;}
.stat-pill p{margin:4px 0 0;color:var(--muted);font-size:13px;}

/* Public footer */
.ds-footer{background:var(--blue-d);color:#cdd5ea;padding:44px 0 20px;}
.ds-footer a{color:#cdd5ea;}
.ds-footer a:hover{color:var(--saffron);}

/* ============ DASHBOARD SHELL (member + admin) ============ */
.app-body{background:var(--bg);min-height:100vh;}
.app-sidebar{position:fixed;top:0;left:0;bottom:0;width:260px;background:linear-gradient(180deg,var(--blue-d),var(--blue));color:#dbe4f5;overflow-y:auto;z-index:1040;transition:transform .25s;}
.app-sidebar .brand{display:flex;align-items:center;gap:10px;padding:18px;border-bottom:1px solid rgba(255,255,255,.12);}
.app-sidebar .brand img{height:42px;background:#fff;border-radius:8px;padding:3px;}
.app-sidebar .brand span{font-weight:800;color:#fff;font-size:15px;line-height:1.1;}
.app-sidebar .nav-section{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:#9fb3d9;padding:16px 18px 6px;}
.app-sidebar a.side-link{display:flex;align-items:center;gap:11px;padding:11px 18px;color:#cfdbf2;font-size:14px;font-weight:500;border-left:3px solid transparent;}
.app-sidebar a.side-link:hover,.app-sidebar a.side-link.active{background:rgba(255,255,255,.08);color:#fff;border-left-color:var(--saffron);}
.app-sidebar a.side-link i{font-size:17px;width:20px;text-align:center;}

.app-main{margin-left:260px;transition:margin .25s;}
.app-topbar{background:#fff;box-shadow:0 1px 12px rgba(0,0,0,.06);padding:12px 22px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:1030;}
.app-topbar .user-chip{display:flex;align-items:center;gap:9px;font-weight:600;color:var(--blue);}
.app-content{padding:24px;}
.app-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:1035;}

.card-ds{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 6px 18px rgba(13,63,128,.05);}
.card-ds .card-ds-head{padding:16px 20px;border-bottom:1px solid var(--line);font-weight:800;color:var(--blue);display:flex;align-items:center;justify-content:space-between;}
.card-ds .card-ds-body{padding:20px;}

/* Wallet/stat tiles */
.tile{border-radius:16px;padding:20px;color:#fff;position:relative;overflow:hidden;height:100%;}
.tile .tile-ic{position:absolute;right:14px;top:14px;font-size:38px;opacity:.25;}
.tile h3{font-weight:900;margin:6px 0 0;font-size:24px;}
.tile small{opacity:.9;font-weight:600;letter-spacing:.03em;}
.tile.t-saffron{background:linear-gradient(135deg,var(--saffron),var(--saffron-d));}
.tile.t-green{background:linear-gradient(135deg,var(--green),var(--green-d));}
.tile.t-blue{background:linear-gradient(135deg,var(--blue),var(--blue-d));}
.tile.t-dark{background:linear-gradient(135deg,#2b3650,#1b2330);}

/* Tables */
.table-ds{width:100%;border-collapse:separate;border-spacing:0;}
.table-ds thead th{background:#eef3fb;color:var(--blue);font-size:12px;letter-spacing:.04em;text-transform:uppercase;padding:11px 14px;border-bottom:2px solid var(--line);}
.table-ds tbody td{padding:11px 14px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle;}
.table-ds tbody tr:hover td{background:#f8fbff;}

/* Status badges */
.badge-st{font-size:11px;font-weight:700;padding:4px 10px;border-radius:30px;text-transform:uppercase;letter-spacing:.03em;}
.badge-unused,.badge-pending{background:#fff3e0;color:#e65100;}
.badge-used,.badge-approved,.badge-paid,.badge-verified,.badge-active{background:#e6f6ec;color:#1e7e3a;}
.badge-expired,.badge-rejected,.badge-blocked{background:#fdecec;color:#c62828;}

/* Matrix coverage table */
.coverage-bar{height:8px;border-radius:6px;background:#eef1f7;overflow:hidden;}
.coverage-bar > span{display:block;height:100%;background:linear-gradient(90deg,var(--green),var(--saffron));}

/* Lazy matrix tree */
.matrix-tree{--node:64px;}
.matrix-tree ul{list-style:none;display:flex;justify-content:center;padding-top:22px;position:relative;margin:0;}
.matrix-tree li{position:relative;padding:22px 8px 0;text-align:center;}
.matrix-tree li::before,.matrix-tree li::after{content:'';position:absolute;top:0;right:50%;border-top:2px solid #c7d3e8;width:50%;height:22px;}
.matrix-tree li::after{right:auto;left:50%;border-left:2px solid #c7d3e8;}
.matrix-tree li:only-child::after,.matrix-tree li:only-child::before{display:none;}
.matrix-tree li:first-child::before,.matrix-tree li:last-child::after{border:0;}
.matrix-tree li:last-child::before{border-right:2px solid #c7d3e8;border-radius:0 6px 0 0;}
.matrix-tree li:first-child::after{border-radius:6px 0 0 0;}
.matrix-tree ul ul::before{content:'';position:absolute;top:0;left:50%;border-left:2px solid #c7d3e8;width:0;height:22px;}
.tree-node{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;width:var(--node);height:var(--node);border-radius:50%;background:#fff;border:2px solid var(--blue);color:var(--blue);font-size:11px;font-weight:700;cursor:pointer;box-shadow:0 4px 10px rgba(13,63,128,.12);transition:.15s;}
.tree-node:hover{transform:translateY(-2px);border-color:var(--saffron);color:var(--saffron);}
.tree-node.empty{border-style:dashed;border-color:#c7d3e8;color:#c7d3e8;cursor:default;}
.tree-node.has-children{background:var(--blue);color:#fff;}
.tree-node small{font-size:9px;font-weight:600;opacity:.85;}

/* Auth pages */
.auth-wrap{min-height:100vh;display:flex;align-items:center;background:linear-gradient(135deg,var(--blue-d),var(--blue));padding:30px 12px;}
.auth-card{background:#fff;border-radius:20px;box-shadow:0 30px 70px rgba(0,0,0,.35);overflow:hidden;width:100%;}
.auth-side{background:linear-gradient(160deg,var(--saffron),var(--saffron-d));color:#fff;padding:40px;display:flex;flex-direction:column;justify-content:center;}
.auth-form{padding:38px;}
.auth-form .form-control,.auth-form .form-select{border-radius:10px;padding:10px 14px;}
.auth-logo{height:64px;background:#fff;border-radius:12px;padding:6px;margin-bottom:14px;}

/* Responsive */
@media (max-width:991.98px){
  .app-sidebar{transform:translateX(-100%);}
  .app-sidebar.open{transform:translateX(0);}
  .app-main{margin-left:0;}
  .app-overlay.show{display:block;}
}
@media (max-width:767.98px){
  .hero-slider .carousel-item,.hero-slider .carousel-item img{height:460px;}
  .section{padding:48px 0;}
  .app-content{padding:16px;}
}
