@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,600;0,700;0,800;1,600;1,700;1,800&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&family=Fira+Code:wght@400;500&display=swap');

/* ═══════════════════════════════════════════════════
   RESET & TOKENS
═══════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

:root{
  /* Sky-blue palette */
  --sky-50:  #f0f9ff;   /* lightest — page body bg */
  --sky-100: #e0f2fe;   /* light sections */
  --sky-200: #bae6fd;   /* mid sky — alt sections, cards */
  --sky-300: #7dd3fc;   /* borders, dividers */
  --sky-400: #38bdf8;   /* accents */

  /* Ink — deep navy for text & dark sections */
  --ink:     #0c1a2e;
  --ink-2:   #1a3050;
  --ink-3:   #2d4a6e;

  /* Brand green */
  --green:   #0d6e42;
  --green-2: #15a060;
  --green-3: #bbead6;

  /* Amber — CTA / highlight */
  --amber:   #d97706;
  --amber-2: #f59e0b;

  /* Functional */
  --muted:   #3b5a7a;
  --border:  #7dd3fc;    /* sky-300 */
  --white:   #ffffff;

  /* Typography */
  --display: 'Playfair Display', Georgia, serif;
  --body:    'Plus Jakarta Sans', system-ui, sans-serif;
  --mono:    'Fira Code', 'Courier New', monospace;
}

body{
  font-family:var(--body);
  font-weight:400;
  font-size:1.0625rem;      /* 17px */
  color:var(--ink);
  background:var(--sky-50);
  line-height:1.82;
  overflow-x:hidden;
}

::-webkit-scrollbar{width:7px}
::-webkit-scrollbar-track{background:var(--ink)}
::-webkit-scrollbar-thumb{background:var(--green-2);border-radius:4px}

/* ═══════════════════════════════════════════════════
   NAV
═══════════════════════════════════════════════════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:64px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(1.25rem,4vw,3rem);
  background:rgba(12,26,46,0.97);
  backdrop-filter:blur(20px) saturate(1.6);
  border-bottom:1px solid rgba(125,211,252,0.12);
  transition:background .3s;
}

.nav__logo{
  display:flex;align-items:center;gap:.625rem;
  font-family:var(--display);font-weight:800;font-style:italic;
  font-size:1.4rem;color:var(--white);text-decoration:none;
  letter-spacing:-.01em;
}
.nav__logo-mark{
  width:34px;height:34px;border-radius:8px;background:var(--green);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:.65rem;font-weight:500;
  color:var(--white);letter-spacing:0;font-style:normal;flex-shrink:0;
}
.nav__logo em{color:var(--amber-2);font-style:italic}

.nav__links{display:flex;align-items:center;gap:.2rem;list-style:none}
.nav__links a{
  font-size:.875rem;font-weight:500;
  color:rgba(255,255,255,.58);text-decoration:none;
  padding:.4rem .85rem;border-radius:7px;
  transition:color .18s,background .18s;
}
.nav__links a:hover{color:var(--white);background:rgba(255,255,255,.08)}
.nav__links a.active{color:var(--amber-2)}
.nav__cta{
  background:var(--amber)!important;color:var(--white)!important;
  font-weight:600!important;padding:.45rem 1.1rem!important;
  border-radius:7px;transition:background .18s!important;
}
.nav__cta:hover{background:#b45309!important}

/* ═══════════════════════════════════════════════════
   PAGE HERO
═══════════════════════════════════════════════════ */
.page-hero{
  background:var(--ink);
  padding:calc(64px + 3.75rem) clamp(1.25rem,4vw,3rem) 4rem;
  position:relative;overflow:hidden;
}
.page-hero__bg{
  position:absolute;inset:0;pointer-events:none;opacity:.45;
  background-image:radial-gradient(rgba(56,189,248,.22) 1px,transparent 1px);
  background-size:40px 40px;
  animation:dotDrift 50s linear infinite;
}
@keyframes dotDrift{to{background-position:80px 80px}}

.page-hero__glow{
  position:absolute;right:-150px;top:-250px;
  width:700px;height:700px;pointer-events:none;
  background:radial-gradient(circle,rgba(13,110,66,.25) 0%,transparent 65%);
}
.page-hero__glow2{
  position:absolute;left:5%;bottom:-100px;
  width:450px;height:450px;pointer-events:none;
  background:radial-gradient(circle,rgba(56,189,248,.08) 0%,transparent 70%);
}
.page-hero__inner{position:relative;z-index:1;max-width:1100px;margin:0 auto}

