/* ============================================================
   DRMS Jamaica — landing / home page
   ============================================================ */
:root{
  --ink:#15271b; --ink-soft:#5b7263; --paper:#f4f7f4; --line:#e1eae2;
  --green:#009b3a; --green-2:#00772c; --gold:#f4c20d;
  --side:#0f2417; --side-2:#173420; --red:#dc2626; --radius:16px;
}
*{box-sizing:border-box;}
html,body{margin:0;}
html{scroll-behavior:smooth;}
body.drm-home{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink); background:#fff; -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:'Plus Jakarta Sans',system-ui,sans-serif;margin:0;}
a{color:inherit;text-decoration:none;}
img{display:block;}

/* ---------- buttons ---------- */
.btn{
  border:1px solid transparent;border-radius:11px;padding:10px 18px;font-size:14px;font-weight:700;
  font-family:inherit;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:.14s;
}
.btn-primary{background:var(--green);color:#fff;}
.btn-primary:hover{background:var(--green-2);}
.btn-light{background:#fff;color:var(--ink);border-color:var(--line);}
.btn-light:hover{background:var(--paper);}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.4);}
.btn-outline:hover{background:rgba(255,255,255,.10);}
.btn-lg{padding:14px 24px;font-size:15px;border-radius:13px;}
.btn-block{width:100%;justify-content:center;}

