/* FSU-inspired palette (garnet & gold) */
:root{
  --garnet:#782F40;
  --garnet-2:#5e1f2e;
  --gold:#CEB888;

  --ink:#0f1115;
  --muted:#555b66;

  --bg:#ffffff;
  --surface:#f7f7fa;
  --surface-2:#ffffff;

  --border:rgba(15,17,21,.12);
  --shadow:0 18px 40px rgba(15,17,21,.10);

  --radius:18px;
  --max:1120px;
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  text-rendering:optimizeLegibility;
}

img{max-width:100%; height:auto; display:block}
.container{width:min(var(--max), calc(100% - 2rem)); margin-inline:auto;}

.skip-link{position:absolute;left:-999px;top:0;background:var(--garnet);color:white;padding:.6rem .9rem;border-radius:12px;z-index:999;}
.skip-link:focus{left:1rem;top:1rem}

.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.78);
  backdrop-filter:saturate(170%) blur(14px);
  border-bottom:1px solid var(--border);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.9rem 0;gap:1rem;}

.brand{display:flex;align-items:center;gap:.75rem;min-width:260px;text-decoration:none;color:inherit;}
.brand-mark{
  width:44px;height:44px;border-radius:16px;
  background:radial-gradient(circle at 30% 25%, rgba(255,255,255,.35), transparent 45%),
             linear-gradient(135deg, var(--garnet), var(--garnet-2));
  box-shadow:0 14px 22px rgba(120,47,64,.22);
  border:1px solid rgba(255,255,255,.32);
}
.brand-text{display:flex;flex-direction:column;gap:.1rem}
.name{font-weight:900;letter-spacing:.2px}
.tagline{font-size:.92rem;color:var(--muted);font-weight:650}

.nav{display:flex;gap:1rem;align-items:center}
.nav a{color:var(--ink);text-decoration:none;font-weight:750;font-size:.98rem;padding:.35rem .2rem;position:relative;}
.nav a:not(.btn)::after{
  content:""; position:absolute; left:0; right:0; bottom:-.2rem; height:2px;
  background:linear-gradient(90deg, transparent, rgba(120,47,64,.55), transparent);
  transform:scaleX(0); transform-origin:center; transition:transform .18s ease;
}
.nav a:not(.btn):hover{color:var(--garnet)}
.nav a:not(.btn):hover::after{transform:scaleX(1)}

.menu-btn{display:none;width:44px;height:44px;border-radius:14px;border:1px solid rgba(120,47,64,.22);background:rgba(120,47,64,.04);cursor:pointer;}
.menu-btn span{display:block;width:18px;height:2px;background:var(--garnet);margin:4px auto;border-radius:999px;}

.mobile-nav{display:none;border-top:1px solid var(--border);background:rgba(255,255,255,.92);backdrop-filter:saturate(170%) blur(12px);}
.mobile-nav a{
  display:block;
  padding:1rem calc((100% - min(var(--max), calc(100% - 2rem))) / 2 + 1rem);
  text-decoration:none;color:var(--ink);font-weight:850;border-bottom:1px solid rgba(15,17,21,.06);
}
.mobile-nav a:hover{background:rgba(120,47,64,.05)}
.mobile-cta{color:var(--garnet)}
@media (max-width: 900px){
  .nav{display:none}
  .menu-btn{display:inline-grid;place-items:center}
  .mobile-nav{display:block}
}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.9rem 1.1rem;border-radius:999px;border:1px solid rgba(120,47,64,.25);
  background:linear-gradient(135deg, var(--garnet), var(--garnet-2));
  color:white;text-decoration:none;font-weight:850;
  box-shadow:0 14px 26px rgba(120,47,64,.18);
  transition:transform .12s ease, box-shadow .12s ease;
}
.btn:hover{transform:translateY(-1px);box-shadow:0 18px 30px rgba(120,47,64,.22)}
.btn:active{transform:translateY(0)}
.btn-ghost{background:transparent;color:var(--garnet);border:1px solid rgba(120,47,64,.35);box-shadow:none;}
.btn-ghost:hover{background:rgba(120,47,64,.06);transform:translateY(-1px)}
.btn-small{padding:.55rem .85rem;font-size:.95rem}

