/* Valli Information Systems — valli.com */
@import url("fonts.css");

:root{
  --white:#ffffff;
  --tint:#edf1f7;
  --tint2:#e2e8f2;
  --ink:#101828;
  --soft:#475467;
  --navy:#15295a;
  --blue:#1c3563;
  --blue-lt:#4a6da8;
  --line:#d7dee9;
  --max:1160px;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'IBM Plex Sans',system-ui,sans-serif;background:var(--white);color:var(--ink);line-height:1.65;font-size:17px}
h1,h2,h3{color:var(--navy);line-height:1.12;font-weight:700;letter-spacing:-.015em}
.mono{font-family:'IBM Plex Mono',monospace}
a{color:var(--blue);text-decoration:none}
.wrap{max-width:var(--max);margin:0 auto;padding:0 32px}
.skip{position:absolute;left:-9999px;top:0;background:var(--navy);color:#fff;padding:10px 18px;z-index:100}
.skip:focus{left:0}
/* header */
header{background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.nav{display:flex;align-items:center;justify-content:space-between;padding:15px 32px;max-width:var(--max);margin:0 auto}
.nav img{height:48px;width:auto;display:block}
.nav ul{display:flex;gap:32px;list-style:none;align-items:center}
.nav ul a{color:var(--ink);font-size:15px;font-weight:500}
.nav ul a:hover{color:var(--blue)}
.nav .cta{background:var(--blue);color:#fff;padding:10px 24px;border-radius:6px;font-weight:600}
.nav .cta:hover{background:#0f2240;color:#fff}
/* hero */
.hero{padding:96px 0 84px;border-bottom:1px solid var(--line);background-image:linear-gradient(180deg,rgba(238,242,251,.92) 0%,rgba(255,255,255,.97) 100%),repeating-linear-gradient(0deg,#dce3ee 0 1px,transparent 1px 44px),repeating-linear-gradient(90deg,#dce3ee 0 1px,transparent 1px 44px)}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:64px;align-items:center}
.mono-tag{font-family:'IBM Plex Mono',monospace;font-size:13px;color:var(--blue);letter-spacing:.08em;display:inline-block;margin-bottom:22px;background:#fff;border:1px solid var(--line);border-radius:4px;padding:6px 12px}
.hero h1{font-size:clamp(34px,4.2vw,50px);margin-bottom:22px}
.hero p{font-size:18.5px;color:var(--soft);max-width:54ch;margin-bottom:36px}
.quote-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:38px 40px;box-shadow:0 6px 28px rgba(21,41,90,.07);position:relative}
.quote-card::before{content:"\201C";position:absolute;top:6px;left:26px;font-size:84px;line-height:1;color:var(--blue);opacity:.18;font-family:Georgia,serif}
.quote-card::after{content:"\201D";position:absolute;bottom:-22px;right:26px;font-size:84px;line-height:1;color:var(--blue);opacity:.18;font-family:Georgia,serif}
.quote-card blockquote{font-size:18.5px;line-height:1.65;color:var(--ink);margin:0 0 22px;border:none}
.quote-card blockquote b{color:var(--navy)}
.quote-card .mono{font-size:11.5px;color:#98a2b3;letter-spacing:.14em}
.btn{display:inline-block;background:var(--blue);color:#fff;padding:14px 32px;border-radius:6px;font-weight:600;font-size:16px;border:none;cursor:pointer;font-family:inherit}
.btn:hover{background:#0f2240;color:#fff}
.btn.ghost{background:#fff;color:var(--navy);border:1px solid var(--line);margin-left:12px}
.btn.ghost:hover{border-color:var(--blue);color:var(--blue);background:#fff}
/* ribbon */
.ribbon{padding:22px 0;border-bottom:1px solid var(--line);background:#fff}
.ribbon .wrap{display:flex;flex-wrap:wrap;gap:10px 34px;justify-content:center;align-items:baseline}
.ribbon .mono{font-size:12px;color:#98a2b3;letter-spacing:.1em}
.ribbon span{font-weight:600;color:var(--navy);font-size:15.5px}
/* sections */
section{padding:92px 0}
.mono-kicker{font-family:'IBM Plex Mono',monospace;font-size:13px;color:var(--blue);letter-spacing:.1em;display:block;margin-bottom:16px}
h2{font-size:clamp(28px,3.6vw,42px)}
/* about */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;margin-top:10px}
.about-col{margin-top:18px}
.about-grid p{color:var(--soft);margin-bottom:18px}
.about-grid p b{color:var(--ink)}
.ledger{border:1px solid var(--line);border-radius:10px;overflow:hidden;margin-top:18px}
.ledger .row{display:grid;grid-template-columns:160px 1fr;border-bottom:1px solid var(--line)}
.ledger .row:last-child{border-bottom:none}
.ledger .k{font-family:'IBM Plex Mono',monospace;font-size:13px;color:#98a2b3;padding:18px 20px;background:var(--tint);border-right:1px solid var(--line)}
.ledger .v{padding:18px 20px;font-weight:600;color:var(--navy);font-size:15.5px}
/* services */
.services{background:var(--tint);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.svc-lead{color:var(--soft);font-size:18px;max-width:64ch;margin-top:16px}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:48px}
.sec-band{margin-top:20px;background:var(--navy);border-radius:10px;padding:34px 38px;display:flex;gap:28px;align-items:center}
.sec-band svg{flex:0 0 44px;width:44px;height:44px;stroke:#8fb0dd;fill:none;stroke-width:1.5}
.sec-band .mono{font-size:12px;color:#9db5d6;letter-spacing:.08em;display:block;margin-bottom:8px}
.sec-band h3{color:#fff;font-size:19px;margin-bottom:6px}
.sec-band p{color:#bccbe0;font-size:15px;max-width:90ch}
.svc{background:#fff;border:1px solid var(--line);border-radius:10px;padding:30px 26px;transition:box-shadow .15s,border-color .15s}
.svc:hover{border-color:var(--blue-lt);box-shadow:0 4px 18px rgba(28,53,99,.08)}
.svc .mono{font-size:12px;color:var(--blue);letter-spacing:.08em;display:block;margin-bottom:16px}
.svc svg{width:34px;height:34px;stroke:var(--navy);fill:none;stroke-width:1.6;margin-bottom:18px}
.svc h3{font-size:18.5px;margin-bottom:10px}
.svc p{color:var(--soft);font-size:14.8px}
/* why */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.why{border:1px solid var(--line);border-radius:10px;padding:32px 28px;background:#fff}
.why .mono{font-size:12px;color:#98a2b3;letter-spacing:.08em}
.why h3{font-size:19px;margin:10px 0 10px}
.why p{color:var(--soft);font-size:15.5px}
/* contact */
.contact{background:var(--navy)}
.contact h2{color:#fff}
.contact .mono-kicker{color:#9db5d6}
.contact-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:72px;margin-top:10px}
.contact .lead{color:#bccbe0;font-size:18px;margin-bottom:26px}
.acq{background:#234168;border:1px solid #3a5a85;border-radius:8px;padding:20px 24px;font-size:15px;color:#bccbe0}
.acq b{color:#fff}
form{display:grid;gap:18px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:18px}
label{font-family:'IBM Plex Mono',monospace;font-size:12px;color:#9db5d6;display:block;margin-bottom:7px;letter-spacing:.08em}
input,select,textarea{width:100%;padding:13px 14px;border:1px solid #3a5a85;background:#234168;color:#fff;border-radius:6px;font-family:'IBM Plex Sans',sans-serif;font-size:16px}
input::placeholder,textarea::placeholder{color:#8095b5}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239db5d6' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
input:focus,select:focus,textarea:focus{outline:2px solid var(--blue-lt);border-color:transparent}
.contact .btn{background:#fff;color:var(--navy);justify-self:start;padding:14px 40px}
.contact .btn:hover{background:#dfe6f8}
.hp-field{position:absolute;left:-9999px;top:-9999px;height:0;width:0;overflow:hidden}
.form-msg{display:none;border-radius:8px;padding:16px 20px;font-size:15.5px;margin-bottom:4px}
.form-msg.ok{display:block;background:#1d4d36;border:1px solid #2e7d52;color:#c9ecd9}
.form-msg.err{display:block;background:#5a2430;border:1px solid #8d3a4c;color:#f1c9d2}
/* privacy + utility pages */
.page{padding:72px 0;min-height:55vh}
.page h1{font-size:clamp(30px,4vw,42px);margin-bottom:10px}
.page .updated{font-family:'IBM Plex Mono',monospace;font-size:12.5px;color:#98a2b3;letter-spacing:.08em;display:block;margin-bottom:34px}
.page h2{font-size:22px;margin:34px 0 12px}
.page p,.page li{color:var(--soft);max-width:75ch;margin-bottom:14px}
.page ul{padding-left:22px;margin-bottom:14px}
.center{text-align:center}
/* footer */
footer{background:#0e1c33;padding:36px 0;font-size:14px;color:#8b9cb8}
footer .wrap{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
footer .mono{font-size:12.5px;letter-spacing:.06em}
footer a{color:#b6c3d8}
footer a:hover{color:#fff}
@media(max-width:960px){
  .nav ul{display:none}
  .hero-grid,.about-grid,.contact-grid,.frow{grid-template-columns:1fr;gap:32px}
  .svc-grid{grid-template-columns:1fr 1fr}
  .why-grid{grid-template-columns:1fr}
  section{padding:60px 0}
}
@media(max-width:620px){.svc-grid{grid-template-columns:1fr}}
