/* Shared styles for the Adam Hanafi profile */
:root{
  --accent:#c49a45;
  --bg1:#111719;
  --bg2:#24372f;
  --muted:rgba(244,239,226,0.82);
}
*{box-sizing:border-box}
body{font-family:Inter,system-ui,Arial,Helvetica,sans-serif;margin:0;color:var(--muted);background:linear-gradient(135deg,var(--bg1),var(--bg2) 58%,#4b3f2b);min-height:100vh;-webkit-font-smoothing:antialiased}
.container{max-width:1100px;margin:0 auto;padding:24px}
.site-header{position:fixed;left:0;right:0;top:0;padding:12px 24px;z-index:40;background:linear-gradient(180deg,rgba(9,12,13,0.74),rgba(9,12,13,0))}
.site-header .container{display:flex;align-items:center;justify-content:center;gap:64px}
.brand{color:#fff;font-weight:800;text-decoration:none;font-size:20px}
.main-nav{display:flex;align-items:center;gap:18px}
.main-nav a{color:rgba(255,255,255,0.82);text-decoration:none;font-weight:600}
.hero{position:relative;height:72vh;min-height:520px;overflow:hidden;background:#111719;display:flex;align-items:center;justify-content:center}
#scene{position:absolute;inset:0;width:100%;height:100%;display:block}
.hero-overlay{position:relative;z-index:30;padding:96px 24px;color:#fff;max-width:760px;text-align:center;display:flex;flex-direction:column;align-items:center}
.hero-overlay h1{font-family:'Dancing Script',cursive;font-size:88px;font-weight:700;margin:0;line-height:1.05;color:#fff;text-shadow:0 7px 24px rgba(0,0,0,0.48);white-space:nowrap;overflow:hidden;width:0;display:inline-block;border-right:3px solid rgba(255,255,255,0.92);animation:typeCursive 2.2s steps(12,end) .25s forwards, caretPulse .75s step-end infinite;letter-spacing:0}
.hero-overlay .tag{margin-top:14px;font-weight:600;opacity:0;animation:fadeUp .9s ease 2.35s both}
.btn{display:inline-block;background:var(--accent);color:#141414;padding:10px 18px;border-radius:8px;text-decoration:none;font-weight:700;margin-right:8px}
.btn.ghost{background:rgba(0,0,0,0.18);border:1px solid rgba(255,255,255,0.24);color:#fff}
.intro{padding:48px 24px;text-align:center}
.intro h2{font-size:22px;color:#fff;margin-bottom:12px}
.site-footer{padding:28px 0;color:rgba(255,255,255,0.6);text-align:center}
.page{padding:120px 24px 48px}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-top:18px}
.cards article{background:linear-gradient(180deg,rgba(255,255,255,0.03),rgba(255,255,255,0.01));padding:20px;border-radius:10px}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-top:18px}

/* Subtle overlay for title contrast */
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,10,11,0.72),rgba(7,10,11,0.34) 38%,rgba(7,10,11,0.08) 72%),linear-gradient(180deg,rgba(0,0,0,0.24),transparent 42%,rgba(0,0,0,0.18));z-index:20}

 /* Animated hero text */
 @keyframes typeCursive{from{width:0}to{width:5.7em}}
 @keyframes caretPulse{0%,100%{border-color:transparent}50%{border-color:rgba(255,255,255,0.92)}}
 .hero-overlay .cta{animation:fadeUp .9s ease 2.55s both}
 @keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
 
.case-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:20px}
.case-card{background:linear-gradient(180deg,rgba(255,255,255,0.03),rgba(255,255,255,0.01));padding:20px;border-radius:12px;overflow:hidden;position:relative;transition:transform .36s cubic-bezier(.2,.9,.2,1),box-shadow .36s}
.case-card:hover{transform:translateY(-8px);box-shadow:0 18px 40px rgba(0,0,0,0.28)}
.case-card h3{margin:0 0 8px 0;color:#fff}
.case-card p{margin:0;color:rgba(255,255,255,0.78)}
.case-thumb{height:140px;background:linear-gradient(180deg,rgba(0,0,0,0.1),rgba(0,0,0,0.18));border-radius:8px;margin-bottom:12px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.18);font-weight:700}

/* Page transition helper */
.page-enter{opacity:0;transform:translateY(6px)}
.page-ready{opacity:1;transform:none;transition:opacity .45s,transform .45s}
.page-exit{opacity:0;transform:translateY(-8px);transition:opacity .36s,transform .36s}

@media (max-width:700px){
  .site-header{padding:8px 10px}
  .site-header .container{padding:16px;gap:16px}
  .brand{font-size:18px}
  .main-nav{gap:12px}
  .hero{height:76vh;min-height:560px}
  .hero-overlay{padding:96px 20px 40px}
  .hero-overlay h1{font-size:56px}
  .btn{margin-bottom:8px}
}