/* ---------- header ---------- */
.hm-top{
  position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:20px;
  padding:13px 32px;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.hm-brand{display:flex;align-items:center;gap:11px;}
.hm-brand img{width:42px;height:42px;border-radius:10px;}
.hm-brand b{font-family:'Plus Jakarta Sans';font-size:17px;font-weight:800;letter-spacing:-.3px;display:block;}
.hm-brand small{font-size:11px;color:var(--ink-soft);font-weight:600;}
.hm-nav{margin-left:auto;display:flex;align-items:center;gap:24px;}
.hm-nav a{font-size:14px;font-weight:600;color:var(--ink-soft);}
.hm-nav a:hover{color:var(--ink);}
.hm-burger{display:none;flex-direction:column;gap:4px;background:none;border:0;cursor:pointer;margin-left:auto;}
.hm-burger span{width:22px;height:2px;background:var(--ink);border-radius:2px;}

/* ---------- hero ---------- */
.hm-hero{
  background:
    radial-gradient(900px 420px at 78% -8%,rgba(244,194,13,.16),transparent),
    radial-gradient(800px 500px at 8% 110%,rgba(0,155,58,.30),transparent),
    var(--side);
  color:#eaf3ec;position:relative;overflow:hidden;
  border-bottom:4px solid transparent;
  border-image:linear-gradient(90deg,var(--green) 0 38%,var(--gold) 38% 62%,#141414 62% 100%) 1;
}
.hm-hero-inner{max-width:1080px;margin:0 auto;padding:78px 32px 86px;}
.hm-eyebrow{
  display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;color:#8fd6a4;
  background:rgba(0,155,58,.16);border:1px solid rgba(143,214,164,.3);
  padding:6px 13px;border-radius:20px;
}
.hm-eyebrow::before{content:"";width:8px;height:8px;border-radius:50%;background:#36d96b;
  box-shadow:0 0 0 4px rgba(54,217,107,.25);animation:hp 2s infinite;}
@keyframes hp{0%,100%{opacity:1}50%{opacity:.4}}
.hm-hero h1{
  font-size:clamp(32px,5vw,52px);font-weight:800;line-height:1.08;letter-spacing:-1.4px;
  margin:20px 0 0;color:#fff;
}
.hm-lede{font-size:clamp(15px,1.7vw,18px);line-height:1.6;color:#b9d2c0;max-width:620px;margin:18px 0 0;}
.hm-hero-actions{display:flex;gap:13px;flex-wrap:wrap;margin-top:30px;}
.hm-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-top:54px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.10);border-radius:var(--radius);overflow:hidden;
}
.hm-stat{background:rgba(15,36,23,.6);padding:22px 18px;text-align:center;}
.hm-stat b{font-family:'Plus Jakarta Sans';font-size:34px;font-weight:800;color:#fff;display:block;letter-spacing:-1px;}
.hm-stat span{font-size:12.5px;color:#8fae97;font-weight:600;}

/* ---------- sections ---------- */
.hm-section{max-width:1080px;margin:0 auto;padding:84px 32px;}
.hm-section-head{text-align:center;max-width:620px;margin:0 auto 44px;}
.hm-kicker{
  font-size:12.5px;font-weight:800;letter-spacing:.10em;text-transform:uppercase;color:var(--green);
}
.hm-kicker.light{color:var(--gold);}
.hm-section-head h2{font-size:clamp(25px,3.4vw,36px);font-weight:800;letter-spacing:-.8px;margin:10px 0 12px;}
.hm-section-head p{font-size:15.5px;color:var(--ink-soft);line-height:1.6;margin:0;}

.hm-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.hm-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;
  transition:.15s;
}
.hm-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(8,40,18,.10);border-color:#cfe3d4;}
.hm-ic{
  width:48px;height:48px;border-radius:13px;display:grid;place-items:center;font-size:22px;
  background:linear-gradient(135deg,var(--green),var(--green-2));color:#fff;margin-bottom:16px;
}
.hm-card h3{font-size:17px;font-weight:800;margin-bottom:8px;letter-spacing:-.3px;}
.hm-card p{font-size:14px;color:var(--ink-soft);line-height:1.6;margin:0;}

/* ---------- coverage ---------- */
.hm-coverage{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.hm-coverage-inner{
  max-width:1080px;margin:0 auto;padding:80px 32px;display:grid;
  grid-template-columns:1.25fr 1fr;gap:48px;align-items:center;
}
.hm-coverage-text h2{font-size:clamp(24px,3.2vw,33px);font-weight:800;letter-spacing:-.7px;margin:10px 0 14px;}
.hm-coverage-text p{font-size:15px;color:var(--ink-soft);line-height:1.65;margin:0 0 18px;}
.hm-ticks{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px;}
.hm-ticks li{font-size:14.5px;font-weight:500;display:flex;align-items:flex-start;gap:11px;}
.hm-ticks li::before{
  content:"✓";flex-shrink:0;width:22px;height:22px;border-radius:7px;background:rgba(0,155,58,.13);
  color:var(--green);font-weight:800;font-size:13px;display:grid;place-items:center;margin-top:1px;
}
.hm-coverage-card{
  background:var(--side);color:#dceee2;border-radius:var(--radius);padding:30px 28px;
  box-shadow:0 20px 50px rgba(8,40,18,.25);
}
.hm-cc-head{font-family:'Plus Jakarta Sans';font-size:19px;font-weight:800;color:#fff;margin-bottom:10px;}
.hm-coverage-card p{font-size:14px;line-height:1.6;color:#a9c6b2;margin:0 0 20px;}
.hm-cc-link{display:block;text-align:center;margin-top:14px;font-size:13px;color:#8fd6a4;font-weight:600;}
.hm-cc-link:hover{color:#fff;}

/* ---------- footer ---------- */
.hm-foot{background:var(--side);color:#9fbfa8;}
.hm-foot-inner{
  max-width:1080px;margin:0 auto;padding:40px 32px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;
}
.hm-foot-brand{display:flex;align-items:center;gap:11px;}
.hm-foot-brand img{width:40px;height:40px;border-radius:10px;}
.hm-foot-brand b{color:#fff;font-family:'Plus Jakarta Sans';font-size:15px;display:block;}
.hm-foot-brand small{font-size:11px;}
.hm-foot nav{margin-left:auto;display:flex;gap:22px;align-items:center;}
.hm-foot nav a,.linkbtn{font-size:13.5px;font-weight:600;color:#9fbfa8;background:none;border:0;cursor:pointer;font-family:inherit;}
.hm-foot nav a:hover,.linkbtn:hover{color:#fff;}
.hm-foot-base{
  border-top:1px solid var(--side-2);text-align:center;padding:16px;font-size:12px;color:#6f9079;
}

/* ---------- login modal ---------- */
.hm-modal-wrap{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:20px;}
.hm-modal-scrim{position:absolute;inset:0;background:rgba(10,24,15,.6);backdrop-filter:blur(3px);}
.hm-modal{
  position:relative;background:#fff;border-radius:18px;width:min(420px,100%);
  padding:32px 30px 26px;box-shadow:0 30px 80px rgba(0,0,0,.4);animation:pop .2s ease;
}
@keyframes pop{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.hm-modal-x{
  position:absolute;top:12px;right:14px;width:32px;height:32px;border:0;border-radius:9px;
  background:var(--paper);font-size:20px;color:var(--ink-soft);cursor:pointer;
}
.hm-modal-brand{text-align:center;margin-bottom:20px;}
.hm-modal-brand img{width:54px;height:54px;border-radius:13px;margin:0 auto 12px;}
.hm-modal-brand h3{font-size:20px;font-weight:800;}
.hm-modal-brand p{font-size:13px;color:var(--ink-soft);margin:5px 0 0;}
.fld{display:block;margin-bottom:13px;}
.fld span{display:block;font-size:12.5px;font-weight:600;color:var(--ink-soft);margin-bottom:5px;}
.fld input{
  width:100%;border:1px solid var(--line);border-radius:11px;padding:11px 13px;font-size:14.5px;
  font-family:inherit;color:var(--ink);
}
.fld input:focus{outline:2px solid rgba(0,155,58,.25);border-color:var(--green);}
.hm-err{
  background:rgba(220,38,38,.09);border:1px solid rgba(220,38,38,.25);color:#b91c1c;
  font-size:13px;font-weight:600;padding:9px 12px;border-radius:10px;margin-bottom:12px;
}
.hm-modal-foot{text-align:center;font-size:11.5px;color:var(--ink-soft);margin:14px 0 0;}

/* ---------- standalone login page ---------- */
.login-page{
  min-height:100vh;display:grid;place-items:center;padding:24px;
  background:
    radial-gradient(700px 360px at 80% 0%,rgba(244,194,13,.14),transparent),
    radial-gradient(700px 420px at 10% 100%,rgba(0,155,58,.30),transparent),
    var(--side);
}
.login-card{
  background:#fff;border-radius:20px;width:min(420px,100%);
  padding:36px 34px 30px;box-shadow:0 30px 80px rgba(0,0,0,.42);
}
.login-brand{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:18px;}
.login-brand img{width:58px;height:58px;border-radius:14px;}
.login-brand b{font-family:'Plus Jakarta Sans';font-size:18px;font-weight:800;letter-spacing:-.3px;}
.login-brand small{font-size:11.5px;color:var(--ink-soft);font-weight:600;}
.login-card h1{font-size:21px;font-weight:800;text-align:center;letter-spacing:-.3px;}
.login-sub{font-size:13px;color:var(--ink-soft);text-align:center;margin:6px 0 20px;line-height:1.5;}
.login-back{display:block;text-align:center;margin-top:16px;font-size:13px;color:var(--ink-soft);font-weight:600;}
.login-back:hover{color:var(--ink);}
.login-flag{
  height:4px;border-radius:3px;margin-top:22px;
  background:linear-gradient(90deg,var(--green) 0 38%,var(--gold) 38% 62%,#141414 62% 100%);
}

/* ---------- responsive ---------- */
@media(max-width:820px){
  .hm-nav{display:none;}
  .hm-nav.open{
    display:flex;flex-direction:column;align-items:flex-start;gap:14px;
    position:absolute;top:68px;left:0;right:0;background:#fff;padding:18px 32px;
    border-bottom:1px solid var(--line);box-shadow:0 14px 30px rgba(8,40,18,.12);
  }
  .hm-burger{display:flex;}
  .hm-cards{grid-template-columns:1fr;}
  .hm-stats{grid-template-columns:repeat(2,1fr);}
  .hm-coverage-inner{grid-template-columns:1fr;gap:32px;}
  .hm-foot-inner{flex-direction:column;align-items:flex-start;}
  .hm-foot nav{margin-left:0;flex-wrap:wrap;}
}