.hero{
  position:relative;
  padding:3.2rem 0 0;
  background:
    radial-gradient(circle at 15% 0%, rgba(206,184,136,.28), transparent 48%),
    radial-gradient(circle at 90% 10%, rgba(120,47,64,.16), transparent 42%),
    linear-gradient(180deg, #ffffff, #fbfbfd);
  overflow:hidden;
}
.hero-grid{display:grid;grid-template-columns: 1.15fr .85fr;gap:2.2rem;align-items:start;padding-bottom:2.3rem;}
@media (max-width: 900px){.hero-grid{grid-template-columns:1fr;gap:1.6rem}}

.pill{
  display:inline-flex;align-items:center;gap:.55rem;
  background:rgba(206,184,136,.25);border:1px solid rgba(206,184,136,.55);
  color:var(--garnet);padding:.35rem .7rem;border-radius:999px;font-weight:900;font-size:.9rem;
}
.dot{width:.5rem;height:.5rem;border-radius:999px;background:linear-gradient(135deg, var(--gold), var(--garnet));}

h1{margin:.7rem 0 .8rem;font-size: clamp(2.05rem, 4.1vw, 3.1rem);letter-spacing:-1px;line-height:1.1;}
.lead{font-size:1.12rem;color:#2a2f39;max-width:65ch;}
.hero-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin:1.25rem 0 1.1rem;}

.portrait{
  margin:0;background:rgba(255,255,255,.65);border:1px solid var(--border);
  border-radius:26px;padding:1rem;box-shadow:var(--shadow);
}
.portrait-frame{border-radius:20px;overflow:hidden;position:relative;}
.portrait-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, transparent 55%, rgba(15,17,21,.18));pointer-events:none;}
.portrait img{aspect-ratio: 4 / 5;object-fit:cover;}
.portrait figcaption{margin-top:.8rem;font-weight:900;color:var(--garnet);display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.badge{
  display:inline-flex;align-items:center;padding:.35rem .6rem;border-radius:999px;
  background:rgba(120,47,64,.06);border:1px solid rgba(120,47,64,.16);color:#2a2f39;font-weight:850;font-size:.9rem;
}

.mini-card{
  margin-top:1rem;
  border:1px solid rgba(206,184,136,.55);
  background:rgba(206,184,136,.16);
  border-radius:18px;
  padding:1rem;
}
.mini-title{font-weight:950;color:var(--garnet);margin-bottom:.4rem}
.mini-list{margin:0;padding-left:1.1rem}
.mini-list li{margin:.25rem 0}

.stats{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:.9rem;
  margin-top:1.1rem;
}
@media (max-width: 900px){.stats{grid-template-columns:1fr}}
.stat{background:rgba(255,255,255,.72);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;box-shadow:0 12px 26px rgba(15,17,21,.06);}
.stat-top{font-weight:950;color:var(--garnet);margin-bottom:.25rem}
.stat-bottom{color:var(--muted);font-weight:750;font-size:.98rem}

.wave{height:110px;width:100%;}
.wave svg{width:100%;height:100%}
.wave path{fill:rgba(120,47,64,.06)}

.section{padding:3.1rem 0}
.section.alt{background:var(--surface)}
.section-head{max-width:74ch;margin-bottom:1.45rem}
.section-head h2{margin:0 0 .35rem;font-size:1.85rem;letter-spacing:-.5px;}
.section-subtitle{margin:0;color:var(--muted);font-weight:750}

.three-col{display:grid;grid-template-columns:repeat(3, 1fr);gap:1rem;}
@media (max-width: 900px){.three-col{grid-template-columns:1fr}}

.panel{
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1.25rem 1.25rem 1.15rem;
  box-shadow:0 12px 26px rgba(15,17,21,.05);
}
.panel h3{margin:.1rem 0 .85rem;color:var(--garnet);letter-spacing:-.25px}
.panel h4{margin:1rem 0 .5rem;color:#2a2f39}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
@media (max-width: 900px){.grid-2{grid-template-columns:1fr}}

.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}
.panel-tag{
  display:inline-flex;align-items:center;
  padding:.35rem .6rem;border-radius:999px;
  background:rgba(120,47,64,.06);
  border:1px solid rgba(120,47,64,.16);
  color:#2a2f39;font-weight:850;font-size:.88rem;
  white-space:nowrap;
}

.bullets{margin:.35rem 0 0;padding-left:1.1rem}
.bullets li{margin:.35rem 0}
.bullets.tight li{margin:.25rem 0}

.credits{list-style:none;padding:0;margin:.25rem 0 0}
.credits li{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;padding:.6rem 0;border-bottom:1px dashed rgba(15,17,21,.16);}
.credits li:last-child{border-bottom:none}
.role{font-weight:900}
.show{color:var(--muted);font-weight:750}

.subpanel{
  margin-top:1rem;
  padding:1rem;
  border-radius:16px;
  border:1px solid rgba(206,184,136,.55);
  background:rgba(206,184,136,.16);
}

.callout-row{display:grid;grid-template-columns:1.3fr .7fr;gap:1rem;margin-top:1rem;}
@media (max-width: 900px){.callout-row{grid-template-columns:1fr}}

.callout{
  border-radius:var(--radius);
  border:1px solid rgba(120,47,64,.18);
  background:radial-gradient(circle at 10% 10%, rgba(206,184,136,.18), transparent 40%),
             linear-gradient(135deg, rgba(120,47,64,.07), rgba(120,47,64,.02));
  padding:1.25rem;
}
.callout h3{margin:.1rem 0 .9rem;color:var(--garnet)}
.callout-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:1rem;}
@media (max-width: 900px){.callout-grid{grid-template-columns:1fr}}
.chipbox{background:rgba(255,255,255,.74);border:1px solid var(--border);border-radius:16px;padding:1rem;}
.chipbox-title{font-weight:950;margin-bottom:.25rem}

