/* Barangay Connect Portal - Main Stylesheet */
:root{--brand-blue:#1a3a5c;--brand-accent:#1a56db;--brand-yellow:#f5a623;--bs-primary:#1a56db;}
body{font-family:"Segoe UI",Roboto,system-ui,-apple-system,sans-serif;background-color:#f3f4f6;color:#1f2937;}
.navbar{background:#1a3a5c !important;border-bottom:1px solid rgba(255,255,255,0.08);padding:0.6rem 0;}
.navbar-toggler{border-color:rgba(255,255,255,0.3);}
.navbar-toggler-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.8%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");}
.navbar .nav-link{color:rgba(255,255,255,0.80) !important;font-size:0.875rem;padding:0.45rem 0.65rem;border-radius:6px;transition:background 0.15s,color 0.15s;}
.navbar .nav-link:hover,.navbar .nav-link.active{color:#fff !important;background:rgba(255,255,255,0.1);}
.bc-badge{width:40px;height:40px;background:linear-gradient(135deg,#2563eb,#1a3a5c);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:0.8rem;font-weight:700;color:#fff;flex-shrink:0;text-decoration:none;}
.btn-nav-login{color:rgba(255,255,255,0.85) !important;border:1px solid rgba(255,255,255,0.35);border-radius:6px;padding:0.35rem 0.9rem;font-size:0.85rem;transition:all 0.15s;text-decoration:none;}
.btn-nav-login:hover{background:rgba(255,255,255,0.12) !important;color:#fff !important;}
.btn-nav-register{background:#f5a623 !important;color:#1a3a5c !important;border:none;border-radius:6px;padding:0.35rem 1rem;font-size:0.85rem;font-weight:700;transition:background 0.15s,transform 0.1s;text-decoration:none;}
.btn-nav-register:hover{background:#e59400 !important;color:#1a3a5c !important;transform:translateY(-1px);}
.hero-section{background:linear-gradient(135deg,rgba(15,41,66,0.92) 0%,rgba(26,58,92,0.88) 45%,rgba(30,73,118,0.85) 100%), url('../images/muzoneast.png') center center / cover no-repeat;min-height:520px;position:relative;overflow:hidden;}
.hero-section::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none;}
.hero-content{position:relative;z-index:1;}
.hero-subtitle{color:#f5a623;font-size:1.5rem;font-weight:700;}
.btn-hero-primary{background:#f5a623;color:#1a3a5c;border:none;font-weight:700;padding:0.75rem 1.75rem;border-radius:8px;font-size:1rem;transition:background 0.15s,transform 0.1s,box-shadow 0.15s;text-decoration:none;display:inline-flex;align-items:center;}
.btn-hero-primary:hover{background:#e59400;color:#1a3a5c;transform:translateY(-2px);box-shadow:0 6px 20px rgba(245,166,35,0.35);}
.btn-hero-secondary{background:transparent;color:rgba(255,255,255,0.9);border:2px solid rgba(255,255,255,0.45);font-weight:600;padding:0.75rem 1.75rem;border-radius:8px;font-size:1rem;transition:all 0.15s;text-decoration:none;display:inline-flex;align-items:center;}
.btn-hero-secondary:hover{background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,0.7);color:#fff;}
.feature-card{background:rgba(255,255,255,0.08);border-radius:14px;border:1px solid rgba(255,255,255,0.12);padding:1.25rem 1rem;text-align:center;transition:transform .2s,background 0.2s;}
.feature-card:hover{transform:translateY(-4px);background:rgba(255,255,255,0.13);}
.feature-card .fw-bold{color:#fff;font-size:0.9rem;}
.feature-card .text-muted{color:rgba(255,255,255,0.6) !important;}
.feature-icon-wrap{width:52px;height:52px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:0.65rem;}
.feature-icon-wrap.yellow{background:rgba(245,166,35,0.2);color:#f5a623;}
.feature-icon-wrap.blue{background:rgba(59,130,246,0.2);color:#60a5fa;}
.feature-icon-wrap.green{background:rgba(34,197,94,0.2);color:#4ade80;}
.feature-icon-wrap.red{background:rgba(239,68,68,0.2);color:#f87171;}
.stat-card{border-radius:12px;background:white;box-shadow:0 2px 12px rgba(0,0,0,.07);border:1px solid #e5e7eb;transition:transform .2s,box-shadow .2s;}
.stat-card:hover{transform:translateY(-3px);box-shadow:0 6px 24px rgba(0,0,0,.12);}
.stat-number{font-size:2rem;font-weight:800;line-height:1;}
.stat-label{font-size:0.78rem;margin-top:4px;}
.announcement-card{border-radius:12px;transition:transform .2s,box-shadow .2s;}
.announcement-card:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(0,0,0,.12) !important;}
.service-card{border-radius:12px;transition:transform .2s;background:#fff;}
.service-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.09) !important;}
.service-icon{font-size:2rem;}
.official-card{border-radius:12px;transition:transform .2s;}
.official-card:hover{transform:translateY(-3px);}
.official-avatar{width:80px;height:80px;background:linear-gradient(135deg,#1a3a5c,#2563eb);border-radius:50%;display:flex;align-items:center;justify-content:center;}
.official-avatar-lg{width:120px;height:120px;background:linear-gradient(135deg,#1a3a5c,#2563eb);border-radius:50%;display:flex;align-items:center;justify-content:center;}
.footer{font-size:0.875rem;}
.section-tag{display:inline-block;background:rgba(26,86,219,0.1);color:#1a56db;font-size:0.72rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:0.25rem 0.75rem;border-radius:999px;margin-bottom:0.4rem;}
.page-header{border-left:4px solid #1a56db;padding-left:1rem;}
.auth-body{background:#f1f5f9;min-height:calc(100vh - 60px);}
.auth-card{max-width:480px;width:100%;border-radius:16px;box-shadow:0 8px 40px rgba(0,0,0,.12);}
.auth-bc-badge{width:64px;height:64px;background:linear-gradient(135deg,#1a3a5c,#2563eb);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;color:#fff;}
.step-bar{display:flex;gap:4px;margin-bottom:0.5rem;}
.step-bar .step{flex:1;height:4px;border-radius:4px;background:#e5e7eb;transition:background 0.3s;}
.step-bar .step.active{background:#1a56db;}
.step-bar .step.done{background:#16a34a;}
.admin-login-body{background:linear-gradient(135deg,#1a3a5c 0%,#1a56db 100%);}
.login-card{width:400px;border-radius:16px;}
.admin-body{background:#f1f5f9;display:flex;min-height:100vh;}
.admin-sidebar{width:240px;min-height:100vh;background:linear-gradient(180deg,#1a3a5c 0%,#122b45 100%);position:fixed;top:0;left:0;z-index:1000;overflow-y:auto;transition:transform 0.3s;}
.sidebar-header{display:flex;align-items:center;border-bottom:1px solid rgba(255,255,255,0.1);}
.sidebar-nav{padding-top:8px;}
.sidebar-nav .nav-item{display:flex;align-items:center;padding:9px 14px;border-radius:8px;color:rgba(255,255,255,0.75);text-decoration:none;font-size:0.875rem;margin-bottom:2px;transition:background 0.15s,color 0.15s;}
.sidebar-nav .nav-item:hover{background:rgba(255,255,255,0.1);color:#fff;}
.sidebar-nav .nav-item.active{background:rgba(255,255,255,0.18);color:#fff;font-weight:600;}
.admin-content{margin-left:240px;flex:1;min-height:100vh;display:flex;flex-direction:column;}
.admin-topbar{background:#fff;border-bottom:1px solid #e2e8f0;min-height:52px;position:sticky;top:0;z-index:100;}
.stat-admin-card{border-radius:12px;transition:transform .15s,box-shadow .15s;color:#1f2937;}
.stat-admin-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.1) !important;}
.stat-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;}
.table{font-size:0.875rem;}
.table th{font-size:0.75rem;text-transform:uppercase;letter-spacing:0.5px;color:#6b7280;font-weight:600;}
@media(max-width:992px){.admin-sidebar{transform:translateX(-100%)}.admin-sidebar.show{transform:translateX(0)}.admin-content{margin-left:0}}
.opacity-90{opacity:0.9 !important;}
.text-yellow{color:#f5a623 !important;}
.bg-dark-navy{background-color:#1a3a5c !important;}
@media print{.admin-sidebar,.admin-topbar,.btn,nav{display:none !important}.admin-content{margin-left:0 !important}.card{box-shadow:none !important;border:1px solid #ddd !important}}

/* Mobile Responsive Styles for Registration and Dashboard */
@media (max-width: 576px) {
  .auth-card {
    padding: 1.25rem !important;
    margin: 0.5rem;
    border-radius: 12px !important;
  }
  .auth-card h2 {
    font-size: 1.25rem !important;
  }
  .auth-body {
    padding: 1rem 0.5rem !important;
    min-height: auto;
  }
  .step-bar {
    margin: 0 0.5rem;
  }
  .form-label {
    font-size: 0.8rem;
  }
  .form-control, .form-select {
    font-size: 16px; /* Prevents zoom on iOS */
  }
  .btn {
    padding: 0.5rem 1rem;
  }
  .d-flex.justify-content-between {
    flex-direction: column;
    gap: 0.75rem;
  }
  .d-flex.justify-content-between .btn {
    width: 100%;
  }
  .navbar {
    padding: 0.5rem 0;
  }
  .navbar-brand img {
    width: 32px !important;
    height: 32px !important;
  }
  .navbar-brand .fw-bold {
    font-size: 0.85rem !important;
  }
  .btn-nav-login, .btn-nav-register {
    padding: 0.3rem 0.7rem;
    font-size: 0.8rem;
  }
  footer .row {
    text-align: center;
  }
  footer .col-lg-4 {
    margin-bottom: 1.5rem;
  }
}

@media (max-width: 768px) {
  .hero-section {
    min-height: 400px;
    padding: 2rem 0;
  }
  .hero-subtitle {
    font-size: 1.2rem;
  }
  .hero-content h1 {
    font-size: 1.75rem;
  }
  .feature-card {
    margin-bottom: 1rem;
  }
  .stat-card {
    margin-bottom: 1rem;
  }
  .page-header h1 {
    font-size: 1.25rem;
  }
  .table-responsive {
    font-size: 0.85rem;
  }
  .table-responsive th, .table-responsive td {
    padding: 0.5rem;
  }
  .admin-table th, .admin-table td {
    padding: 0.4rem 0.3rem;
    font-size: 0.75rem;
  }
  .admin-avatar {
    width: 28px !important;
    height: 28px !important;
    font-size: 0.65rem !important;
  }
  .btn-sm {
    padding: 0.2rem 0.4rem;
    font-size: 0.7rem;
  }
}

/* Camera and upload mobile styles */
@media (max-width: 576px) {
  .camera-preview, .camera-placeholder, .selfie-preview {
    height: 180px;
  }
  .camera-placeholder i {
    font-size: 2rem;
  }
  .camera-placeholder span {
    font-size: 0.8rem;
  }
  .id-preview-container {
    height: 120px;
  }
  .upload-area {
    padding: 1rem;
  }
  .upload-area i {
    font-size: 1.5rem;
  }
  .upload-area p {
    font-size: 0.75rem;
    margin-bottom: 0 !important;
  }
}

/* Dashboard mobile styles */
@media (max-width: 576px) {
  .container.py-5 {
    padding: 1rem 0.5rem !important;
  }
  .page-header {
    text-align: center;
  }
  .page-header h1 {
    font-size: 1.1rem;
  }
  .card {
    margin-bottom: 1rem;
  }
  .table {
    margin-bottom: 0;
  }
  .badge {
    font-size: 0.65rem;
    padding: 0.3rem 0.5rem;
  }
  .d-flex.flex-wrap.gap-2.small {
    justify-content: center;
  }
}
