/* cabibbo.com — custom styles (navy/gray, matches résumé) */
:root{
  --navy:#1F3A5F;
  --navy-dark:#16293f;
  --accent:#2D7DD2;
  --accent-light:#4aa3ff;
  --ink:#1a2230;
  --gray:#555c66;
  --muted:#7a828c;
  --line:#e3e8ee;
  --bg:#ffffff;
  --bg-alt:#f6f8fb;
  --radius:14px;
  --shadow:0 8px 24px rgba(16,32,56,.08);
  --shadow-lg:0 14px 38px rgba(16,32,56,.14);
  --maxw:1100px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:74px;}
body{
  margin:0;color:var(--ink);background:var(--bg);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  line-height:1.6;-webkit-font-smoothing:antialiased;
}
a{color:var(--accent);text-decoration:none;}
a:hover{text-decoration:underline;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px;}
.center{text-align:center;margin-top:26px;}

/* ---- Buttons ---- */
.btn{
  display:inline-block;background:var(--navy);color:#fff;border:2px solid var(--navy);
  padding:.7em 1.4em;border-radius:999px;font-weight:600;font-size:.95rem;
  cursor:pointer;transition:all .18s ease;text-decoration:none;
}
.btn:hover{background:var(--navy-dark);border-color:var(--navy-dark);text-decoration:none;transform:translateY(-1px);box-shadow:var(--shadow);}
.btn--ghost{background:transparent;color:var(--navy);}
.btn--ghost:hover{background:var(--navy);color:#fff;}
.btn--sm{padding:.45em 1em;font-size:.85rem;}

/* ---- Nav ---- */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:64px;}
.nav__brand{font-weight:800;font-size:1.2rem;color:var(--navy);letter-spacing:.3px;}
.nav__brand:hover{text-decoration:none;}
.nav__links{display:flex;align-items:center;gap:22px;}
.nav__links a{color:var(--gray);font-weight:600;font-size:.92rem;}
.nav__links a:hover{color:var(--navy);text-decoration:none;}
.nav__links a.btn{color:#fff;}
.nav__links a.btn:hover{color:#fff;}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;}
.nav__toggle span{width:24px;height:2px;background:var(--navy);transition:.2s;}

/* ---- Hero ---- */
.hero{
  background:linear-gradient(160deg,#16293f 0%,#1F3A5F 55%,#2a5488 100%);
  color:#fff;padding:84px 0 76px;
}
.hero__inner{max-width:820px;}
.hero__eyebrow{text-transform:uppercase;letter-spacing:2px;font-size:.78rem;color:#a9c4e6;margin:0 0 10px;}
.hero__name{font-size:3.2rem;line-height:1.05;margin:0 0 10px;font-weight:800;}
.hero__tagline{font-size:1.5rem;margin:0;color:#eaf1fb;font-weight:600;}
.hero__subtag{font-size:1.05rem;margin:.2em 0 18px;color:#a9c4e6;font-weight:600;}
.hero__intro{font-size:1.08rem;color:#dfe8f4;max-width:680px;margin:0 0 28px;}
.hero__cta{display:flex;flex-wrap:wrap;gap:12px;}
.hero .btn{background:#fff;color:var(--navy);border-color:#fff;}
.hero .btn:hover{background:#eaf1fb;border-color:#eaf1fb;}
.hero .btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6);}
.hero .btn--ghost:hover{background:#fff;color:var(--navy);}

/* ---- Sections ---- */
.section{padding:68px 0;}
.section--alt{background:var(--bg-alt);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.section__title{font-size:1.8rem;color:var(--navy);margin:0 0 8px;font-weight:800;position:relative;padding-bottom:10px;}
.section__title::after{content:"";position:absolute;left:0;bottom:0;width:54px;height:3px;background:var(--accent);border-radius:3px;}
.section__sub{color:var(--gray);margin:0 0 26px;font-size:1.02rem;}
.lede{font-size:1.08rem;color:var(--gray);max-width:820px;}

/* ---- Chips ---- */
.chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px;}
.chip{background:#eaf1fb;color:var(--navy);padding:.4em .9em;border-radius:999px;font-size:.85rem;font-weight:600;border:1px solid #d4e2f4;}

/* ---- Grid ---- */
.grid{display:grid;gap:22px;}
.grid--2{grid-template-columns:repeat(2,1fr);}
.grid--3{grid-template-columns:repeat(3,1fr);}
.grid--4{grid-template-columns:repeat(4,1fr);}
.grid--top{align-items:start;}

/* ---- Cards ---- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease;}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);}
.card h3{margin:0 0 8px;color:var(--navy);font-size:1.12rem;}
.card p{margin:0;color:var(--gray);font-size:.95rem;}
.service__icon{font-size:1.9rem;margin-bottom:8px;}

/* ---- Projects ---- */
.project__top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px;}
.project__top h3{margin:0;}
.badge{background:var(--navy);color:#fff;font-size:.68rem;font-weight:700;padding:.25em .6em;border-radius:999px;white-space:nowrap;letter-spacing:.3px;}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px;}
.tag{background:#eef2f7;color:var(--gray);font-size:.74rem;font-weight:600;padding:.28em .7em;border-radius:6px;border:1px solid var(--line);}

/* ---- Timeline ---- */
.timeline{border-left:2px solid var(--line);margin-left:6px;}
.tl{position:relative;padding:0 0 26px 26px;}
.tl::before{content:"";position:absolute;left:-7px;top:6px;width:12px;height:12px;border-radius:50%;background:var(--accent);border:2px solid #fff;box-shadow:0 0 0 2px var(--line);}
.tl:last-child{padding-bottom:0;}
.tl__head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.tl__role{margin:0;color:var(--ink);font-size:1.08rem;}
.tl__org{color:var(--gray);font-weight:600;font-size:.95rem;}
.tl__dates{color:var(--muted);font-size:.85rem;font-weight:600;white-space:nowrap;}
.tl__points{margin:8px 0 0;padding-left:18px;color:var(--gray);}
.tl__points li{margin-bottom:5px;font-size:.95rem;}

/* ---- Skills / edu ---- */
.skillrow{margin-bottom:16px;}
.skillrow__label{display:block;font-weight:700;color:var(--navy);margin-bottom:6px;font-size:.95rem;}
.edu{margin:0;padding-left:18px;color:var(--gray);}
.edu li{margin-bottom:8px;}

/* ---- Contact ---- */
.contactlist{list-style:none;margin:0;padding:0;}
.contactlist li{margin-bottom:12px;color:var(--gray);}
.contactlist strong{display:inline-block;width:84px;color:var(--navy);}
.form__row{margin-bottom:14px;display:flex;flex-direction:column;}
.form__row label{font-weight:600;color:var(--navy);margin-bottom:5px;font-size:.9rem;}
.form input,.form textarea,.form select{
  font:inherit;padding:.65em .8em;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink);
}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(45,125,210,.15);}
.form textarea{resize:vertical;}
.hp{position:absolute;left:-9999px;height:0;overflow:hidden;}
.form__status{margin:12px 0 0;font-size:.92rem;font-weight:600;min-height:1.2em;}
.form__status.ok{color:#1e7e34;}
.form__status.err{color:#c0392b;}

/* ---- Footer ---- */
.footer{background:var(--navy-dark);color:#cdd9e6;padding:24px 0;}
.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;font-size:.88rem;}
.footer a{color:#a9c4e6;}

/* ---- Responsive ---- */
@media (max-width:860px){
  .grid--4{grid-template-columns:repeat(2,1fr);}
  .grid--3{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:680px){
  .hero__name{font-size:2.3rem;}
  .hero__tagline{font-size:1.2rem;}
  .grid--2,.grid--3,.grid--4{grid-template-columns:1fr;}
  .nav__toggle{display:flex;}
  .nav__links{
    position:absolute;top:64px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);
    flex-direction:column;align-items:flex-start;gap:0;padding:8px 22px 16px;
    display:none;box-shadow:var(--shadow);
  }
  .nav__links.open{display:flex;}
  .nav__links a{padding:10px 0;width:100%;}
}