.page-hero__eyebrow{
  display:inline-block;
  font-family:var(--mono);font-size:.75rem;font-weight:500;
  color:rgba(125,211,252,.85);text-transform:uppercase;letter-spacing:.15em;
  margin-bottom:.875rem;
  opacity:0;animation:fadeUp .5s .1s ease forwards;
}
.page-hero__title{
  font-family:var(--display);font-weight:800;font-style:italic;
  font-size:clamp(2.25rem,5.5vw,3.875rem);
  line-height:1.08;letter-spacing:-.015em;
  color:var(--white);margin-bottom:1.125rem;
  opacity:0;animation:fadeUp .55s .2s ease forwards;
}
.page-hero__title em{font-style:normal;color:var(--amber-2)}
.page-hero__sub{
  font-size:1.125rem;font-weight:300;
  color:rgba(255,255,255,.52);
  max-width:640px;line-height:1.9;
  opacity:0;animation:fadeUp .55s .3s ease forwards;
}

/* ═══════════════════════════════════════════════════
   BREADCRUMB
═══════════════════════════════════════════════════ */
.breadcrumb{
  background:var(--sky-200);
  border-bottom:1px solid var(--sky-300);
  padding:.8rem clamp(1.25rem,4vw,3rem);
}
.breadcrumb__inner{
  max-width:1100px;margin:0 auto;
  display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;
  font-family:var(--mono);font-size:.75rem;color:var(--muted);
}
.breadcrumb__inner a{color:var(--green);font-weight:500;text-decoration:none}
.breadcrumb__inner a:hover{text-decoration:underline}
.breadcrumb__sep{color:var(--sky-300);margin:0 .15rem}

/* ═══════════════════════════════════════════════════
   MAIN LAYOUT
═══════════════════════════════════════════════════ */
.main{padding:clamp(2.75rem,6vw,5.5rem) clamp(1.25rem,4vw,3rem);background:var(--sky-50)}
.wrap{max-width:1100px;margin:0 auto}
.content-grid{display:grid;grid-template-columns:1fr 272px;gap:3rem;align-items:start}

/* ═══════════════════════════════════════════════════
   SIDEBAR
═══════════════════════════════════════════════════ */
.sidebar{position:sticky;top:84px;display:flex;flex-direction:column;gap:1.25rem}

.sidebar-card{
  background:var(--sky-100);
  border:1.5px solid var(--sky-300);
  border-radius:14px;overflow:hidden;
  box-shadow:0 2px 16px rgba(56,189,248,.1);
}
.sidebar-card__head{
  background:var(--green);
  padding:1rem 1.125rem;
  font-family:var(--display);font-weight:700;font-size:1rem;
  color:var(--white);letter-spacing:.01em;
}
.sidebar-card__body{padding:.5rem 0}

.sidebar-link{
  display:flex;align-items:center;gap:.6rem;
  padding:.575rem 1.125rem;
  font-size:.9rem;font-weight:400;color:var(--ink-2);
  text-decoration:none;
  border-left:3px solid transparent;
  transition:background .15s,color .15s,border-color .15s;
}
.sidebar-link:hover{background:rgba(13,110,66,.07);color:var(--green);border-left-color:var(--green-2)}
.sidebar-link.active{background:rgba(13,110,66,.1);color:var(--green);border-left-color:var(--green);font-weight:600}
.sidebar-link__icon{font-size:.95rem;flex-shrink:0;width:20px;text-align:center}

