/* ═══════════════════════════════════════
   HakiGH — Ghana Citizen Legal Rights
   Style Sheet v1.0
   Colour: Midnight Blue · Ghana Glow Edges
═══════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

:root{
  --bg:      #080f1f;
  --bg2:     #0c1528;
  --card:    #0f1c35;
  --card2:   #132040;
  --border:  #1e3058;
  --border2: #253968;
  --accent:  #4f8ef7;
  --accent2: #3a75e0;
  --accentlo:#4f8ef720;
  --gold:    #e8b84b;
  --goldlo:  #e8b84b18;
  --text:    #dce8ff;
  --text2:   #7a9cc8;
  --text3:   #4a6898;
  --white:   #ffffff;
}

html{scroll-behavior:smooth;}
body{
  background:var(--bg);
  font-family:'DM Sans',sans-serif;
  color:var(--text);
  min-height:100vh;
  overflow-x:hidden;
}

::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:#1e3058;border-radius:4px;}

/* ── ANIMATIONS ── */
@keyframes dotBounce{0%,100%{transform:translateY(0);opacity:.4}50%{transform:translateY(-5px);opacity:1}}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:.6}50%{opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}


button{cursor:pointer;font-family:'DM Sans',sans-serif;}
button:hover{filter:brightness(1.08);}
a{text-decoration:none;}

/* ── GHANA GLOW EDGES ── */
.glow-top,.glow-bottom{position:fixed;left:0;right:0;height:3px;display:flex;z-index:300;pointer-events:none;}
.glow-top{top:0;}.glow-bottom{bottom:0;}
.glow-left,.glow-right{position:fixed;top:0;bottom:0;width:3px;display:flex;flex-direction:column;z-index:300;pointer-events:none;}
.glow-left{left:0;}.glow-right{right:0;}
.gb{flex:1;}

/* ── HEADER ── */
header{
  background:rgba(8,15,31,0.97);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:200;
}
.header-inner{
  max-width:920px;margin:0 auto;padding:13px 22px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.logo{display:flex;align-items:center;gap:12px;cursor:pointer;flex-shrink:0;}
.logo-mark{
  width:36px;height:36px;border-radius:10px;
  background:var(--accent2);display:flex;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:700;
  color:#fff;flex-shrink:0;letter-spacing:-.5px;
}
.logo-text{font-family:'Cormorant Garamond',serif;font-weight:700;font-size:22px;color:var(--white);line-height:1;}
.logo-sub{font-size:10px;color:var(--text3);letter-spacing:.12em;text-transform:uppercase;margin-top:2px;}
.header-right{display:flex;align-items:center;gap:10px;}
nav{display:flex;gap:3px;}
.nav-btn{
  background:none;border:1px solid transparent;border-radius:8px;
  padding:7px 13px;font-size:13px;color:var(--text2);font-weight:500;transition:all .2s;
}
.nav-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accentlo);}
.lang-toggle{
  display:flex;align-items:center;background:var(--card);
  border:1px solid var(--border);border-radius:20px;padding:3px;gap:2px;
}
.lang-btn{padding:5px 11px;border-radius:16px;font-size:12px;font-weight:600;border:none;background:transparent;color:var(--text2);transition:all .2s;}
.lang-btn.active{background:var(--accent2);color:#fff;}

/* ── MAIN / PAGES ── */
main{max-width:920px;margin:0 auto;padding:0 18px 80px;}
.page{padding-top:36px;animation:fadeUp .4s ease;}

/* ── HERO ── */
.hero{padding:56px 0 44px;border-bottom:1px solid var(--border);margin-bottom:28px;}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent);font-weight:600;margin-bottom:20px;
  background:var(--accentlo);border:1px solid rgba(79,142,247,.2);
  padding:5px 14px;border-radius:20px;
}
.hero-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(42px,8vw,74px);
  font-weight:700;line-height:1.04;color:var(--white);
  margin-bottom:20px;letter-spacing:-.5px;
}
.hero-title em{font-style:italic;color:var(--accent);}
.hero-body{font-size:16px;color:var(--text2);line-height:1.75;max-width:520px;margin-bottom:32px;}
.hero-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.cta-primary{
  background:var(--accent2);color:#fff;border:none;border-radius:12px;
  padding:14px 30px;font-size:15px;font-weight:600;letter-spacing:.01em;
}
.cta-secondary{
  background:transparent;color:var(--accent);
  border:1px solid var(--border2);border-radius:12px;
  padding:14px 22px;font-size:15px;font-weight:500;
}
.trust-bar{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  margin-top:28px;padding-top:28px;border-top:1px solid var(--border);
}
.trust-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text3);}
.trust-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.5;}

