*{
  box-sizing:border-box;
  margin:0;
  padding:0;
}

:root{
  --primary:#2563EB;
  --primary-hover:#1D4ED8;
  --accent-bg:#E0ECFF;
  --page-bg:#F8FAFC;
  --card-bg:#FFFFFF;
  --border:#E5E7EB;
  --border-strong:#D7DFEA;
  --text:#0F172A;
  --text-muted:#64748B;
  --success:#16A34A;
  --danger:#DC2626;
  --warning:#F59E0B;
  --info:#0EA5E9;

  --shadow:0 10px 30px rgba(15,23,42,0.06);
  --shadow-soft:0 4px 18px rgba(15,23,42,0.04);

  --radius-btn:10px;
  --radius-card:16px;
  --radius-lg:20px;

  --container:1180px;
}

html{
  scroll-behavior:smooth;
}

body{
  font-family:'Inter',sans-serif;
  background:var(--page-bg);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

.auth-page{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:40px 20px;
}

a{
  color:inherit;
  text-decoration:none;
}

img{
  max-width:100%;
  display:block;
}

button,
input,
textarea,
select{
  font:inherit;
}

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 20px;
}

.page-wrap{
  min-height:calc(100vh - 180px);
  padding:28px 0 0;
}

/* HEADER */

.site-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(248,250,252,0.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(229,231,235,0.9);
}

.navbar-shell{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 20px;
}

.navbar{
  min-height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}

.logo{
  display:flex;
  align-items:center;
  gap:12px;
  font-weight:800;
  font-size:1.15rem;
  color:var(--text);
  flex-shrink:0;
}

.logo-img{
  width:42px;
  height:42px;
  object-fit:contain;
  object-position:center;
  border-radius:12px;
  display:block;
  flex-shrink:0;
}

.logo-text{
  letter-spacing:-0.02em;
  line-height:1;
}

.nav-links{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

.nav-item{
  color:var(--text-muted);
  font-weight:600;
  padding:10px 14px;
  border-radius:10px;
  transition:all 0.2s ease;
}

.nav-item:hover{
  color:var(--primary);
  background:#EFF6FF;
}

/* BUTTONS */

.btn,
.btn-outline,
.btn-soft{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:none;
  outline:none;
  cursor:pointer;
  font-family:inherit;
  font-weight:600;
  font-size:15px;
  border-radius:var(--radius-btn);
  transition:all 0.2s ease;
  padding:12px 20px;
  line-height:1;
  text-decoration:none;
  white-space:nowrap;
}

.btn{
  background:var(--primary);
  color:#fff !important;
  box-shadow:0 10px 22px rgba(37,99,235,0.14);
}

.btn:hover{
  background:var(--primary-hover);
  transform:translateY(-1px);
}

.btn-primary{
  background:var(--primary);
  color:#fff !important;
  box-shadow:0 10px 22px rgba(37,99,235,0.14);
}

.btn-primary:hover{
  background:var(--primary-hover);
  transform:translateY(-1px);
}

.btn-outline{
  background:#fff;
  color:var(--text) !important;
  border:1px solid var(--border);
  box-shadow:none;
}

.btn-outline:hover{
  background:#F8FAFC;
  border-color:#D1D5DB;
  color:var(--text) !important;
  transform:none;
}

.btn-soft{
  background:#F1F5F9;
  color:var(--text) !important;
  border:1px solid var(--border);
  box-shadow:none;
}

.btn-soft:hover{
  background:#E2E8F0;
  color:var(--text) !important;
  transform:none;
}

.logout-btn{
  padding:12px 18px;
}

/* HERO */

.hero{
  text-align:center;
  padding:82px 0 64px;
}

.hero-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--accent-bg);
  color:var(--primary);
  padding:8px 14px;
  border-radius:999px;
  font-size:14px;
  font-weight:700;
  margin-bottom:20px;
}

.hero h1{
  font-size:56px;
  font-weight:800;
  line-height:1.08;
  letter-spacing:-1.4px;
  margin-bottom:18px;
}

.hero span{
  color:var(--primary);
}

.hero p{
  max-width:700px;
  margin:0 auto 30px;
  color:var(--text-muted);
  font-size:18px;
}

.hero-buttons{
  display:flex;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
}

/* SECTIONS */

.section{
  padding:70px 0;
}