.quote{
  border-radius:var(--radius);
  border:1px solid var(--border);
  background:rgba(255,255,255,.74);
  padding:1.25rem;
  box-shadow:0 12px 26px rgba(15,17,21,.05);
}
.quote p{margin:0 0 .8rem;font-weight:900;letter-spacing:-.2px}
.quote-by{color:var(--muted);font-weight:800}

.sm-inline{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:start;margin-top:1rem;}
@media (max-width: 900px){.sm-inline{grid-template-columns:1fr}}
.sm-photo{width:180px;border-radius:14px;box-shadow:0 10px 22px rgba(15,17,21,.14);border:1px solid rgba(255,255,255,.35);}

.timeline{margin-top:1rem}
.timeline h3{margin:.2rem 0 .9rem}
.timeline-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;}
@media (max-width: 900px){.timeline-grid{grid-template-columns:1fr}}
.t-item{background:rgba(255,255,255,.74);border:1px solid var(--border);border-radius:16px;padding:1rem;position:relative;overflow:hidden;}
.t-dot{width:10px;height:10px;border-radius:999px;background:linear-gradient(135deg,var(--gold),var(--garnet));margin-bottom:.6rem}
.t-title{font-weight:950;margin-bottom:.25rem}
.t-body{font-weight:750}

.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;}
@media (max-width: 900px){.work-grid{grid-template-columns:1fr}}
.work-card{background:rgba(255,255,255,.74);border:1px solid var(--border);border-radius:var(--radius);padding:1.15rem;box-shadow:0 12px 26px rgba(15,17,21,.05);}
.work-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.7rem}
.work-title{font-weight:950}
.work-role{color:var(--garnet);font-weight:900}
.work-date{color:var(--muted);font-weight:800;white-space:nowrap}