/* ── TIP BANNER ── */
.tip-row{
  background:var(--card);border:1px solid var(--border);border-radius:14px;
  padding:16px 20px;display:flex;align-items:center;gap:14px;
  margin-bottom:32px;border-left:3px solid var(--accent);
}
.tip-inner{transition:opacity .4s;}
.tip-text{font-size:14px;font-weight:500;color:var(--text);line-height:1.5;}
.tip-law{font-size:11px;color:var(--accent);font-weight:600;letter-spacing:.04em;margin-top:5px;}

/* ── SECTION / CATEGORY GRID ── */
.section-label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text3);font-weight:600;margin-bottom:16px;}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:10px;margin-bottom:32px;}
.cat-card{
  background:var(--card);border:1px solid var(--border);border-radius:14px;
  padding:20px 17px;display:flex;flex-direction:column;align-items:flex-start;
  gap:6px;text-align:left;transition:border-color .2s,background .2s;
}
.cat-card:hover{border-color:var(--accent);background:var(--card2);}
.cat-icon{font-size:22px;margin-bottom:4px;}
.cat-label{font-weight:600;font-size:14px;color:var(--white);}
.cat-desc{font-size:12px;color:var(--text2);line-height:1.45;flex:1;}
.cat-arrow{font-size:14px;color:var(--accent);margin-top:6px;font-weight:600;}