.section.center{
  text-align:center;
}

.section h1,
.section h2{
  line-height:1.15;
  letter-spacing:-0.7px;
}

.section h2{
  font-size:34px;
  margin-bottom:14px;
}

.section-sub{
  color:var(--text-muted);
  margin-bottom:40px;
  max-width:700px;
}

.section.center .section-sub{
  margin-left:auto;
  margin-right:auto;
}

/* GRID */

.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:24px;
}

.steps{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:24px;
}

/* CARDS */

.card,
.step{
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:var(--radius-card);
  padding:28px;
  box-shadow:var(--shadow-soft);
}

.card{
  text-align:left;
}

.card-icon{
  width:54px;
  height:54px;
  background:var(--accent-bg);
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--primary);
  font-weight:800;
  margin-bottom:18px;
}

.card h3,
.step h3{
  font-size:1.12rem;
  line-height:1.3;
  margin-bottom:10px;
}

.card p,
.step p{
  color:var(--text-muted);
}

/* STEPS */

.step-number{
  font-size:28px;
  font-weight:800;
  color:#93C5FD;
  margin-bottom:12px;
  line-height:1;
}

/* CTA */

.cta{
  background:linear-gradient(135deg, #2563EB, #1D4ED8);
  color:white;
  padding:60px 24px;
  border-radius:24px;
  max-width:920px;
  margin:80px auto;
  text-align:center;
  box-shadow:0 24px 40px rgba(37,99,235,0.18);
}

.cta h2{
  font-size:34px;
  line-height:1.15;
  margin-bottom:14px;
  letter-spacing:-0.7px;
}

.cta p{
  opacity:0.95;
  margin-bottom:24px;
  font-size:16px;
}

.cta .btn{
  background:#fff;
  color:var(--primary) !important;
  box-shadow:none;
}

.cta .btn:hover{
  background:#F8FAFC;
}

/* PANELS */

.panel{
  background:#fff;
  border:1px solid var(--border);
  border-radius:16px;
  padding:28px;
  box-shadow:var(--shadow-soft);
}

.panel-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:20px;
}

.panel-title{
  font-size:20px;
  font-weight:700;
  color:var(--text);
}

/* FORMS */

form{
  width:100%;
}

label{
  display:block;
  margin-bottom:8px;
  font-weight:600;
  color:var(--text);
  font-size:14px;
}

input,
textarea,
select{
  width:100%;
  padding:13px 15px;
  margin-bottom:16px;
  border:1px solid var(--border);
  border-radius:12px;
  background:#fff;
  color:var(--text);
  outline:none;
  transition:all 0.2s ease;
  font-size:15px;
  font-family:inherit;
}

input::placeholder,
textarea::placeholder,
select{
  color:#94A3B8;
}

input:focus,
textarea:focus,
select:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 4px rgba(37,99,235,0.10);
}

textarea{
  min-height:120px;
  resize:vertical;
}

form button{
  width:auto;
  min-width:160px;
}

/* TABLES */

.table-wrap{
  width:100%;
  overflow-x:auto;
  border-radius:16px;
}

table{
  width:100%;
  border-collapse:collapse;
  background:#fff;
  border:1px solid var(--border);
  border-radius:16px;
  overflow:hidden;
  box-shadow:var(--shadow-soft);
}

table th{
  background:#F8FAFC;
  color:var(--text-muted);
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:0.4px;
  padding:15px 16px;
  text-align:left;
  border-bottom:1px solid var(--border);
}

table td{
  padding:15px 16px;
  border-bottom:1px solid #F1F5F9;
  color:var(--text);
  vertical-align:middle;
}

table tr:last-child td{
  border-bottom:none;
}

table tr:hover td{
  background:#F8FAFC;
}

/* ALERTS / MESSAGES */

.message{
  background:#EFF6FF;
  border:1px solid #BFDBFE;
  color:var(--primary-hover);
  padding:14px 16px;
  border-radius:12px;
  margin-bottom:16px;
  font-weight:500;
}

/* TEXT HELPERS */

.small{
  color:var(--text-muted);
  font-size:14px;
  line-height:1.7;
}

.muted{
  color:var(--text-muted);
}

.text-center{
  text-align:center;
}

/* BADGES */

.badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:7px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  line-height:1;
}

