:root {
    --forest: #0b3325;
    --forest-deep: #061b14;
    --green: #1f6b48;
    --lime: #c9e364;
    --sand: #f4f1e8;
    --ink: #17211d;
    --muted: #64706a;
    --line: rgba(20, 45, 35, .13);
    --white: #fff;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: #fbfcf9; font-family: "DM Sans", sans-serif; -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
button, input { font: inherit; }
.ramis-public { overflow-x: hidden; }

.public-nav {
    position: fixed; z-index: 50; top: 0; left: 0; right: 0; height: 82px; padding: 0 max(5vw, 24px);
    display: flex; align-items: center; justify-content: space-between; color: white; transition: .25s ease;
}
.public-nav.scrolled { height: 70px; background: rgba(5, 27, 20, .96); box-shadow: 0 12px 34px rgba(0, 0, 0, .14); backdrop-filter: blur(18px); }
.brand, .footer-brand { display: inline-flex; align-items: center; gap: 12px; }
.brand-mark { width: 43px; height: 48px; display: grid; place-items: center; color: var(--forest-deep); background: var(--lime); clip-path: polygon(50% 0, 92% 17%, 84% 76%, 50% 100%, 16% 76%, 8% 17%); font-size: 20px; }
.brand strong, .footer-brand strong { display: block; font: 800 20px/1 "Manrope", sans-serif; letter-spacing: 2px; }
.brand small, .footer-brand small { display: block; margin-top: 5px; font-size: 9px; letter-spacing: 1.1px; text-transform: uppercase; opacity: .65; }
.public-nav nav { display: flex; align-items: center; gap: 28px; font-size: 13px; font-weight: 600; }
.public-nav nav > a:not(.button) { position: relative; opacity: .82; }
.public-nav nav > a:not(.button):hover { opacity: 1; }
.nav-login { padding-left: 28px; border-left: 1px solid rgba(255,255,255,.22); }
.nav-toggle { display: none; border: 0; color: white; background: transparent; font-size: 22px; }
.button { display: inline-flex; align-items: center; justify-content: center; gap: 12px; padding: 16px 22px; border: 1px solid var(--lime); border-radius: 7px; color: var(--forest-deep); background: var(--lime); font-weight: 800; box-shadow: 0 12px 28px rgba(201, 227, 100, .13); transition: .2s ease; }
.button:hover { transform: translateY(-2px); background: #d9ef80; }
.button-small { padding: 11px 17px; font-size: 12px; }

.hero { position: relative; min-height: 780px; height: 100vh; display: grid; grid-template-columns: 1.05fr .95fr; align-items: center; padding: 120px max(7vw, 30px) 60px; color: white; overflow: hidden; background: linear-gradient(105deg, rgba(4,23,17,.98) 0%, rgba(6,40,28,.96) 50%, rgba(13,56,39,.91) 100%), url("../img/intro-bg-ramis.png") center/cover; }
.hero-grid { position: absolute; inset: 0; opacity: .12; background-image: linear-gradient(rgba(255,255,255,.13) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.13) 1px, transparent 1px); background-size: 72px 72px; mask-image: linear-gradient(to right, black, transparent 80%); }
.hero-glow { position: absolute; width: 650px; height: 650px; right: -180px; top: 15%; border-radius: 50%; background: rgba(90,155,101,.18); filter: blur(70px); }
.hero-content, .hero-panel { position: relative; z-index: 2; }
.eyebrow, .kicker { display: flex; align-items: center; gap: 10px; color: var(--lime); font-size: 11px; font-weight: 800; letter-spacing: 2.2px; text-transform: uppercase; }
.eyebrow span { width: 26px; height: 2px; background: var(--lime); }
.hero h1 { max-width: 720px; margin: 24px 0 24px; font: 800 clamp(54px, 6.1vw, 88px)/.98 "Manrope", sans-serif; letter-spacing: -4.8px; }
.hero h1 em { color: var(--lime); font-style: normal; }
.hero-content > p { max-width: 590px; color: rgba(255,255,255,.71); font-size: 18px; line-height: 1.7; }
.hero-actions { display: flex; align-items: center; gap: 28px; margin-top: 34px; }
.text-link { font-weight: 700; font-size: 14px; }
.text-link i { margin-right: 8px; color: var(--lime); font-size: 18px; vertical-align: -1px; }
.trust-row { display: flex; gap: 22px; margin-top: 44px; color: rgba(255,255,255,.55); font-size: 11px; }
.trust-row i { margin-right: 6px; color: var(--lime); }
.hero-panel { justify-self: end; width: min(470px, 90%); margin-right: 3vw; }
.status-card { padding: 25px; border: 1px solid rgba(255,255,255,.14); border-radius: 18px; background: rgba(8,36,27,.72); box-shadow: 0 40px 90px rgba(0,0,0,.34); backdrop-filter: blur(20px); }
.status-card-top { display: flex; align-items: center; gap: 12px; }
.status-card-top > span:nth-child(2) { flex: 1; }
.status-card-top small { display: block; color: rgba(255,255,255,.46); font-size: 9px; letter-spacing: 1.4px; }
.status-card-top strong { display: block; margin-top: 5px; font-size: 18px; }
.status-logo { width: 46px; height: 46px; display: grid; place-items: center; border-radius: 11px; color: var(--lime); background: rgba(201,227,100,.11); }
.live-dot { color: var(--lime); font-size: 9px; font-weight: 800; }
.live-dot:before { content: ""; display: inline-block; width: 6px; height: 6px; margin-right: 5px; border-radius: 50%; background: var(--lime); box-shadow: 0 0 0 4px rgba(201,227,100,.1); }
.progress-track { height: 5px; margin: 24px 0 11px; border-radius: 5px; background: rgba(255,255,255,.1); overflow: hidden; }
.progress-track span { display: block; height: 100%; border-radius: inherit; background: var(--lime); }
.status-meta { display: flex; justify-content: space-between; color: rgba(255,255,255,.42); font-size: 9px; text-transform: uppercase; letter-spacing: .8px; }
.status-meta span:last-child { text-align: right; }
.status-meta strong { display: inline-block; margin-top: 4px; color: white; font-size: 11px; letter-spacing: .5px; }
.mini-timeline { margin-top: 25px; }
.mini-timeline > div { position: relative; display: flex; gap: 13px; min-height: 58px; color: rgba(255,255,255,.35); font-size: 12px; }
.mini-timeline > div:not(:last-child):after { content: ""; position: absolute; left: 13px; top: 27px; bottom: 0; width: 1px; background: rgba(255,255,255,.12); }
.mini-timeline i { position: relative; z-index: 1; width: 27px; height: 27px; display: grid; place-items: center; flex: 0 0 27px; border: 1px solid rgba(255,255,255,.13); border-radius: 50%; font-size: 10px; background: #0a2c21; }
.mini-timeline span { padding-top: 4px; }
.mini-timeline small { display: block; margin-top: 3px; color: rgba(255,255,255,.32); }
.mini-timeline .done { color: white; }
.mini-timeline .done i { color: var(--forest-deep); border-color: var(--lime); background: var(--lime); }
.mini-timeline .active { color: var(--lime); }
.mini-timeline .active i { border-color: var(--lime); }
.floating-card { position: absolute; display: flex; align-items: center; gap: 10px; padding: 13px 15px; border: 1px solid rgba(255,255,255,.14); border-radius: 11px; background: rgba(9,39,29,.9); box-shadow: 0 18px 40px rgba(0,0,0,.25); font-size: 11px; backdrop-filter: blur(15px); }
.floating-card > i:first-child { width: 32px; height: 32px; display: grid; place-items: center; border-radius: 8px; color: var(--lime); background: rgba(201,227,100,.1); }
.floating-card span { min-width: 125px; }
.floating-card strong, .floating-card small { display: block; }
.floating-card small { margin-top: 3px; color: rgba(255,255,255,.4); font-size: 9px; }
.floating-card > .fa-check-circle { color: var(--lime); }
.document-float { right: -50px; top: 28%; }
.secure-float { left: -65px; bottom: 12%; }
.scroll-cue { position: absolute; z-index: 2; left: max(7vw, 30px); bottom: 25px; display: flex; align-items: center; gap: 10px; color: rgba(255,255,255,.38); font-size: 10px; letter-spacing: 1.3px; text-transform: uppercase; }
.scroll-cue span { width: 28px; height: 1px; background: var(--lime); }

.section { padding: 110px max(7vw, 30px); }
.section-heading { max-width: 740px; margin-bottom: 58px; }
.section-heading h2, .requirements h2, .cta-section h2 { margin: 15px 0 18px; font: 800 clamp(36px, 4vw, 55px)/1.08 "Manrope", sans-serif; letter-spacing: -2.4px; }
.section-heading p, .requirements-copy > p { max-width: 660px; color: var(--muted); font-size: 16px; line-height: 1.75; }
.why { background: var(--sand); }
.value-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; border: 1px solid var(--line); background: var(--line); }
.value-grid article { position: relative; min-height: 310px; padding: 38px; background: var(--sand); transition: .2s ease; }
.value-grid article:hover { z-index: 1; transform: translateY(-5px); background: white; box-shadow: 0 22px 50px rgba(17,47,36,.1); }
.value-grid article > span { position: absolute; right: 28px; top: 25px; color: rgba(15,51,38,.18); font: 800 36px "Manrope"; }
.value-grid i { width: 52px; height: 52px; display: grid; place-items: center; border-radius: 12px; color: var(--green); background: rgba(31,107,72,.09); font-size: 20px; }
.value-grid h3 { margin: 55px 0 12px; font: 800 22px "Manrope"; }
.value-grid p { color: var(--muted); line-height: 1.7; }
.process { color: white; background: var(--forest-deep); }
.section-heading.light p { color: rgba(255,255,255,.56); }
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.process-grid article { position: relative; min-height: 260px; padding: 32px 28px; border-top: 1px solid rgba(255,255,255,.12); border-right: 1px solid rgba(255,255,255,.1); }
.process-grid article:last-child { border-right: 0; }
.process-grid b { color: rgba(255,255,255,.16); font: 700 13px "Manrope"; }
.process-icon { width: 48px; height: 48px; display: grid; place-items: center; margin: 34px 0 26px; border-radius: 50%; color: var(--forest-deep); background: var(--lime); }
.process-grid h3 { font: 700 18px "Manrope"; }
.process-grid p { color: rgba(255,255,255,.48); font-size: 13px; line-height: 1.65; }
.requirements { display: grid; grid-template-columns: .9fr 1.1fr; gap: 9vw; align-items: center; background: #f9faf6; }
.dark-link { display: inline-flex; gap: 10px; align-items: center; margin-top: 20px; color: var(--green); font-weight: 800; }
.document-stack { display: grid; gap: 12px; }
.doc-card { display: flex; align-items: center; gap: 17px; padding: 21px; border: 1px solid var(--line); border-radius: 12px; background: white; box-shadow: 0 10px 35px rgba(23,50,40,.04); }
.doc-card > i { width: 44px; height: 44px; display: grid; place-items: center; flex: 0 0 44px; border-radius: 10px; color: var(--green); background: #edf3eb; }
.doc-card span { flex: 1; }
.doc-card strong, .doc-card small { display: block; }
.doc-card small { margin-top: 5px; color: var(--muted); font-size: 11px; }
.doc-card b { padding: 5px 9px; border-radius: 30px; color: var(--green); background: #edf5e9; font-size: 9px; text-transform: uppercase; }
.cta-section { display: flex; align-items: center; justify-content: space-between; gap: 60px; padding: 75px max(7vw, 30px); color: white; background: var(--green); }

.qr-verify-page {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 32px;
    background: #f4f7f4;
}

.qr-verify-card {
    width: min(560px, 100%);
    padding: 34px;
    border: 1px solid #dfe7df;
    border-radius: 14px;
    background: #fff;
    box-shadow: 0 20px 60px rgba(8, 38, 25, .12);
}

.qr-verify-mark {
    width: 52px;
    height: 52px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    color: #0f3d2b;
    background: #e8f2e9;
    font-size: 22px;
}

.qr-verify-card > small {
    display: block;
    margin-top: 18px;
    color: #287650;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 1.4px;
    text-transform: uppercase;
}

.qr-verify-card h1 {
    margin: 8px 0 4px;
    color: #10231a;
    font: 800 30px/1.1 "Manrope", sans-serif;
}

.qr-verify-card p {
    margin: 0 0 24px;
    color: #6d7871;
    font-weight: 700;
}

.qr-verify-card dl {
    display: grid;
    gap: 10px;
    margin: 0;
}

.qr-verify-card dl div {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    padding: 12px 0;
    border-top: 1px solid #edf1ed;
}

.qr-verify-card dt {
    color: #7d8982;
    font-size: 12px;
    font-weight: 800;
}

.qr-verify-card dd {
    margin: 0;
    color: #26352c;
    font-size: 12px;
    font-weight: 700;
    text-align: right;
}

.qr-verify-foot {
    display: block;
    margin-top: 24px;
    color: #7d8982;
    font-size: 12px;
}
.cta-section > div:first-child { max-width: 700px; }
.cta-section .kicker { color: var(--lime); }
.cta-section p { max-width: 610px; color: rgba(255,255,255,.64); line-height: 1.7; }
.cta-actions { min-width: 250px; text-align: center; }
.button-light { color: var(--forest-deep); background: white; border-color: white; }
.cta-actions span { display: block; margin-top: 15px; color: rgba(255,255,255,.55); font-size: 11px; }
.cta-actions span a { color: white; font-weight: 700; }
.public-footer { padding: 50px max(7vw, 30px) 28px; color: rgba(255,255,255,.58); background: #041510; font-size: 12px; }
.public-footer .footer-brand { color: white; }
.public-footer > p { max-width: 520px; line-height: 1.6; }
.public-footer > div:nth-of-type(2) { display: flex; gap: 25px; margin: 30px 0; padding: 25px 0; border-top: 1px solid rgba(255,255,255,.08); border-bottom: 1px solid rgba(255,255,255,.08); color: white; }
.public-footer > small { font-size: 10px; }

@media (max-width: 1050px) {
    .public-nav nav { gap: 18px; }
    .public-nav nav > a:not(.button):not(.nav-login) { display: none; }
    .hero { grid-template-columns: 1fr 1fr; }
    .hero h1 { font-size: 58px; }
    .document-float { right: -15px; }
    .secure-float { left: -20px; }
}
@media (max-width: 780px) {
    .public-nav { height: 68px; }
    .nav-toggle { display: block; }
    .public-nav nav { position: absolute; top: 68px; left: 16px; right: 16px; display: none; padding: 18px; border-radius: 12px; background: #09251b; box-shadow: 0 20px 50px rgba(0,0,0,.3); }
    .public-nav nav.open { display: grid; }
    .public-nav nav > a:not(.button):not(.nav-login) { display: block; }
    .nav-login { padding: 10px 0; border: 0; }
    .hero { height: auto; min-height: 100vh; grid-template-columns: 1fr; padding-top: 120px; padding-bottom: 100px; }
    .hero h1 { font-size: clamp(48px, 14vw, 66px); letter-spacing: -3px; }
    .hero-panel { display: none; }
    .hero-actions, .trust-row { align-items: flex-start; flex-direction: column; }
    .trust-row { gap: 10px; }
    .section { padding: 75px 24px; }
    .value-grid, .process-grid, .requirements { grid-template-columns: 1fr; }
    .value-grid article { min-height: 260px; }
    .process-grid article { min-height: 220px; border-right: 0; }
    .requirements { gap: 50px; }
    .cta-section { align-items: flex-start; flex-direction: column; padding: 65px 24px; }
    .cta-actions { width: 100%; text-align: left; }
    .public-footer { padding-left: 24px; padding-right: 24px; }
    .public-footer > div:nth-of-type(2) { flex-wrap: wrap; }
}
