/* FINAL CLEAN STYLE.CSS - Sai Priya Charitable Trust NGO Management */

:root{
  --primary:#064e3b;--primary-dark:#022c22;--primary-soft:#0f766e;--gold:#d4a64f;
  --danger:#dc2626;--text:#101828;--muted:#667085;--bg:#f3f6f5;
  --shadow:0 18px 45px rgba(15,23,42,.08);
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.5}

/* LOGIN */
.login-body{min-height:100vh!important;display:flex;align-items:center;justify-content:center;padding:28px;background:radial-gradient(circle at 15% 15%,rgba(250,204,21,.28),transparent 24%),radial-gradient(circle at 85% 20%,rgba(20,184,166,.26),transparent 28%),linear-gradient(135deg,#020617 0%,#052e2b 52%,#064e3b 100%)!important}
.login-wrapper,.login-page-shell{width:min(1120px,96vw);min-height:650px;display:grid;grid-template-columns:1.12fr .88fr;border-radius:42px;overflow:hidden;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);box-shadow:0 42px 120px rgba(0,0,0,.42);backdrop-filter:blur(20px)}
.login-left{position:relative;padding:70px 60px;color:#fff;background:linear-gradient(145deg,rgba(2,6,23,.92),rgba(6,78,59,.72));overflow:hidden}
.login-left:before{content:"";position:absolute;right:-100px;top:-100px;width:330px;height:330px;border-radius:50%;background:linear-gradient(135deg,rgba(250,204,21,.32),transparent)}
.login-logo,.logo{width:96px;height:96px;border-radius:30px;background:linear-gradient(135deg,#fff,#fde68a);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:900;box-shadow:0 18px 45px rgba(0,0,0,.25);position:relative}
.login-premium-tag,.tag{display:inline-block;margin-top:30px;color:#fde68a;text-transform:uppercase;font-size:12px;font-weight:900;letter-spacing:1.3px;position:relative}
.login-left h1{position:relative;font-size:56px;line-height:1.06;margin:14px 0 18px;font-weight:900}
.login-left p{position:relative;max-width:620px;color:#e7fff7;font-size:17px;line-height:1.8}
.login-feature-list,.features{position:relative;margin-top:34px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.login-feature-list div,.features div{padding:15px 16px;border-radius:18px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);color:#fff;font-weight:800}
.login-right{display:flex;align-items:center;justify-content:center;padding:45px;background:linear-gradient(180deg,#fff,#fff7ed)}
.login-card-pro,.login-card{width:100%;max-width:430px;padding:42px;border-radius:34px;background:#fff;box-shadow:0 22px 55px rgba(15,23,42,.13);border:1px solid #f2e8d8}
.mini-logo{width:72px;height:72px;border-radius:24px;background:linear-gradient(135deg,var(--primary),var(--primary-soft));color:#facc15;display:flex;align-items:center;justify-content:center;font-weight:900;margin-bottom:22px}
.login-card-pro h2,.login-card h2{font-size:36px;color:var(--primary);margin-bottom:8px;font-weight:900}
.login-card-pro p,.login-card p{color:var(--muted);line-height:1.6;margin-bottom:24px}
.login-card-pro label,.login-card label{display:block;margin:16px 0 8px;color:var(--primary);font-weight:900}
.login-card-pro input,.login-card input{width:100%;height:56px;border:1px solid #d0d5dd;border-radius:18px;padding:0 17px;font-size:15px;background:#fff}
.login-card-pro input:focus,.login-card input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 5px rgba(212,166,79,.16)}
.login-card-pro button,.login-btn{width:100%;height:58px;margin-top:24px;border:0;border-radius:999px;background:linear-gradient(135deg,var(--primary),#22c55e);color:white;font-size:16px;font-weight:900;cursor:pointer}
.login-error,.error{background:#fee2e2;color:#991b1b;border-radius:16px;padding:13px 15px;font-weight:800;margin-bottom:16px}

/* APP LAYOUT */
.layout{display:flex;min-height:100vh}
.sidebar{width:292px;min-height:100vh;position:fixed;left:0;top:0;padding:28px 20px;background:linear-gradient(180deg,#020617 0%,#064e3b 55%,#0f766e 100%);color:#fff;box-shadow:0 0 40px rgba(15,23,42,.22);overflow-y:auto;z-index:50}
.brand{padding-bottom:22px;margin-bottom:26px;border-bottom:1px solid rgba(255,255,255,.18)}
.brand-icon{width:62px;height:62px;border-radius:20px;background:linear-gradient(135deg,#fff,#fde68a);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:900;margin-bottom:14px}
.brand h2,.brand h3{color:#fff;font-size:25px;line-height:1.22;margin-bottom:8px}
.brand p{color:#d1fae5;font-size:13px;font-weight:700}
.sidebar a{display:block;padding:14px 16px;margin-bottom:9px;color:#fff;text-decoration:none;font-weight:800;border-radius:16px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.06)}
.sidebar a:hover{transform:translateX(5px);background:rgba(255,255,255,.16)}
.main{margin-left:292px;width:calc(100% - 292px);padding:30px}
.topbar{background:#fff;padding:20px 28px;border-radius:26px;box-shadow:var(--shadow);margin-bottom:26px;display:flex;justify-content:space-between;align-items:center;gap:18px}
.topbar h1,.topbar h2{color:var(--primary);font-size:28px;line-height:1.2}
.topbar p,.topbar-title span,.user-chip{color:var(--muted);font-weight:700;font-size:14px}
.top-actions{display:flex;align-items:center;gap:14px}
.logout{background:linear-gradient(135deg,#ef4444,#f97316);color:#fff;text-decoration:none;padding:11px 20px;border-radius:999px;font-weight:900}

/* PAGE BLOCKS */
.hero,.page-title{background:linear-gradient(135deg,#031311,#07533f 60%,#d4a64f);border-radius:34px;padding:42px;color:#fff;margin-bottom:28px;box-shadow:0 22px 60px rgba(15,23,42,.16);overflow:hidden}
.hero h1,.hero h2,.page-title h1{font-size:44px;line-height:1.12;margin-bottom:12px}
.hero p,.page-title p{max-width:820px;line-height:1.75;color:#ecfdf5}
.eyebrow{display:inline-block;padding:8px 14px;margin-bottom:12px;border-radius:999px;background:rgba(255,255,255,.16);color:#fff7c2;font-size:12px;font-weight:900;text-transform:uppercase}
.income-title{background:linear-gradient(135deg,#052e16,#118348,#a3e635)}
.expense-title{background:linear-gradient(135deg,#450a0a,#b91c1c,#f97316)}
.donation-title{background:linear-gradient(135deg,#042f2e,#0f766e,#d97706)}
.donor-title{background:linear-gradient(135deg,#111827,#07533f,#0891b2)}
.report-title{background:linear-gradient(135deg,#1e1b4b,#07533f,#d97706)}
.panel{background:#fff;border-radius:30px;padding:30px;box-shadow:var(--shadow);margin-bottom:30px;border:1px solid rgba(15,23,42,.04)}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:28px}
.card{background:#fff;border-radius:28px;padding:26px;box-shadow:var(--shadow);position:relative;overflow:hidden;min-height:145px}
.card:before{content:"";position:absolute;left:0;top:0;width:7px;height:100%;background:linear-gradient(180deg,var(--primary),#22c55e)}
.card span,.card h3{color:var(--muted);font-size:14px;font-weight:900;display:block;margin-bottom:10px}
.card h1,.card h2{color:var(--primary);font-size:32px}
.module-grid,.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.module-card,.quick{border-radius:30px;padding:28px;min-height:210px;color:#fff;text-decoration:none;box-shadow:0 22px 55px rgba(15,23,42,.14)}
.module-card:hover,.quick:hover{transform:translateY(-6px)}
.module-card h2,.module-card h3,.quick b{display:block;margin-top:18px;font-size:26px;color:#fff}
.module-card p,.quick span{display:block;margin-top:10px;line-height:1.65;color:#fff}
.receipt-card,.q-donation,.quick:nth-child(1){background:linear-gradient(135deg,#064e3b,#0f766e)}
.income-card,.q-income,.quick:nth-child(2){background:linear-gradient(135deg,#14532d,#22c55e)}
.expense-card,.q-expense,.quick:nth-child(3){background:linear-gradient(135deg,#7f1d1d,#ef4444)}
.report-card,.q-report,.quick:nth-child(4){background:linear-gradient(135deg,#1e1b4b,#f59e0b)}

/* FORMS/TABLES */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.form label,.form-group label,.filter label,.report-filter label{display:block;margin:15px 0 8px;color:var(--primary);font-weight:900}
.form input,.form select,.form textarea,.form-group input,.form-group select,.form-group textarea,.filter input,.report-filter input{width:100%;padding:15px;border:1px solid #d0d5dd;border-radius:16px;font-size:15px;background:#fff;font-family:Arial,Helvetica,sans-serif}
.form textarea,.form-group textarea{min-height:110px}
.btn,.form button,.report-filter button{background:linear-gradient(135deg,var(--primary),#22c55e);color:#fff;border:none;padding:15px 28px;border-radius:999px;font-weight:900;cursor:pointer;text-decoration:none;display:inline-block;margin-top:18px}
.btn-dark{background:linear-gradient(135deg,#0f172a,#334155)!important}
.btn-gold{background:linear-gradient(135deg,#b45309,#f59e0b)!important}
.danger-btn{background:linear-gradient(135deg,#dc2626,#f97316)!important}
.alert{margin:15px 0;padding:14px 16px;border-radius:14px;font-weight:800}
.success{background:#dcfce7;color:#166534}
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;background:#fff;border-radius:22px;overflow:hidden;box-shadow:var(--shadow);margin-top:20px}
table th{background:linear-gradient(135deg,#031311,var(--primary));color:#fff;padding:16px;font-size:14px;text-align:left}
table td{padding:15px;border-bottom:1px solid #eaecf0;vertical-align:top}
table tr:hover{background:#f9fafb}
.pro-table th{text-transform:uppercase;font-size:12px;letter-spacing:.5px}
.pro-table td{font-size:14px}
.amount-cell{text-align:right;font-weight:900;color:var(--primary)}
.empty-row{text-align:center;color:var(--muted);padding:30px!important}
.mini,.delete-btn{display:inline-block;color:#fff;padding:8px 14px;border-radius:999px;text-decoration:none;font-weight:900;margin:2px}
.mini{background:#f97316}.delete-btn{background:#dc2626}

/* RECEIPT + REPORT */
.receipt-body{background:#f3f4f6!important;padding:20px!important}
.receipt-a4{width:860px;margin:20px auto;background:#fff;border-radius:22px;padding:40px;box-shadow:0 20px 60px rgba(0,0,0,.10);position:relative;overflow:hidden;border:1px solid #e7d7ab}
.receipt-a4:before{content:"SPCT";position:absolute;top:43%;left:50%;transform:translate(-50%,-50%);font-size:115px;font-weight:900;color:rgba(6,78,59,.035)}
.receipt-a4 *{position:relative;z-index:1}
.receipt-topline{height:8px;background:linear-gradient(90deg,var(--primary),var(--gold),#f97316);position:absolute;top:0;left:0;right:0}
.receipt-header{display:flex;gap:20px;align-items:center;padding-bottom:18px;border-bottom:2px solid #eee}
.seal{width:76px;height:76px;border-radius:22px;background:linear-gradient(135deg,#031311,var(--primary));color:#facc15;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:900;flex-shrink:0}
.receipt-header h1{font-size:32px;color:#111827;line-height:1.15}
.receipt-header p{margin-top:7px;color:var(--muted);line-height:1.55;font-size:13px}
.receipt-title{text-align:center;font-size:34px;color:#92400e;margin:28px 0;font-weight:900;letter-spacing:3px}
.receipt-meta{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.receipt-meta div{background:#fffaf0;border:1px solid #f4d7a1;padding:18px;border-radius:18px}
.receipt-table{width:100%;border-collapse:collapse;margin-top:18px;box-shadow:none;border-radius:0}
.amount-box{margin-top:24px;background:linear-gradient(135deg,#ecfdf5,#f0fdf4);border-left:8px solid #22c55e;border-radius:22px;padding:26px;display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:center}
.amount-box h3{font-size:48px;color:#065f46}
.printbar{text-align:center;margin:22px auto;display:flex;justify-content:center;gap:12px}

.financial-report{width:184mm;margin:18px auto;background:#fff;border:1px solid #d8d8d8;box-shadow:0 16px 45px rgba(0,0,0,.08);padding:12mm 14mm;border-radius:8px;color:#1f2937;position:relative;overflow:hidden}
.report-watermark{position:absolute;top:46%;left:50%;transform:translate(-50%,-50%);font-size:80px;font-weight:900;color:rgba(6,78,59,.035);z-index:0}
.financial-report>*:not(.report-watermark){position:relative;z-index:1}
.fr-header{display:flex;gap:14px;align-items:center;border-bottom:3px double #111827;padding-bottom:10px;margin-bottom:12px}
.fr-logo{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,#031311,var(--primary));color:#facc15;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:900;flex-shrink:0}
.fr-header h1{font-size:21px;letter-spacing:.6px;color:#111827;margin-bottom:4px}
.fr-title-block{text-align:center;margin:12px 0}
.fr-title-block h2{font-size:18px;color:var(--primary);text-transform:uppercase;letter-spacing:1px}
.summary-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin:12px 0}
.summary-strip div{border:1px solid #d1d5db;background:#f9fafb;padding:8px;border-radius:5px;text-align:center}
.summary-strip span{display:block;font-size:9px;text-transform:uppercase;color:#6b7280;font-weight:900;margin-bottom:4px}
.summary-strip b{font-size:12px;color:var(--primary)}
.statement-section{margin-top:13px;page-break-inside:avoid}
.statement-section h2{font-size:15px;color:var(--primary);margin-bottom:6px;border-bottom:1px solid #d1d5db;padding-bottom:5px;text-transform:uppercase}
.statement-table{width:100%;border-collapse:collapse;margin:0;box-shadow:none;border-radius:0}
.statement-table th{background:var(--primary);color:#fff;border:1px solid var(--primary);padding:6px;text-align:center;font-size:10px;text-transform:uppercase}
.statement-table td{border:1px solid #d1d5db;padding:6px;font-size:10.5px;text-align:left}
.statement-table td:nth-child(2),.statement-table td:nth-child(4){text-align:right;font-weight:700}
.statement-table .total-row td{font-weight:900;background:#f3f4f6;text-transform:uppercase}
.category-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.detailed-table th,.detailed-table td{font-size:9.8px}
.signature-section,.report-sign-section{display:flex;justify-content:space-between;align-items:flex-end;margin-top:35px;gap:40px;border-top:1px solid #d1d5db;padding-top:14px}
.left-sign,.report-left-sign{text-align:center;width:190px}
.seal-circle{width:68px;height:68px;border:2px solid #0d9488;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;color:#0d9488;margin:auto;background:#fff;font-size:14px}
.right-sign,.report-right-sign{text-align:center;width:250px;margin-left:auto}
.signature-img,.report-right-sign img{width:145px;max-height:58px;object-fit:contain;margin-bottom:-6px}
.signature-line,.sign-line{border-top:2px solid #222;margin:7px auto 8px;width:210px}

/* PRINT */
@media print{
  @page{size:A4;margin:8mm}
  body{background:#fff!important;padding:0!important}
  .sidebar,.topbar,.page-title,.panel,.printbar,.no-print{display:none!important}
  .main{margin:0!important;padding:0!important;width:100%!important}
  .financial-report{width:100%!important;margin:0!important;padding:0!important;border:none;box-shadow:none;border-radius:0;overflow:visible}
  .statement-section{page-break-inside:avoid;margin-top:12px}
  .statement-table th{background:var(--primary)!important;color:#fff!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .statement-table th,.statement-table td{font-size:10px;padding:5px}
  .detailed-table th,.detailed-table td{font-size:8.8px!important;padding:4px!important}
  .category-grid{grid-template-columns:1fr 1fr;gap:8px}
}

/* MOBILE */
@media(max-width:992px){
  .login-wrapper,.login-page-shell{grid-template-columns:1fr;min-height:auto}
  .login-left{display:none}
  .login-right{padding:24px}
  .sidebar{width:100%;position:relative;min-height:auto}
  .main{margin-left:0;width:100%;padding:16px}
  .cards,.module-grid,.grid,.form-grid,.receipt-meta,.amount-box,.summary-strip,.category-grid{grid-template-columns:1fr}
  .receipt-a4,.financial-report{width:100%;padding:22px}
  .signature-section,.report-sign-section{display:block;text-align:center}
  .left-sign,.right-sign,.report-left-sign,.report-right-sign{margin:20px auto;width:100%}
  .hero h1,.hero h2,.page-title h1{font-size:34px}
  .topbar{flex-direction:column;gap:15px;align-items:flex-start}
}