/* ── EMERGENCY BAR ── */
.emergency-bar{
  background:rgba(206,17,38,.08);border:1px solid rgba(206,17,38,.25);
  border-radius:14px;padding:18px 22px;
  display:flex;align-items:center;gap:16px;margin-top:8px;
}
.emergency-title{font-weight:600;font-size:14px;color:#ff7080;}
.emergency-num{font-size:13px;color:var(--text2);margin-top:3px;}

/* ── CHAT ── */
.chat-wrap{padding-top:16px;height:calc(100vh - 82px);display:flex;flex-direction:column;animation:fadeUp .3s ease;}
.chat-top{
  background:var(--card);border:1px solid var(--border);border-radius:13px;
  padding:12px 18px;display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;
}
.back-btn{background:none;border:1px solid var(--border);border-radius:8px;padding:6px 12px;font-size:13px;color:var(--text2);}
.chat-top-title{font-weight:600;font-size:15px;color:var(--white);}
.live-chip{font-size:11px;color:#4ade80;font-weight:600;display:flex;align-items:center;gap:5px;animation:pulse 2s infinite;}
.live-dot{width:6px;height:6px;border-radius:50%;background:#4ade80;}
.messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:13px;padding:4px 0 12px;}
.msg-row{display:flex;align-items:flex-end;gap:10px;animation:fadeUp .25s ease;}
.bot-avatar{
  width:34px;height:34px;border-radius:50%;
  background:var(--accentlo);border:1px solid var(--border2);
  display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;
}
.bubble{max-width:75%;padding:12px 16px;border-radius:18px;font-size:14px;line-height:1.7;}
.bubble-user{background:var(--accent2);color:#fff;border-bottom-right-radius:4px;font-weight:500;}
.bubble-bot{background:var(--card);color:var(--text);border:1px solid var(--border);border-bottom-left-radius:4px;}
.typing-bubble{display:flex;gap:5px;align-items:center;padding:14px 18px;}
.dot{width:7px;height:7px;border-radius:50%;background:var(--text3);display:inline-block;animation:dotBounce 1s infinite;}
.input-wrap{
  display:flex;gap:10px;align-items:flex-end;
  background:var(--card);border:1px solid var(--border);
  border-radius:15px;padding:12px 14px;margin-bottom:8px;
}
textarea{
  flex:1;border:none;outline:none;resize:none;font-size:14px;
  font-family:'DM Sans',sans-serif;color:var(--text);
  background:transparent;line-height:1.55;caret-color:var(--accent);
}
.send-btn{
  background:var(--accent2);color:#fff;border:none;border-radius:10px;
  padding:10px 20px;font-size:14px;font-weight:600;transition:all .15s;flex-shrink:0;
}
.chat-note{font-size:11px;color:var(--text3);text-align:center;}

/* ── TIPS PAGE ── */
.page-title{font-family:'Cormorant Garamond',serif;font-size:38px;font-weight:700;color:var(--white);margin-bottom:6px;}
.page-sub{font-size:14px;color:var(--text2);margin-bottom:28px;}
.tip-card{
  background:var(--card);border:1px solid var(--border);border-radius:14px;
  padding:20px 22px;margin-bottom:10px;display:flex;gap:18px;align-items:flex-start;
}
.tip-num{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:700;color:var(--accent);line-height:1;flex-shrink:0;width:40px;}
.tip-card-text{font-weight:500;font-size:14px;color:var(--text);line-height:1.6;margin-bottom:6px;}
.tip-card-law{font-size:12px;color:var(--accent);font-weight:600;}

/* ── LAWYERS ── */
.lawyers-header{padding:36px 0 22px;border-bottom:1px solid var(--border);margin-bottom:22px;}
.lawyers-eyebrow{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:8px;}
.lawyers-title{font-family:'Cormorant Garamond',serif;font-size:clamp(30px,6vw,50px);font-weight:700;color:var(--white);line-height:1.1;margin-bottom:8px;}
.lawyers-sub{font-size:14px;color:var(--text2);line-height:1.65;max-width:500px;}
.search-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px;}
.search-input{flex:1;min-width:200px;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:10px 14px;color:var(--text);font-size:14px;outline:none;font-family:'DM Sans',sans-serif;}
.search-input::placeholder{color:var(--text3);}
.sort-select{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:10px 12px;color:var(--text2);font-size:13px;outline:none;font-family:'DM Sans',sans-serif;}
.filter-row{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:4px;margin-bottom:12px;}
.filter-row::-webkit-scrollbar{display:none;}
.chip{white-space:nowrap;padding:6px 14px;border-radius:20px;font-size:12px;font-weight:500;border:1px solid var(--border);background:transparent;color:var(--text2);transition:all .18s;}
.chip.active{border-color:var(--accent);background:var(--accentlo);color:var(--accent);}
.results-count{font-size:12px;color:var(--text3);margin-bottom:14px;}
.lawyers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(285px,1fr));gap:14px;margin-bottom:24px;}
.lawyer-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:20px;position:relative;transition:border-color .2s;}
.lawyer-card.featured{border-color:rgba(232,184,75,.4);}
.featured-badge{position:absolute;top:12px;right:12px;background:var(--goldlo);color:var(--gold);font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:3px 9px;border-radius:20px;border:1px solid rgba(232,184,75,.25);}
.lawyer-top{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px;}
.avatar{width:46px;height:46px;border-radius:50%;background:var(--accentlo);border:1.5px solid rgba(79,142,247,.35);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--accent);flex-shrink:0;}
.lawyer-name{font-family:'Cormorant Garamond',serif;font-size:1.08rem;font-weight:600;color:var(--white);line-height:1.2;margin-bottom:2px;}
.lawyer-title-sm{font-size:12px;color:var(--text2);margin-bottom:2px;}
.lawyer-firm{font-size:12px;color:var(--accent);font-weight:500;opacity:.8;}
.verified{display:inline-flex;align-items:center;gap:3px;font-size:10px;color:#4ade80;background:#0a2a1a;border:1px solid #1a4a2a;border-radius:20px;padding:2px 8px;font-weight:600;margin-top:4px;}
.info-row{display:flex;gap:7px;align-items:flex-start;margin-bottom:5px;}
.info-icon{font-size:11px;flex-shrink:0;margin-top:2px;}
.info-text{font-size:12px;color:var(--text2);line-height:1.4;}
.spec-row{display:flex;flex-wrap:wrap;gap:5px;margin:10px 0;}
.spec{font-size:11px;padding:3px 9px;border-radius:20px;background:var(--bg2);color:var(--text2);border:1px solid var(--border);font-weight:500;}
.rating-row{display:flex;align-items:center;gap:6px;margin-bottom:10px;}
.stars{color:var(--gold);font-size:12px;letter-spacing:-1px;}
.rating-num{font-size:12px;font-weight:600;color:var(--white);}
.review-count{font-size:11px;color:var(--text3);}
.card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--border);}
.fee-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;}
.fee-amount{font-size:15px;font-weight:700;color:var(--gold);}
.contact-btn{background:var(--accentlo);border:1px solid rgba(79,142,247,.35);color:var(--accent);border-radius:8px;padding:7px 14px;font-size:12px;font-weight:600;}
.list-banner{background:var(--card2);border:1px solid var(--border2);border-radius:14px;padding:22px 26px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.list-banner-title{font-size:15px;font-weight:600;color:var(--white);margin-bottom:5px;}
.list-banner-body{font-size:13px;color:var(--text2);max-width:380px;line-height:1.6;}
.apply-btn{background:var(--accent2);color:#fff;border:none;border-radius:10px;padding:11px 20px;font-size:13px;font-weight:600;white-space:nowrap;flex-shrink:0;}
.empty-state{padding:3rem 1rem;text-align:center;color:var(--text2);}

/* ── DOCUMENTS ── */
.docs-header{padding:36px 0 22px;border-bottom:1px solid var(--border);margin-bottom:26px;}
.docs-eyebrow{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:8px;}
.docs-title{font-family:'Cormorant Garamond',serif;font-size:clamp(30px,6vw,50px);font-weight:700;color:var(--white);line-height:1.1;margin-bottom:8px;}
.docs-sub{font-size:14px;color:var(--text2);line-height:1.65;max-width:520px;}
.doc-templates{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:14px;margin-bottom:28px;}
.doc-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;cursor:pointer;transition:border-color .2s,background .2s;position:relative;}
.doc-card:hover{border-color:rgba(79,142,247,.5);background:var(--card2);}
.doc-card-icon{font-size:28px;margin-bottom:14px;}
.doc-card-title{font-weight:600;font-size:15px;color:var(--white);margin-bottom:7px;}
.doc-card-desc{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:16px;}
.doc-card-footer{display:flex;align-items:center;justify-content:space-between;}
.doc-fee{font-size:13px;font-weight:700;color:var(--gold);}
.doc-btn{background:var(--accentlo);border:1px solid rgba(79,142,247,.35);color:var(--accent);border-radius:8px;padding:7px 14px;font-size:12px;font-weight:600;}
.doc-badge{position:absolute;top:12px;right:12px;background:var(--goldlo);color:var(--gold);font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:3px 9px;border-radius:20px;border:1px solid rgba(232,184,75,.25);}
.doc-builder{animation:fadeUp .35s ease;}
.builder-top{display:flex;align-items:center;gap:16px;margin-bottom:26px;padding-bottom:22px;border-bottom:1px solid var(--border);}
.builder-back{background:none;border:1px solid var(--border);border-radius:8px;padding:7px 13px;font-size:13px;color:var(--text2);}
.builder-title{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:700;color:var(--white);}
.form-group{margin-bottom:18px;}
.form-label{font-size:12px;font-weight:600;color:var(--text2);letter-spacing:.06em;text-transform:uppercase;margin-bottom:7px;display:block;}
.form-input,.form-textarea{width:100%;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:11px 14px;color:var(--text);font-size:14px;outline:none;font-family:'DM Sans',sans-serif;transition:border-color .2s;}
.form-input:focus,.form-textarea:focus{border-color:rgba(79,142,247,.5);}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text3);}
.form-textarea{resize:vertical;line-height:1.55;min-height:90px;}
.generate-btn{background:var(--accent2);color:#fff;border:none;border-radius:12px;padding:14px 28px;font-size:15px;font-weight:600;width:100%;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:10px;}
.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;}
.doc-preview{animation:fadeUp .35s ease;}
.preview-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px;}
.preview-actions{display:flex;gap:10px;}
.preview-back{background:none;border:1px solid var(--border);border-radius:8px;padding:8px 14px;font-size:13px;color:var(--text2);}
.download-btn{background:var(--accent2);color:#fff;border:none;border-radius:8px;padding:10px 18px;font-size:13px;font-weight:600;}
.new-doc-btn{background:var(--accentlo);border:1px solid rgba(79,142,247,.35);color:var(--accent);border-radius:8px;padding:10px 14px;font-size:13px;font-weight:600;}
.doc-paper{background:#fff;color:#1a1a1a;border-radius:12px;padding:48px 52px;font-family:'Times New Roman',serif;font-size:14px;line-height:1.8;margin-bottom:16px;}
.doc-paper h2{font-size:16px;font-weight:700;text-align:center;margin-bottom:4px;text-transform:uppercase;letter-spacing:.05em;}
.doc-paper .doc-date{text-align:right;font-size:13px;margin-bottom:24px;}
.doc-paper .doc-subject{font-weight:700;margin-bottom:16px;text-decoration:underline;}
.doc-paper p{margin-bottom:12px;}
.doc-paper .doc-sig{margin-top:40px;}
.doc-paper .doc-sig-name{font-weight:700;}
.copy-notice{background:var(--accentlo);border:1px solid rgba(79,142,247,.25);border-radius:10px;padding:12px 16px;font-size:12px;color:var(--text2);margin-bottom:16px;}
.doc-disclaimer{font-size:11px;color:var(--text3);text-align:center;padding:0 0 8px;}

/* ── ABOUT ── */
.about-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:22px 26px;margin-bottom:10px;}
.about-card-title{font-weight:600;font-size:15px;color:var(--white);margin-bottom:10px;}
.about-card-body{font-size:14px;color:var(--text2);line-height:1.75;}
.quote-block{border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:0 14px 14px 0;padding:24px 28px;margin-top:10px;}
.quote-text{font-family:'Cormorant Garamond',serif;font-size:21px;font-style:italic;color:var(--accent);line-height:1.5;}

/* ── RESPONSIVE ── */
@media(max-width:640px){
  .header-inner{flex-wrap:wrap;}
  .header-right{width:100%;justify-content:space-between;}
  .hero{padding:36px 0 32px;}
  .doc-paper{padding:28px 20px;}
  .lawyers-grid{grid-template-columns:1fr;}
  .doc-templates{grid-template-columns:1fr;}
  .grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));}
}