.badge-primary{
  background:var(--accent-bg);
  color:var(--primary);
}

.badge-success{
  background:#DCFCE7;
  color:#15803D;
}

.badge-warning{
  background:#FEF3C7;
  color:#B45309;
}

.badge-danger{
  background:#FEE2E2;
  color:#B91C1C;
}

/* FOOTER */

.footer{
  background:#0F172A;
  border-top:1px solid #1E293B;
  margin-top:80px;
  padding:60px 0 30px;
}

.footer-top{
  display:grid;
  grid-template-columns:1.3fr 0.8fr 0.9fr 1fr;
  gap:32px;
  padding-bottom:28px;
}

.footer-brand-col{
  max-width:420px;
}

.footer-logo{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:14px;
}

.footer-logo-img{
  width:42px;
  height:42px;
  object-fit:contain;
  border-radius:12px;
  flex-shrink:0;
}

.footer-logo-text{
  color:#FFFFFF;
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:-0.02em;
}

.footer-desc{
  color:#94A3B8;
  font-size:14px;
  line-height:1.8;
}

.footer-links-col h4{
  color:#F8FAFC;
  font-size:15px;
  font-weight:700;
  margin-bottom:14px;
}

.footer-links-col a{
  display:block;
  color:#94A3B8;
  font-size:14px;
  margin-bottom:10px;
  transition:0.2s ease;
}

.footer-links-col a:hover{
  color:#FFFFFF;
}

.footer .small{
  color:#94A3B8;
  font-size:14px;
  line-height:1.8;
}

.footer-bottom{
  border-top:1px solid #1E293B;
  padding-top:20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}

/* AUTH PAGES */

.auth-container,
.auth-wrap{
  width:100%;
  max-width:480px;
}

.brand,
.admin-brand{
  text-align:center;
  margin-bottom:26px;
}

.brand img,
.admin-brand img{
  width:54px;
  height:54px;
  border-radius:12px;
  margin:0 auto 14px;
  display:block;
}

.brand h1,
.admin-brand h1{
  font-size:24px;
  font-weight:800;
  margin-bottom:4px;
}

.brand p,
.admin-brand p{
  color:var(--text-muted);
  font-size:14px;
}

.auth-card,
.admin-card{
  background:#FFFFFF;
  border:1px solid var(--border);
  border-radius:16px;
  padding:30px;
  box-shadow:0 8px 24px rgba(15,23,42,.05);
}

.auth-card h2,
.admin-card h2{
  font-size:20px;
  margin-bottom:20px;
  font-weight:700;
}

.captcha-box{
  background:var(--accent-bg);
  border:1px solid #BFDBFE;
  color:var(--primary);
  padding:12px 14px;
  border-radius:12px;
  font-size:14px;
  font-weight:700;
  margin-bottom:12px;
}

.bottom-text,
.bottom,
.admin-bottom{
  text-align:center;
  margin-top:18px;
  color:var(--text-muted);
  font-size:14px;
}

.bottom-text a,
.bottom a{
  color:var(--primary);
  text-decoration:none;
  font-weight:600;
}

.bottom-text a:hover,
.bottom a:hover{
  text-decoration:underline;
}

/* PAGE SPECIFIC HELPERS */

.contact-page-grid{
  grid-template-columns:1fr 1fr;
}

.dashboard-grid{
  grid-template-columns:1.2fr 0.8fr;
}

.form-layout{
  grid-template-columns:1.15fr 0.85fr;
}

.legal-grid{
  grid-template-columns:1.1fr 0.9fr;
}

.two-col{
  grid-template-columns:1fr 1fr;
}

/* ADMIN LAYOUT */

.admin-body{
  background:#F8FAFC;
}

.admin-layout{
  min-height:100vh;
  display:grid;
  grid-template-columns:280px 1fr;
}

.admin-sidebar{
  background:#0F172A;
  color:#E2E8F0;
  border-right:1px solid #1E293B;
  padding:24px 18px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  position:sticky;
  top:0;
  height:100vh;
}

.admin-sidebar-top{
  margin-bottom:20px;
}

.admin-sidebar-brand{
  display:flex;
  align-items:center;
  gap:12px;
}

.admin-sidebar-logo{
  width:44px;
  height:44px;
  object-fit:contain;
  border-radius:12px;
  flex-shrink:0;
}

