:root{
  --dz-black:#1a1a1a;
  --dz-dark:#2a2a2a;
  --dz-green:#0f5132;
  --dz-green-2:#147a4a;
  --dz-green-soft:#1f8b59;
  --dz-white:#ffffff;
  --dz-bg:#f4f6f5;
  --dz-bg-2:#ffffff;
  --dz-text:#1a1a1a;
  --dz-muted:#5f6b66;
  --dz-card:#ffffff;
  --dz-border:#e3e7e5;
  --dz-soft:#eef2f0;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  background:var(--dz-bg);
  color:var(--dz-text);
  font-family:'Inter','Segoe UI',Roboto,system-ui,sans-serif;
  margin:0;
}

/* Brand */
.dz-brand{
  font-weight:800;
  letter-spacing:.5px;
  color:var(--dz-black);
  text-decoration:none;
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:1.25rem;
}
.dz-brand .dot{
  width:14px;height:14px;border-radius:50%;
  background:var(--dz-green-2);
  box-shadow:0 0 0 4px rgba(20,122,74,.18);
}
.dz-brand small{color:var(--dz-green);font-weight:700;letter-spacing:2px;font-size:.65rem;text-transform:uppercase}

/* Navbar */
.dz-navbar{
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--dz-border);
}
.dz-navbar .nav-link{color:var(--dz-muted);font-weight:500}
.dz-navbar .nav-link:hover{color:var(--dz-green)}

