/* ===== Basil Sunny — shared styles (navy + slate, corporate-clean) ===== */
:root{
  --navy:#0f1e34;        /* deep navy ink */
  --navy-2:#16294a;      /* raised navy */
  --slate:#334155;       /* slate text */
  --slate-2:#64748b;     /* muted slate */
  --line:#e2e8f0;        /* hairline */
  --line-2:#cbd5e1;
  --bg:#f7f9fc;          /* page bg */
  --surface:#ffffff;     /* cards */
  --ink:#0f172a;         /* headings */
  --accent:#1d6fdb;      /* corporate blue */
  --accent-dk:#1657ad;
  --gold:#b8893d;        /* restrained accent for seniority cues */
  --radius:10px;
  --shadow:0 1px 2px rgba(15,30,52,.04),0 8px 28px rgba(15,30,52,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--slate);
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  line-height:1.65;-webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
.wrap{max-width:1080px;margin:0 auto;padding:0 28px}
h1,h2,h3,h4{color:var(--ink);font-family:"Newsreader","Georgia",serif;font-weight:600;letter-spacing:-.01em;line-height:1.15}

/* ---------- NAV ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.88);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:11px;font-family:"Newsreader",serif}
.brand .mark{width:36px;height:36px;border-radius:8px;background:var(--navy);
  color:#fff;display:grid;place-items:center;font-weight:600;font-size:15px;letter-spacing:.5px}
.brand .who{line-height:1.1}
.brand .who b{display:block;color:var(--ink);font-size:16px;font-weight:600}
.brand .who span{font-family:"Inter",sans-serif;font-size:11.5px;color:var(--slate-2);letter-spacing:.04em;text-transform:uppercase}
.nav-links{display:flex;gap:6px;align-items:center}
.nav-links a{font-size:14.5px;color:var(--slate);padding:8px 14px;border-radius:7px;transition:.18s}
.nav-links a:hover{background:#eef3f9;color:var(--ink)}
.nav-links a.active{color:var(--accent);font-weight:600}
.nav-cta{margin-left:8px;background:var(--navy);color:#fff!important;font-weight:500}
.nav-cta:hover{background:var(--navy-2)!important;color:#fff!important}
.menu-btn{display:none;background:none;border:1px solid var(--line-2);border-radius:7px;
  width:40px;height:40px;font-size:20px;color:var(--ink);cursor:pointer}

/* ---------- HERO / PAGE HEAD ---------- */
.pagehead{background:linear-gradient(180deg,#fff,var(--bg));border-bottom:1px solid var(--line);padding:64px 0 52px}
.eyebrow{font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);
  font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:24px;height:2px;background:var(--accent);opacity:.5}
.greeting{font-size:16px;color:var(--slate-2);margin-bottom:8px}
.pagehead h1{font-size:clamp(32px,5vw,46px)}
.pagehead .sub{font-size:18px;color:var(--slate-2);max-width:620px;margin-top:14px}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-size:14.5px;font-weight:500;
  padding:12px 22px;border-radius:8px;border:1px solid transparent;cursor:pointer;transition:.2s}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-dk);box-shadow:0 6px 18px rgba(29,111,219,.28);transform:translateY(-1px)}
