/* =====================================================================
   Highnoon Final Settlement Portal — Theme
   Brand palette inspired by highnoon-labs.com (pharma green + clean white)
   ===================================================================== */

:root{
    --hn-green:#009a44;          /* primary brand green */
    --hn-green-dark:#007a36;
    --hn-green-darker:#0c5a2b;
    --hn-green-deep:#0d3320;     /* footer / dark sections */
    --hn-green-tint:#e8f6ed;
    --hn-green-tint-2:#f3faf5;
    --hn-accent:#16b35a;

    --ink:#16261c;
    --body:#465048;
    --muted:#7c887f;
    --line:#e4eae5;
    --line-soft:#eef2ef;
    --white:#ffffff;
    --bg:#f6f9f6;

    --ok:#0f9d58;
    --ok-bg:#e7f6ee;
    --warn:#c8861a;
    --warn-bg:#fdf3e2;
    --pending:#b06a00;
    --pending-bg:#fff3e0;

    --radius:16px;
    --radius-sm:10px;
    --shadow:0 10px 30px rgba(16,51,32,.08);
    --shadow-sm:0 4px 14px rgba(16,51,32,.06);
    --maxw:1140px;
    --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
    margin:0;
    font-family:var(--font);
    color:var(--body);
    background:var(--bg);
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{color:var(--ink);line-height:1.2;margin:0 0 .4em;}
a{color:var(--hn-green-dark);text-decoration:none;}
a:hover{text-decoration:underline;}
img{max-width:100%;display:block;}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px;}

/* ---------- Header ---------- */
.site-header{
    background:var(--white);
    border-bottom:1px solid var(--line);
    position:sticky;top:0;z-index:50;
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px;}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;}
.brand:hover{text-decoration:none;}
.brand-logo{height:42px;width:auto;}
.brand-text{display:flex;flex-direction:column;line-height:1.05;}
.brand-text strong{color:var(--hn-green-dark);font-size:1.15rem;font-weight:800;letter-spacing:-.01em;}
.brand-text small{color:var(--muted);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;}
.header-tag{
    color:var(--hn-green-dark);font-weight:600;font-size:.82rem;
    background:var(--hn-green-tint);padding:7px 14px;border-radius:999px;
}

/* ---------- Hero ---------- */
.hero{
    background:
        radial-gradient(1200px 400px at 80% -10%, rgba(0,154,68,.10), transparent 60%),
        linear-gradient(180deg,#ffffff 0%, var(--hn-green-tint-2) 100%);
    border-bottom:1px solid var(--line);
    padding:56px 0 64px;
}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;}
.eyebrow{
    display:inline-block;color:var(--hn-green-dark);font-weight:700;
    font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
    background:var(--hn-green-tint);padding:6px 12px;border-radius:999px;margin-bottom:18px;
}
.hero-copy h1{font-size:2.8rem;font-weight:800;letter-spacing:-.02em;color:var(--ink);}
.hero-copy p{font-size:1.04rem;max-width:34em;margin:.6em 0 1.4em;}
.hero-points{list-style:none;padding:0;margin:0;display:grid;gap:12px;}
.hero-points li{display:flex;align-items:center;gap:12px;font-weight:500;color:var(--ink);}
.hero-points .dot{width:9px;height:9px;border-radius:50%;background:var(--hn-green);box-shadow:0 0 0 4px var(--hn-green-tint);flex:none;}