.dl-card{
  background:var(--ink);border-radius:14px;padding:1.5rem;text-align:center;
  border:1px solid rgba(125,211,252,.08);
  box-shadow:0 4px 24px rgba(12,26,46,.25);
}
.dl-card__label{font-family:var(--mono);font-size:.68rem;color:rgba(255,255,255,.38);text-transform:uppercase;letter-spacing:.13em;margin-bottom:.5rem}
.dl-card__ver{font-family:var(--display);font-weight:800;font-style:italic;font-size:1.6rem;color:var(--white);margin-bottom:.25rem}
.dl-card__sub{font-family:var(--mono);font-size:.75rem;color:rgba(255,255,255,.38);margin-bottom:1.25rem;line-height:1.5}
.dl-card__btn{
  display:block;background:var(--amber);color:var(--white);
  font-family:var(--body);font-weight:700;font-size:.9375rem;
  padding:.75rem 1rem;border-radius:8px;text-decoration:none;
  transition:background .18s,transform .15s;
}
.dl-card__btn:hover{background:#b45309;transform:translateY(-1px)}

/* ═══════════════════════════════════════════════════
   ARTICLE TYPOGRAPHY
═══════════════════════════════════════════════════ */
.article h2{
  font-family:var(--display);font-weight:800;font-style:italic;
  font-size:clamp(1.6rem,3vw,2.2rem);
  letter-spacing:-.015em;line-height:1.15;
  color:var(--ink);
  margin:3rem 0 1.25rem;padding-bottom:.75rem;
  border-bottom:2px solid var(--sky-200);
}
.article h2:first-child{margin-top:0}

.article h3{
  font-family:var(--display);font-weight:700;
  font-size:1.25rem;color:var(--green);
  margin:2.25rem 0 .875rem;
}

.article p{
  font-size:1.0625rem;color:var(--muted);
  line-height:1.9;margin-bottom:1.125rem;font-weight:400;
}
.article p:last-child{margin-bottom:0}
.article strong{color:var(--ink);font-weight:600}
.article a{color:var(--green);font-weight:500;text-decoration:none}
.article a:hover{text-decoration:underline}

code{
  font-family:var(--mono);font-size:.82em;
  background:rgba(13,110,66,.1);color:var(--green);
  padding:.15em .45em;border-radius:5px;white-space:nowrap;
}

/* ═══════════════════════════════════════════════════
   CODE BLOCK
═══════════════════════════════════════════════════ */
.code-block{
  background:var(--ink);border-radius:12px;
  padding:1.5rem 1.75rem;margin:1.5rem 0;
  font-family:var(--mono);font-size:.9rem;
  color:#8dd5b8;line-height:1.9;
  border:1px solid rgba(125,211,252,.08);
  overflow-x:auto;
}
.code-block .kw{color:var(--amber-2);font-weight:500}
.code-block .cm{color:rgba(255,255,255,.3);font-style:italic}
.code-block .st{color:#fca5a5}

/* ═══════════════════════════════════════════════════
   DATA TABLE
═══════════════════════════════════════════════════ */
.data-table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:1rem;border-radius:10px;overflow:hidden;border:1.5px solid var(--sky-300)}
.data-table th{
  background:var(--green);color:var(--white);
  font-family:var(--body);font-weight:700;font-size:.9rem;
  padding:.75rem 1.1rem;text-align:left;letter-spacing:.02em;
}
.data-table td{padding:.65rem 1.1rem;border-bottom:1px solid var(--sky-200);color:var(--ink)}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:nth-child(even) td{background:var(--sky-100)}
.data-table tr:hover td{background:var(--green-3)}
.data-table .num{font-family:var(--mono);font-size:.9rem;color:var(--green);font-weight:500}

/* ═══════════════════════════════════════════════════
   CALLOUT BOXES
═══════════════════════════════════════════════════ */
.callout{
  border-radius:12px;padding:1.25rem 1.5rem;
  margin:1.5rem 0;display:flex;gap:1rem;align-items:flex-start;
}
.callout--info{background:var(--sky-100);border-left:4px solid var(--sky-400)}
.callout--tip{background:var(--green-3);border-left:4px solid var(--green-2)}
.callout--warn{background:#fef3c7;border-left:4px solid var(--amber)}
.callout__icon{font-size:1.2rem;flex-shrink:0;margin-top:.15rem}
.callout__body{font-size:1rem;color:var(--ink-2);line-height:1.85}
.callout__body strong{color:var(--ink);font-weight:600}
.callout__body a{color:var(--green);font-weight:500}

/* ═══════════════════════════════════════════════════
   STEPS
═══════════════════════════════════════════════════ */
.steps{display:flex;flex-direction:column;gap:1.125rem;margin:1.5rem 0}
.step{
  display:flex;gap:1.25rem;
  background:var(--sky-100);
  border:1.5px solid var(--sky-200);
  border-radius:12px;padding:1.375rem;
  box-shadow:0 2px 8px rgba(56,189,248,.07);
  transition:border-color .2s,box-shadow .2s;
}
.step:hover{border-color:var(--sky-300);box-shadow:0 4px 16px rgba(56,189,248,.12)}
.step__num{
  font-family:var(--display);font-weight:800;font-style:italic;
  font-size:1.75rem;color:var(--green);
  min-width:36px;line-height:1.1;flex-shrink:0;padding-top:.1rem;
}
.step__body h4{font-family:var(--body);font-weight:700;font-size:1.0625rem;color:var(--ink);margin-bottom:.4rem}
.step__body p{font-size:1rem;color:var(--muted);line-height:1.82;margin:0}

/* ═══════════════════════════════════════════════════
   UTILITY BADGE
═══════════════════════════════════════════════════ */
.u-badge{
  display:inline-block;
  background:rgba(217,119,6,.12);border:1px solid rgba(217,119,6,.35);
  color:var(--amber);font-family:var(--mono);font-size:.72rem;
  padding:.2rem .6rem;border-radius:5px;letter-spacing:.03em;
}

/* ═══════════════════════════════════════════════════
   FEEDBACK CARDS
═══════════════════════════════════════════════════ */
.feedback-card{
  background:var(--sky-100);
  border:1.5px solid var(--sky-200);
  border-radius:14px;
  padding:1.75rem 1.625rem 1.5rem;
  position:relative;
  transition:border-color .2s,box-shadow .2s,transform .2s;
  box-shadow:0 2px 12px rgba(56,189,248,.06);
}
.feedback-card:hover{
  border-color:var(--green-2);
  box-shadow:0 8px 28px rgba(13,110,66,.1);
  transform:translateY(-2px);
}
.feedback-card::before{
  content:'\201C';position:absolute;top:.25rem;left:1.125rem;
  font-family:var(--display);font-size:4rem;line-height:1;
  color:var(--sky-200);pointer-events:none;
}
.feedback-card__text{
  font-family:var(--display);font-style:italic;
  font-size:1.0625rem;color:var(--ink-2);line-height:1.85;
  margin-bottom:1rem;padding-left:.25rem;
}
.feedback-card__author{font-family:var(--body);font-size:.9375rem;font-weight:700;color:var(--green)}
.feedback-card__org{font-family:var(--mono);font-size:.78rem;color:var(--muted);margin-top:.2rem}

/* ═══════════════════════════════════════════════════
   LINK CARDS
═══════════════════════════════════════════════════ */
.link-card{
  display:flex;align-items:center;gap:1.25rem;
  border:1.5px solid var(--sky-200);border-radius:12px;
  padding:1.25rem 1.5rem;text-decoration:none;
  background:var(--sky-100);
  transition:border-color .2s,transform .2s,box-shadow .2s;
  margin-bottom:1rem;
  box-shadow:0 2px 8px rgba(56,189,248,.06);
}
.link-card:hover{
  border-color:var(--green-2);
  transform:translateX(5px);
  box-shadow:0 6px 24px rgba(13,110,66,.1);
}
.link-card__icon{font-size:1.75rem;flex-shrink:0}
.link-card__name{font-family:var(--body);font-weight:700;font-size:1.0625rem;color:var(--ink);margin-bottom:.25rem}
.link-card__desc{font-size:.9375rem;color:var(--muted);line-height:1.6}
.link-card__arrow{margin-left:auto;color:var(--green-2);font-size:1.3rem;flex-shrink:0}

/* ═══════════════════════════════════════════════════
   SCROLL REVEAL
═══════════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ═══════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════ */
.footer{
  background:var(--ink);
  padding:3.5rem clamp(1.25rem,4vw,3rem) 2rem;
  border-top:3px solid var(--green);
}
.footer__inner{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr;
  gap:3rem;margin-bottom:2.5rem;
}
.footer__brand p{font-size:.9375rem;color:rgba(255,255,255,.42);line-height:1.9;margin-top:.875rem;max-width:300px}
.footer__col h4{
  font-family:var(--body);font-weight:700;font-size:.8rem;
  color:rgba(255,255,255,.32);text-transform:uppercase;letter-spacing:.15em;margin-bottom:1rem;
}
.footer__col ul{list-style:none;display:flex;flex-direction:column;gap:.55rem}
.footer__col a{font-size:.9375rem;color:rgba(255,255,255,.52);text-decoration:none;transition:color .18s}
.footer__col a:hover{color:var(--amber-2)}
.footer__bottom{
  max-width:1100px;margin:0 auto;
  padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.07);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;
}
.footer__bottom p{font-family:var(--mono);font-size:.75rem;color:rgba(255,255,255,.28)}

/* ═══════════════════════════════════════════════════
   KEYFRAMES
═══════════════════════════════════════════════════ */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

/* ═══════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════ */
@media(max-width:960px){
  .content-grid{grid-template-columns:1fr}
  .sidebar{position:static}
  .footer__inner{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .nav__links{display:none}
  .footer__inner{grid-template-columns:1fr;gap:2rem}
  body{font-size:1rem}
  .page-hero__title{font-size:2rem}
}