.btn-outline{background:#fff;border-color:var(--line-2);color:var(--ink)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}

/* ---------- SECTIONS ---------- */
section{padding:62px 0}
.sec-head{margin-bottom:34px}
.sec-head .eyebrow{justify-content:flex-start}
.sec-head h2{font-size:clamp(26px,3.6vw,34px)}
.sec-head p{color:var(--slate-2);max-width:640px;margin-top:10px;font-size:16px}

/* ---------- HERO SPLIT ---------- */
.hero{display:grid;grid-template-columns:1fr 300px;gap:54px;align-items:start}
.hero .lede{font-size:17px;color:var(--slate);max-width:560px;margin:18px 0 28px;line-height:1.7}
.hero .ctas{display:flex;gap:13px;flex-wrap:wrap}
.profile-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden}
.profile-card .ph{height:96px;background:linear-gradient(120deg,var(--navy),var(--navy-2))}
.profile-card .body{padding:0 22px 24px;text-align:center;margin-top:-46px}
.profile-card .avatar{width:92px;height:92px;border-radius:50%;border:4px solid #fff;object-fit:cover;background:#dbe4ef;margin:0 auto}
.profile-card .name{font-family:"Newsreader",serif;font-size:19px;color:var(--ink);font-weight:600;margin-top:12px}
.profile-card .role{font-size:13px;color:var(--accent);font-weight:600;letter-spacing:.02em}
.profile-card ul{list-style:none;margin-top:18px;border-top:1px solid var(--line);padding-top:16px;text-align:left;display:grid;gap:11px;font-size:13.5px}
.profile-card li{display:flex;justify-content:space-between;color:var(--slate-2)}
.profile-card li b{color:var(--ink);font-weight:500}

/* ---------- TIMELINE ---------- */
.timeline{position:relative;margin-left:6px}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--line)}
.job{position:relative;padding:0 0 30px 38px}
.job:last-child{padding-bottom:0}
.job::before{content:"";position:absolute;left:0;top:5px;width:16px;height:16px;border-radius:50%;
  background:#fff;border:3px solid var(--accent)}
.job .when{font-size:12.5px;color:var(--slate-2);font-weight:500;letter-spacing:.02em}
.job h3{font-size:18px;margin:3px 0 1px}
.job .co{font-size:14px;color:var(--accent);font-weight:600;margin-bottom:9px}
.job ul{margin:0;padding-left:18px;font-size:14.5px;color:var(--slate);display:grid;gap:5px}
.job ul li::marker{color:var(--line-2)}

/* ---------- CARDS GRID ---------- */
.grid{display:grid;gap:18px}
.grid.cols-2{grid-template-columns:1fr 1fr}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;box-shadow:var(--shadow);transition:.22s}
.card:hover{transform:translateY(-3px);box-shadow:0 12px 34px rgba(15,30,52,.10);border-color:var(--line-2)}

/* problem widget */
.problem .tag{display:inline-block;font-size:11.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  color:var(--accent);background:#eaf2fd;border-radius:5px;padding:4px 10px;margin-bottom:14px}
.problem h3{font-size:19px;margin-bottom:10px}
.problem .lbl{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--slate-2);margin:14px 0 4px}
.problem p{font-size:14.5px;color:var(--slate)}
.problem .stack{margin-top:16px;display:flex;gap:7px;flex-wrap:wrap}
.problem .stack span{font-size:11.5px;color:var(--slate-2);background:var(--bg);border:1px solid var(--line);border-radius:5px;padding:4px 9px}
.editable{outline:none;border-radius:4px;transition:.15s}
.editable:focus{background:#fffbe9;box-shadow:0 0 0 2px var(--gold)}
.edit-hint{font-size:12.5px;color:var(--slate-2);background:#fff;border:1px dashed var(--line-2);
  border-radius:8px;padding:11px 16px;margin-bottom:26px;display:flex;align-items:center;gap:9px}

/* contact widgets */
.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.cwidget{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:20px 22px;box-shadow:var(--shadow);transition:.2s}
.cwidget:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 10px 28px rgba(29,111,219,.12)}
.cwidget .ic{width:46px;height:46px;border-radius:10px;flex-shrink:0;display:grid;place-items:center;
  background:#eaf2fd;color:var(--accent);font-size:20px}
.cwidget .k{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--slate-2);font-weight:600}
.cwidget .v{font-size:15.5px;color:var(--ink);font-weight:500;margin-top:1px;word-break:break-word}

/* skill placeholder */
.soon{text-align:center;padding:70px 24px;background:var(--surface);border:1px dashed var(--line-2);
  border-radius:var(--radius)}
.soon .ic{font-size:34px}
.soon h3{font-size:22px;margin:14px 0 8px}
.soon p{color:var(--slate-2);max-width:440px;margin:0 auto}

/* ---------- FOOTER ---------- */
footer{border-top:1px solid var(--line);background:#fff;padding:30px 0;margin-top:30px}
.foot-in{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
  font-size:13.5px;color:var(--slate-2)}
.foot-in .fl{display:flex;gap:18px}
.foot-in a:hover{color:var(--accent)}

/* reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .55s ease,transform .55s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- RESPONSIVE ---------- */
@media(max-width:880px){
  .hero{grid-template-columns:1fr}
  .profile-card{max-width:340px}
  .nav-links{display:none}
  .menu-btn{display:grid;place-items:center}
  .nav-links.open{display:flex;position:absolute;top:68px;left:0;right:0;flex-direction:column;
    align-items:stretch;background:#fff;border-bottom:1px solid var(--line);padding:14px 28px;gap:4px}
  .nav-links.open a{padding:11px 14px}
  .nav-cta{margin-left:0}
}
@media(max-width:680px){
  .grid.cols-2,.grid.cols-3,.contact-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}