.admin-sidebar-title{
  color:#FFFFFF;
  font-weight:800;
  font-size:1.05rem;
  line-height:1.1;
}

.admin-sidebar-subtitle{
  color:#94A3B8;
  font-size:13px;
  margin-top:2px;
}

.admin-sidebar-nav{
  display:grid;
  gap:8px;
  margin-top:10px;
}

.admin-sidebar-link{
  display:block;
  padding:12px 14px;
  border-radius:12px;
  color:#CBD5E1;
  font-weight:600;
  transition:0.2s ease;
}

.admin-sidebar-link:hover{
  background:#1E293B;
  color:#FFFFFF;
}

.admin-sidebar-link-active{
  background:#2563EB;
  color:#FFFFFF !important;
}

.admin-sidebar-bottom{
  margin-top:24px;
}

.admin-admin-box{
  background:#111C2D;
  border:1px solid #1E293B;
  border-radius:14px;
  padding:14px;
  margin-bottom:14px;
}

.admin-admin-label{
  color:#94A3B8;
  font-size:12px;
  margin-bottom:4px;
}

.admin-admin-name{
  color:#FFFFFF;
  font-weight:700;
  font-size:14px;
}

.admin-logout-btn{
  width:100%;
}

.admin-main{
  min-width:0;
}

.admin-main-inner{
  padding:28px;
}

/* UTILITY SPACING */

.mb-0{ margin-bottom:0 !important; }
.mb-1{ margin-bottom:8px !important; }
.mb-2{ margin-bottom:16px !important; }
.mb-3{ margin-bottom:24px !important; }
.mb-4{ margin-bottom:32px !important; }

/* LARGE SCREENS */

@media (min-width: 1400px){
  :root{
    --container:1280px;
  }

  .hero h1{
    font-size:62px;
  }
}

/* TABLET / LAPTOP */

@media (max-width: 1100px){
  .dashboard-grid,
  .form-layout,
  .legal-grid,
  .contact-page-grid,
  .two-col{
    grid-template-columns:1fr !important;
  }

  .footer-top{
    grid-template-columns:1fr 1fr;
  }
}

/* TABLET */

@media (max-width: 980px){
  .admin-layout{
    grid-template-columns:1fr;
  }

  .admin-sidebar{
    position:relative;
    height:auto;
    border-right:none;
    border-bottom:1px solid #1E293B;
  }

  .admin-sidebar-nav{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media (max-width: 900px){
  .navbar{
    padding:14px 0;
    flex-direction:column;
    align-items:flex-start;
  }

  .nav-links{
    width:100%;
    gap:8px;
  }

  .hero h1{
    font-size:42px;
  }

  .footer-bottom{
    flex-direction:column;
    align-items:flex-start;
  }

  .panel-header{
    flex-direction:column;
    align-items:flex-start;
  }
}

/* MOBILE */

@media (max-width: 600px){
  .container{
    padding:0 16px;
  }

  .navbar-shell{
    padding:0 16px;
  }

  .page-wrap{
    padding-top:22px;
  }

  .hero{
    padding:58px 0 46px;
  }

  .hero h1{
    font-size:34px;
    letter-spacing:-1px;
  }

  .hero p{
    font-size:16px;
  }

  .section{
    padding:50px 0;
  }

  .section h2,
  .cta h2{
    font-size:28px;
  }

  .btn,
  .btn-outline,
  .btn-primary,
  .btn-soft,
  form button{
    width:100%;
  }

  .nav-links{
    flex-direction:column;
    align-items:stretch;
  }

  .nav-item{
    width:100%;
  }

  .grid,
  .steps{
    grid-template-columns:1fr;
  }

  .card,
  .step,
  .footer-card,
  .panel,
  .auth-card,
  .admin-card{
    padding:22px;
  }

  .cta{
    padding:40px 18px;
    border-radius:20px;
    margin:50px auto;
  }

  .footer{
    padding:45px 0 28px;
    margin-top:50px;
  }

  .footer-top{
    grid-template-columns:1fr;
    gap:24px;
  }

  .admin-main-inner{
    padding:18px 16px;
  }

  .admin-sidebar{
    padding:18px 16px;
  }

  .admin-sidebar-nav{
    grid-template-columns:1fr;
  }

  table th,
  table td{
    padding:12px 12px;
    font-size:14px;
  }
}