/* ---------- Lookup card ---------- */
.lookup-card{
    background:var(--white);border:1px solid var(--line);
    border-radius:var(--radius);box-shadow:var(--shadow);padding:30px;
}
.lookup-card h2{font-size:1.45rem;}
.lookup-sub{color:var(--muted);margin:0 0 20px;font-size:.95rem;}
.lookup-form label{display:block;font-weight:600;color:var(--ink);margin:14px 0 6px;font-size:.9rem;}
.lookup-form label .req{color:var(--hn-green);}
.lookup-form input{
    width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:var(--radius-sm);
    font-size:1rem;font-family:inherit;color:var(--ink);background:#fbfdfb;transition:border-color .15s, box-shadow .15s;
}
.lookup-form input:focus{outline:none;border-color:var(--hn-green);box-shadow:0 0 0 4px var(--hn-green-tint);background:#fff;}
.field-hint{display:block;color:var(--muted);font-size:.78rem;margin-top:5px;}
.lookup-privacy{margin:16px 0 0;font-size:.8rem;color:var(--muted);text-align:center;}

/* ---------- Buttons ---------- */
.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    font-family:inherit;font-weight:600;font-size:1rem;cursor:pointer;
    padding:13px 22px;border-radius:var(--radius-sm);border:1.5px solid transparent;
    transition:transform .05s, background .15s, box-shadow .15s;text-decoration:none;
}
.btn:hover{text-decoration:none;}
.btn:active{transform:translateY(1px);}
.btn-block{width:100%;margin-top:22px;}
.btn-primary{background:var(--hn-green);color:#fff;box-shadow:0 8px 18px rgba(0,154,68,.25);}
.btn-primary:hover{background:var(--hn-green-dark);}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--hn-green-dark);}
.btn-ghost:hover{background:var(--hn-green-tint);border-color:var(--hn-green);}
.btn-danger{background:#fff;border-color:#e7c4c4;color:#b23b3b;}
.btn-danger:hover{background:#fdeeee;}

/* ---------- Alerts ---------- */
.alert{
    border-radius:var(--radius-sm);padding:16px 18px;display:flex;gap:8px;flex-wrap:wrap;
    align-items:baseline;font-size:.95rem;margin:0 0 8px;
}
.alert strong{color:var(--ink);}
.alert-warn{background:var(--warn-bg);border:1px solid #f0dcb4;color:#8a6516;}
.alert-error{background:#fdeeee;border:1px solid #f2cccc;color:#9a3434;}
.alert-success{background:var(--ok-bg);border:1px solid #c6e9d4;color:#1c7a45;}

/* ---------- Results ---------- */
.results{padding:40px 20px 10px;}
.result-head{
    display:flex;align-items:center;gap:18px;flex-wrap:wrap;
    background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
    padding:22px 24px;box-shadow:var(--shadow-sm);
}
.avatar{
    width:62px;height:62px;border-radius:50%;flex:none;
    background:linear-gradient(135deg,var(--hn-green),var(--hn-green-darker));
    color:#fff;display:flex;align-items:center;justify-content:center;
    font-weight:700;font-size:1.4rem;letter-spacing:.02em;
}
.result-id{flex:1;min-width:200px;}
.result-id h2{font-size:1.4rem;margin:0 0 2px;}
.result-id p{margin:0;color:var(--body);font-weight:500;}
.emp-code{display:inline-block;margin-top:6px;font-size:.78rem;color:var(--muted);
    background:var(--bg);padding:3px 10px;border-radius:999px;border:1px solid var(--line);}
.result-status{margin-left:auto;}

.status-badge{
    display:inline-block;padding:8px 16px;border-radius:999px;font-weight:700;font-size:.85rem;
    border:1px solid transparent;white-space:nowrap;
}
.badge-paid{background:var(--ok-bg);color:#15803d;border-color:#bfe6cd;}
.badge-progress{background:#e9f1fd;color:#1d63c4;border-color:#c8ddf7;}
.badge-initiated{background:var(--pending-bg);color:var(--pending);border-color:#f3d9ad;}
.badge-neutral{background:var(--bg);color:var(--muted);border-color:var(--line);}

/* ---------- Stepper ---------- */
.stepper-card{
    background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
    box-shadow:var(--shadow-sm);padding:26px 24px;margin-top:16px;
}
.stepper{display:flex;justify-content:space-between;position:relative;}
.stepper::before{
    content:"";position:absolute;top:18px;left:6%;right:6%;height:3px;background:var(--line);border-radius:2px;z-index:0;
}
.step{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;flex:1;text-align:center;}
.step-dot{
    width:38px;height:38px;border-radius:50%;background:var(--white);border:3px solid var(--line);
    color:var(--muted);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;
    transition:all .2s;
}
.step-label{margin-top:9px;font-size:.78rem;color:var(--muted);font-weight:600;max-width:90px;}
.step.done .step-dot{background:var(--hn-green);border-color:var(--hn-green);color:#fff;}
.step.done .step-label{color:var(--hn-green-dark);}
.step.current .step-dot{background:#fff;border-color:var(--hn-green);color:var(--hn-green-dark);
    box-shadow:0 0 0 5px var(--hn-green-tint);}
.step.current .step-label{color:var(--ink);}

/* ---------- Result grid ---------- */
.result-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:20px;margin-top:20px;}
.result-main,.result-side{display:flex;flex-direction:column;gap:20px;}
.panel{
    background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
    box-shadow:var(--shadow-sm);padding:22px 24px;
}
.panel-head{border-bottom:1px solid var(--line-soft);padding-bottom:12px;margin-bottom:16px;}
.panel-head h3{font-size:1.08rem;margin:0;}

/* Breakdown */
.breakdown{display:grid;grid-template-columns:1fr 1fr;gap:28px;}
.bk-group h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:0 0 10px;}
.bk-row{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px dashed var(--line-soft);font-size:.92rem;}
.bk-row span:first-child{color:var(--body);}
.bk-row span:last-child{font-weight:600;color:var(--ink);white-space:nowrap;}
.bk-row .neg{color:#b1483f;}
.bk-subtotal{border-bottom:none;border-top:2px solid var(--line);margin-top:4px;font-weight:700;}
.bk-subtotal span{color:var(--ink)!important;font-weight:700;}
.net-row{
    display:flex;justify-content:space-between;align-items:center;
    background:var(--hn-green-tint);border-radius:var(--radius-sm);
    padding:16px 20px;margin-top:20px;
}
.net-row>span:first-child{font-weight:700;color:var(--hn-green-darker);font-size:1rem;}
.net-amount{font-weight:800;color:var(--hn-green-dark);font-size:1.5rem;letter-spacing:-.01em;}

/* Clearance */
.clearance-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.clearance-item{
    border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 12px;text-align:center;background:#fbfdfb;
}
.cl-dept{font-weight:700;color:var(--ink);font-size:.95rem;}
.cl-state{margin-top:6px;font-size:.78rem;font-weight:600;display:inline-block;padding:3px 10px;border-radius:999px;}
.clearance-item.is-cleared{background:var(--ok-bg);border-color:#c6e9d4;}
.clearance-item.is-cleared .cl-state{background:#fff;color:#15803d;}
.clearance-item.is-pending{background:var(--pending-bg);border-color:#f3d9ad;}
.clearance-item.is-pending .cl-state{background:#fff;color:var(--pending);}
.clearance-item.is-neutral .cl-state{background:#fff;color:var(--muted);}

.remarks{margin:0;color:var(--body);}

/* Info lists */
.info-list{margin:0;display:grid;grid-template-columns:auto;gap:0;}
.info-list dt{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-top:12px;font-weight:600;}
.info-list dt:first-child{margin-top:0;}
.info-list dd{margin:2px 0 0;color:var(--ink);font-weight:600;padding-bottom:10px;border-bottom:1px solid var(--line-soft);}
.info-list dd:last-child{border-bottom:none;}

.panel-help{background:var(--hn-green-deep);border-color:var(--hn-green-deep);color:#dfeee5;}
.panel-help h3{color:#fff;}
.panel-help p{color:#bcd6c6;font-size:.9rem;}
.panel-help .btn-ghost{color:#fff;border-color:rgba(255,255,255,.3);margin-top:6px;}
.panel-help .btn-ghost:hover{background:rgba(255,255,255,.1);border-color:#fff;}

.result-foot{color:var(--muted);font-size:.82rem;text-align:center;margin:24px auto 4px;max-width:46em;}

/* ---------- Footer ---------- */
.site-footer{background:var(--hn-green-deep);color:#bcd0c2;margin-top:56px;}
.footer-inner{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:36px;padding:46px 20px 34px;}
.footer-col h4{color:#fff;font-size:.95rem;margin:0 0 12px;}
.footer-col p{margin:0 0 10px;font-size:.9rem;line-height:1.6;}
.footer-col a{color:#9fe3b8;}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
.footer-logo{height:34px;}
.footer-brand span{color:#fff;font-weight:700;}
.footer-note{font-size:.9rem;color:#a8c2b1;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:16px 0;font-size:.82rem;color:#86a392;text-align:center;}

/* ---------- Admin ---------- */
.admin-body{background:var(--bg);}
.admin-wrap{max-width:920px;margin:40px auto;padding:0 20px;}
.login-card{
    max-width:420px;margin:60px auto;background:#fff;border:1px solid var(--line);
    border-radius:var(--radius);box-shadow:var(--shadow);padding:34px;
}
.login-card h2{font-size:1.5rem;}
.login-card p.sub{color:var(--muted);margin:0 0 22px;}
.admin-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:24px;}
.admin-head h1{font-size:1.6rem;margin:0;}
.admin-head .muted{color:var(--muted);font-size:.9rem;}
.admin-card{
    background:#fff;border:1px solid var(--line);border-radius:var(--radius);
    box-shadow:var(--shadow-sm);padding:26px;margin-bottom:22px;
}
.admin-card h3{font-size:1.15rem;margin-bottom:6px;}
.admin-card .hint{color:var(--muted);font-size:.9rem;margin-top:0;}
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:18px 0 6px;}
.stat{background:var(--hn-green-tint-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 18px;}
.stat .num{font-size:1.6rem;font-weight:800;color:var(--hn-green-dark);}
.stat .lbl{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600;}
.upload-zone{
    border:2px dashed var(--line);border-radius:var(--radius);padding:30px;text-align:center;
    background:#fbfdfb;transition:border-color .15s,background .15s;cursor:pointer;
}
.upload-zone.drag{border-color:var(--hn-green);background:var(--hn-green-tint);}
.upload-zone input[type=file]{display:none;}
.upload-zone .icon{font-size:2rem;}
.upload-zone .file-name{font-weight:600;color:var(--hn-green-dark);margin-top:8px;}
.admin-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px;}
table.cols{width:100%;border-collapse:collapse;font-size:.88rem;margin-top:10px;}
table.cols th,table.cols td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--line-soft);}
table.cols th{color:var(--muted);text-transform:uppercase;font-size:.72rem;letter-spacing:.06em;}
.pill{display:inline-block;padding:2px 9px;border-radius:999px;font-size:.74rem;font-weight:600;}
.pill-ok{background:var(--ok-bg);color:#15803d;}
.pill-miss{background:#fdeeee;color:#a23a3a;}
.logout-link{color:#cfe3d6;font-size:.85rem;}

/* ---------- Responsive ---------- */
@media (max-width:920px){
    .hero-inner{grid-template-columns:1fr;gap:32px;}
    .hero-copy h1{font-size:2.3rem;}
    .result-grid{grid-template-columns:1fr;}
    .breakdown{grid-template-columns:1fr;gap:18px;}
    .clearance-grid{grid-template-columns:repeat(2,1fr);}
    .footer-inner{grid-template-columns:1fr 1fr;}
    .stat-row{grid-template-columns:1fr;}
}
@media (max-width:560px){
    .header-tag{display:none;}
    .hero{padding:36px 0 44px;}
    .hero-copy h1{font-size:1.95rem;}
    .lookup-card{padding:24px 20px;}
    .stepper{overflow-x:auto;gap:6px;padding-bottom:6px;}
    .step{min-width:74px;}
    .stepper::before{left:10%;right:10%;}
    .result-status{margin-left:0;width:100%;}
    .footer-inner{grid-template-columns:1fr;gap:24px;}
    .net-amount{font-size:1.25rem;}
    .result-head{padding:18px;}
}