.privacy{margin-top:1rem;color:var(--muted);font-weight:800}

.skills-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:1rem;}
@media (max-width: 900px){.skills-grid{grid-template-columns:1fr}}
.chips{list-style:none;padding:0;margin:.25rem 0 0;display:flex;flex-wrap:wrap;gap:.55rem;}
.chips li{
  padding:.45rem .7rem;border-radius:999px;
  background:rgba(120,47,64,.06);border:1px solid rgba(120,47,64,.16);
  color:#2a2f39;font-weight:850;font-size:.95rem;
}

.cert{margin-top:1rem;display:flex;align-items:center;gap:.75rem;padding:.85rem;border-radius:16px;border:1px solid rgba(206,184,136,.55);background:rgba(206,184,136,.16);}
.cert-badge{width:34px;height:34px;border-radius:999px;display:grid;place-items:center;background:linear-gradient(135deg,var(--gold),#e7d7ab);color:var(--garnet);font-weight:1000;border:1px solid rgba(120,47,64,.16);}
.cert-title{font-weight:950}

.faq{margin-top:1rem}
.faq h3{margin:.2rem 0 .9rem}
.faq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;}
@media (max-width: 900px){.faq-grid{grid-template-columns:1fr}}
.faq-item{background:rgba(255,255,255,.74);border:1px solid var(--border);border-radius:16px;padding:1rem;}
.faq-q{font-weight:950;margin-bottom:.25rem}
.faq-a{font-weight:750}

.portfolio-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;}
@media (max-width: 900px){.portfolio-grid{grid-template-columns:1fr 1fr}}
@media (max-width: 520px){.portfolio-grid{grid-template-columns:1fr}}
.portfolio-card{
  display:block;
  text-decoration:none;
  color:inherit;
  background:rgba(255,255,255,.74);
  border:1px solid var(--border);
  border-radius:18px;
  padding:1rem;
  box-shadow:0 12px 26px rgba(15,17,21,.05);
}
.portfolio-card:hover{transform:translateY(-1px)}
.ph{
  height:110px;
  border-radius:14px;
  border:1px dashed rgba(120,47,64,.28);
  background:
    radial-gradient(circle at 20% 25%, rgba(206,184,136,.20), transparent 45%),
    radial-gradient(circle at 80% 0%, rgba(120,47,64,.10), transparent 40%),
    rgba(120,47,64,.03);
  margin-bottom:.8rem;
}
.p-title{font-weight:950;margin-bottom:.2rem}

.cta-band{
  margin-top:1rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:1.25rem;
  border-radius:var(--radius);
  border:1px solid rgba(120,47,64,.18);
  background:linear-gradient(135deg, rgba(120,47,64,.06), rgba(206,184,136,.12));
}
@media (max-width: 900px){.cta-band{flex-direction:column; align-items:flex-start}}

.contact-card{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;}
@media (max-width: 900px){.contact-card{grid-template-columns:1fr}}
.contact-item{background:rgba(255,255,255,.74);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;}
.label{color:var(--muted);font-weight:900;font-size:.88rem;text-transform:uppercase;letter-spacing:.08em}
.contact-item a{color:var(--garnet);font-weight:950;text-decoration:none}
.contact-item a:hover{text-decoration:underline}
.fineprint{margin-top:1.25rem;color:var(--muted);font-weight:800}

.footer{border-top:1px solid var(--border);padding:1.2rem 0;background:#fff;}
.footer-inner{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;align-items:center;}
.backtotop{color:var(--garnet);font-weight:950;text-decoration:none}
.backtotop:hover{text-decoration:underline}
.muted{color:var(--muted)}