/* Buttons */
.btn-dz{
  background:var(--dz-green);
  color:#fff;
  border:none;
  padding:.6rem 1.2rem;
  border-radius:.6rem;
  font-weight:600;
  transition:.2s;
}
.btn-dz:hover{background:var(--dz-green-2);color:#fff;transform:translateY(-1px)}
.btn-dz-outline{
  background:transparent;color:var(--dz-green);border:1px solid var(--dz-green);
  padding:.6rem 1.2rem;border-radius:.6rem;font-weight:600;
}
.btn-dz-outline:hover{background:var(--dz-green);color:#fff}
.btn-ghost{background:transparent;color:var(--dz-muted);border:1px solid var(--dz-border);border-radius:.5rem}
.btn-ghost:hover{color:var(--dz-green);border-color:var(--dz-green-2);background:#fff}

/* Hero */
.dz-hero{
  padding:6rem 0 4rem;
  background:
    radial-gradient(800px 400px at 80% 0%, rgba(20,122,74,.18), transparent 60%),
    radial-gradient(600px 300px at 0% 100%, rgba(20,122,74,.10), transparent 60%),
    linear-gradient(180deg,#ffffff,#f4f6f5);
  border-bottom:1px solid var(--dz-border);
}
.dz-hero h1{font-size:3.2rem;font-weight:800;line-height:1.05;color:var(--dz-black)}
.dz-hero h1 .accent{color:var(--dz-green)}
.dz-hero p.lead{color:var(--dz-muted);font-size:1.15rem;max-width:560px}

/* Cards */
.dz-card{
  background:var(--dz-card);
  border:1px solid var(--dz-border);
  border-radius:1rem;
  padding:1.25rem;
  transition:.2s;
  box-shadow:0 2px 6px rgba(15,81,50,.04);
}
.dz-card:hover{border-color:var(--dz-green-2);box-shadow:0 6px 20px rgba(15,81,50,.08)}
.dz-card .avatar{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--dz-green),var(--dz-green-soft));
  display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;
}
.dz-card .meta{color:var(--dz-muted);font-size:.85rem}
.dz-card .post-actions{
  display:flex;gap:.5rem;border-top:1px solid var(--dz-border);
  padding-top:.75rem;margin-top:.75rem;
}
.dz-card .post-actions button{
  flex:1;background:transparent;border:none;color:var(--dz-muted);
  padding:.5rem;border-radius:.5rem;font-weight:500;
}
.dz-card .post-actions button:hover{background:var(--dz-soft);color:var(--dz-green)}

/* Auth */
.dz-auth-wrap{
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(700px 400px at 30% 20%, rgba(20,122,74,.18), transparent 60%),
    linear-gradient(180deg,#ffffff,#eef2f0);
  padding:2rem 1rem;
}
.dz-auth{
  background:var(--dz-card);
  border:1px solid var(--dz-border);
  border-radius:1.25rem;
  padding:2.5rem;
  width:100%;max-width:440px;
  box-shadow:0 20px 60px rgba(15,81,50,.12);
}
.dz-auth h1{font-size:1.8rem;font-weight:800;margin-bottom:.25rem;color:var(--dz-black)}
.dz-auth .sub{color:var(--dz-muted);margin-bottom:1.75rem}
.dz-auth .form-control{
  background:#fff;border:1px solid var(--dz-border);color:var(--dz-text);
  padding:.75rem 1rem;border-radius:.6rem;
}
.dz-auth .form-control:focus{
  background:#fff;color:var(--dz-text);border-color:var(--dz-green-2);
  box-shadow:0 0 0 .2rem rgba(20,122,74,.18);
}
.dz-auth label{color:var(--dz-muted);font-size:.85rem;margin-bottom:.4rem}

/* Dashboard layout */
.dz-app{display:grid;grid-template-columns:260px 1fr;min-height:100vh;background:var(--dz-bg)}
.dz-sidebar{
  background:#0f1410;
  color:#e8efe9;
  border-right:1px solid #1a201c;
  padding:1.5rem 1rem;
  position:sticky;top:0;height:100vh;
  overflow-y:auto;
}
.dz-sidebar .dz-brand{color:#fff}
.dz-sidebar .side-link{
  display:flex;align-items:center;gap:.75rem;
  padding:.7rem .9rem;border-radius:.6rem;color:#b9c4bd;
  text-decoration:none;font-weight:500;margin-bottom:.25rem;
}
.dz-sidebar .side-link:hover{background:#1a201c;color:#fff}
.dz-sidebar .side-link.active{background:var(--dz-green);color:#fff}
.dz-sidebar .side-link .ic{
  width:34px;height:34px;border-radius:.5rem;background:#1a201c;
  display:flex;align-items:center;justify-content:center;color:var(--dz-green-soft);
}
.dz-sidebar .side-link.active .ic{background:rgba(255,255,255,.18);color:#fff}
.dz-sidebar .group{color:#6b7a72;font-size:.7rem;text-transform:uppercase;letter-spacing:2px;margin:1.25rem .5rem .5rem}

.dz-main{padding:0;background:var(--dz-bg)}
.dz-topbar{
  position:sticky;top:0;z-index:10;
  background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--dz-border);
  padding:1rem 1.5rem;
  display:flex;gap:1rem;align-items:center;justify-content:space-between;
}
.dz-quote{
  display:flex;align-items:center;gap:.75rem;
  background:linear-gradient(90deg,rgba(20,122,74,.12),rgba(20,122,74,0));
  border:1px solid rgba(20,122,74,.25);
  padding:.6rem 1rem;border-radius:.7rem;color:var(--dz-text);
  font-style:italic;flex:1;max-width:720px;
}
.dz-quote .badge-q{
  background:var(--dz-green);color:#fff;font-size:.65rem;
  letter-spacing:1px;padding:.25rem .5rem;border-radius:.4rem;font-style:normal;
}

/* Facebook-style narrower feed */
.dz-feed{padding:1.5rem;max-width:560px;margin:0 auto}

/* Composer */
.dz-composer{
  background:var(--dz-card);border:1px solid var(--dz-border);
  border-radius:1rem;padding:1rem;margin-bottom:1.5rem;
  box-shadow:0 2px 6px rgba(15,81,50,.04);
}
.dz-composer textarea{
  width:100%;background:#fff;border:1px solid var(--dz-border);
  color:var(--dz-text);border-radius:.6rem;padding:.8rem 1rem;resize:none;min-height:80px;
}
.dz-composer textarea:focus{outline:none;border-color:var(--dz-green-2)}

/* Feed posts: portrait/FB style */
.dz-post{
  background:#fff;border:1px solid var(--dz-border);
  border-radius:.9rem;margin-bottom:1.25rem;overflow:hidden;
  box-shadow:0 1px 3px rgba(0,0,0,.05);
}
.dz-post .head{display:flex;align-items:center;gap:.75rem;padding:.9rem 1rem .25rem}
.dz-post .head .avatar{width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--dz-green),var(--dz-green-soft));
  color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}
.dz-post .head .name{font-weight:700;color:var(--dz-black);line-height:1.1}
.dz-post .head .time{color:var(--dz-muted);font-size:.78rem}
.dz-post .body{padding:.6rem 1rem 1rem;color:var(--dz-text);font-size:1rem;line-height:1.5}
.dz-post .stats{padding:.5rem 1rem;color:var(--dz-muted);font-size:.8rem;border-top:1px solid var(--dz-soft)}
.dz-post .actions{display:flex;border-top:1px solid var(--dz-soft)}
.dz-post .actions button{
  flex:1;background:transparent;border:none;color:var(--dz-muted);
  padding:.7rem;font-weight:600;font-size:.9rem;
}
.dz-post .actions button:hover{background:var(--dz-soft);color:var(--dz-green)}
.dz-post .actions button.liked{color:var(--dz-green)}

/* Landing post grid -> portrait cards */
.dz-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem}

.dz-section-title{font-weight:800;font-size:1.75rem;margin-bottom:.25rem;color:var(--dz-black)}
.dz-section-sub{color:var(--dz-muted);margin-bottom:2rem}

footer.dz-footer{
  border-top:1px solid var(--dz-border);
  padding:2rem 0;color:var(--dz-muted);text-align:center;margin-top:4rem;
  background:#fff;
}

/* Status pills (councilors) */
.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block}
.status-dot.online{background:#1f8b59;box-shadow:0 0 0 4px rgba(31,139,89,.2)}
.status-dot.offline{background:#b8c1bc}
.status-pill{font-size:.75rem;color:var(--dz-muted)}

/* Chat */
.bubble{max-width:70%;padding:.6rem .85rem;border-radius:1rem;margin:.25rem 0;line-height:1.4}
.bubble.me{background:var(--dz-green);color:#fff;align-self:flex-end;border-bottom-right-radius:.3rem}
.bubble.them{background:#eef2f0;color:var(--dz-text);align-self:flex-start;border-bottom-left-radius:.3rem}

/* Mobile */
@media (max-width: 900px){
  .dz-app{grid-template-columns:1fr}
  .dz-sidebar{position:relative;height:auto;display:flex;flex-wrap:wrap;gap:.5rem}
  .dz-sidebar .group{width:100%}
  .dz-sidebar .side-link{flex:1 1 45%}
  .dz-hero h1{font-size:2.2rem}
  .dz-quote{font-size:.85rem}
  .dz-feed{padding:1rem}
}
