/* ═══════════════════════════════════════════════
   CalendarStates.com — Shared Stylesheet
   ═══════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --navy:    #0d1b2a;
  --navy-20: rgba(13,27,42,.2);
  --navy-12: rgba(13,27,42,.12);
  --navy-06: rgba(13,27,42,.06);
  --off:     #f7f8fc;
  --off2:    #eef0f7;
  --white:   #fff;
  --blue:    #1a56db;
  --blue-l:  #eff6ff;
  --blue-d:  #1648c0;
  --green:   #16a34a;
  --green-l: #f0fdf4;
  --amber:   #d97706;
  --amber-l: #fffbeb;
  --red:     #dc2626;
  --red-l:   #fef2f2;
  --purple:  #7c3aed;
  --purple-l:#f5f3ff;
  --teal:    #0891b2;
  --teal-l:  #ecfeff;
  --orange:  #f97316;
  --orange-l:#fff7ed;
  --slate:   #64748b;
  --sans:    'Sora', system-ui, sans-serif;
  --serif:   'Lora', Georgia, serif;
  --r:       10px;
  --sh:      0 2px 16px rgba(13,27,42,.08);
  --sh-lg:   0 8px 40px rgba(13,27,42,.14);
}

html { scroll-behavior: smooth; }
body {
  font-family: var(--sans);
  background: var(--off);
  color: var(--navy);
  line-height: 1.6;
  font-size: 15px;
  overflow-x: hidden;
}

/* ── NAV ── */
nav {
  position: sticky; top: 0; z-index: 300;
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--navy-12);
  height: 88px;
  display: flex; align-items: center; padding: 0 2rem;
}
.nav-in {
  max-width: 1300px; width: 100%; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
}
.nav-logo {
  display: flex; align-items: center;
  text-decoration: none; flex-shrink: 0;
}
.nav-logo-img {
  height: 76px; width: auto; display: block;
}
.nav-bc {
  display: flex; align-items: center; gap: .45rem;
  font-size: .79rem; color: var(--slate);
  flex: 1; justify-content: center; flex-wrap: wrap;
}
.nav-bc a { color: var(--slate); text-decoration: none; transition: color .15s; }
.nav-bc a:hover { color: var(--navy); }
.nav-bc .sep { color: var(--navy-20); font-size: .7rem; }
.nav-bc .cur { color: var(--navy); font-weight: 600; }

/* ── BUTTONS ── */
.btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: .5rem 1.1rem; border-radius: 7px;
  font-family: var(--sans); font-size: .8rem; font-weight: 600;
  text-decoration: none; cursor: pointer; border: none;
  transition: all .15s; white-space: nowrap; line-height: 1;
}
.btn svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 2; flex-shrink: 0; }
.btn-p  { background: var(--blue); color: #fff; }
.btn-p:hover { background: var(--blue-d); }
.btn-o  { background: transparent; color: var(--navy); border: 1.5px solid var(--navy-12); }
.btn-o:hover { border-color: var(--navy); background: var(--navy-06); }
.btn-sm { padding: .38rem .85rem; font-size: .74rem; }

/* ── TAGS ── */
.tag { display: inline-block; padding: .18rem .55rem; font-size: .63rem; font-weight: 700; border-radius: 4px; letter-spacing: .02em; white-space: nowrap; }
.t-h  { background: var(--red-l);    color: var(--red);    }
.t-b  { background: var(--blue-l);   color: var(--blue);   }
.t-e  { background: var(--green-l);  color: var(--green);  }
.t-s  { background: var(--purple-l); color: var(--purple); }
.t-pk { background: var(--orange-l); color: var(--orange); }
.t-cf { background: var(--teal-l);   color: var(--teal);   }
.t-er { background: var(--amber-l);  color: var(--amber);  }
.t-ev { background: var(--off2);     color: var(--slate);  }

/* ── SECTION EYEBROW + HEADINGS ── */
.ey  { font-size: .67rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--blue); margin-bottom: .4rem; }
.h2  { font-family: var(--serif); font-size: clamp(1.4rem,2.2vw,1.9rem); font-weight: 600; margin-bottom: .55rem; line-height: 1.25; }
.h2 em { font-style: italic; color: var(--blue); }
.pdesc { color: var(--slate); font-size: .87rem; line-height: 1.7; margin-bottom: 2rem; max-width: 580px; }

/* ── CARD ── */
.card {
  background: var(--white); border: 1px solid var(--navy-12);
  border-radius: var(--r); overflow: hidden;
  transition: box-shadow .15s, transform .15s;
}
.card:hover { box-shadow: var(--sh-lg); transform: translateY(-2px); }

/* ── FOOTER ── */
footer {
  background: var(--navy); color: rgba(255,255,255,.5);
  padding: 2.5rem 2rem; font-size: .78rem; text-align: center;
}
footer a { color: rgba(255,255,255,.6); text-decoration: none; }
footer a:hover { color: #fff; }
.footer-in { max-width: 1300px; margin: 0 auto; display: flex; flex-direction: column; gap: .75rem; align-items: center; }
.footer-logo-link { display: inline-block; text-decoration: none; }
.footer-logo-img { height: 96px; width: auto; display: block; background: #fff; border-radius: 10px; padding: 5px 12px; }
.footer-links { display: flex; gap: 1.5rem; flex-wrap: wrap; justify-content: center; }

/* ── PULSE ANIMATION ── */
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.4} }

/* ── DESKTOP NAV LINKS ── */
.desk-links {
  display: flex;
  align-items: center;
  gap: .05rem;
  flex: 1;
  justify-content: center;
}
.desk-links a {
  font-size: .76rem;
  font-weight: 500;
  color: var(--slate);
  text-decoration: none;
  padding: .38rem .62rem;
  border-radius: 6px;
  white-space: nowrap;
  transition: color .15s, background .15s;
}
.desk-links a:hover {
  color: var(--navy);
  background: var(--navy-06);
}
.nav-right {
  display: flex;
  align-items: center;
  gap: .65rem;
  flex-shrink: 0;
}

/* ── MOBILE TRIGGER (3 vertical bars) ── */
.nav-mob-trigger {
  display: none;
  align-items: center;
  justify-content: center;
  gap: 4px;
  width: 36px;
  height: 36px;
  padding: 0;
  border: none;
  background: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background .15s;
  flex-shrink: 0;
}
.nav-mob-trigger:hover { background: var(--navy-06); }
.nav-mob-trigger span {
  display: block;
  width: 3px;
  height: 18px;
  background: var(--navy);
  border-radius: 2px;
  transition: all .4s ease;
}
.nav-mob-trigger:hover span:first-of-type,
.nav-mob-trigger:hover span:last-of-type,
.nav-mob-trigger.active span:first-of-type,
.nav-mob-trigger.active span:last-of-type {
  transform: translateY(-5px);
  opacity: 0;
}
.nav-mob-trigger:hover span:nth-of-type(2),
.nav-mob-trigger.active span:nth-of-type(2) {
  transform: scaleY(1.2);
  transform-origin: center bottom;
}

/* ── MOBILE OVERLAY ── */
.nav-mob-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .45);
  z-index: 400;
  opacity: 0;
  transition: opacity .4s ease;
}
.nav-mob-overlay.open { opacity: 1; }

/* ── MOBILE SLIDE MENU ── */
.nav-mob-menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 280px;
  height: 100%;
  background: var(--navy);
  z-index: 500;
  padding: 4.5rem 2.5rem 2.5rem;
  transform: translateX(-100%);
  transition: transform .8s cubic-bezier(.785, .135, .15, .86);
  border-right: 1px solid rgba(255, 255, 255, .08);
  will-change: transform;
}
.nav-mob-menu.open { transform: translateX(0); }

.nav-mob-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: none;
  border: none;
  color: rgba(255, 255, 255, .45);
  font-size: 1.1rem;
  cursor: pointer;
  width: 34px;
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: all .2s;
}
.nav-mob-close:hover {
  background: rgba(255, 255, 255, .1);
  color: #fff;
}

.nav-mob-menu ul { list-style: none; }
.nav-mob-menu ul:hover li:not(:hover) a { color: rgba(249, 249, 237, .35); }
.nav-mob-menu ul li {
  overflow: hidden;
  padding: .65rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, .07);
}
.nav-mob-menu ul li:last-of-type { border-bottom: none; }
.nav-mob-menu ul li a {
  text-decoration: none;
  color: #f9f9ed;
  display: block;
  transition: color .2s;
}
.nav-mob-menu ul li p {
  font-family: var(--serif);
  font-size: 1.45rem;
  font-weight: 600;
  transform: translateY(calc(100% + 10px));
}

/* Staggered slide-up reveal */
.nav-mob-menu ul li:nth-of-type(1) p { transition: transform .6s cubic-bezier(.785, .135, .15, .86) .10s; }
.nav-mob-menu ul li:nth-of-type(2) p { transition: transform .6s cubic-bezier(.785, .135, .15, .86) .20s; }
.nav-mob-menu ul li:nth-of-type(3) p { transition: transform .6s cubic-bezier(.785, .135, .15, .86) .30s; }
.nav-mob-menu ul li:nth-of-type(4) p { transition: transform .6s cubic-bezier(.785, .135, .15, .86) .40s; }
.nav-mob-menu ul li:nth-of-type(5) p { transition: transform .6s cubic-bezier(.785, .135, .15, .86) .50s; }
.nav-mob-menu.open ul li p { transform: translateY(0); }

/* ── CENTER NAV GROUP ── */
.nav-center-links {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
}

/* ── CALENDARS LINK BUTTON ── */
.nav-cals-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: .44rem .85rem;
  border: 1.5px solid var(--navy-12);
  border-radius: 8px;
  background: none;
  font-family: var(--sans);
  font-size: .8rem;
  font-weight: 600;
  color: var(--navy);
  text-decoration: none;
  transition: border-color .15s, background .15s, color .15s;
  white-space: nowrap;
}
.nav-cals-link:hover {
  border-color: var(--blue);
  background: var(--blue-l);
  color: var(--blue);
}

/* ── TOOLS DROPDOWN ── */
.nav-tools-menu {
  position: relative;
  display: flex;
}
.nav-tools-trigger {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: .44rem .85rem;
  border: 1.5px solid var(--navy-12);
  border-radius: 8px;
  background: none;
  font-family: var(--sans);
  font-size: .8rem;
  font-weight: 600;
  color: var(--navy);
  cursor: pointer;
  transition: border-color .15s, background .15s, color .15s;
  white-space: nowrap;
}
.nav-tools-trigger:hover {
  border-color: var(--blue);
  background: var(--blue-l);
  color: var(--blue);
}
.nav-tools-arrow {
  transition: transform .2s ease;
  flex-shrink: 0;
}
.nav-tools-trigger[aria-expanded="true"] .nav-tools-arrow {
  transform: rotate(180deg);
}
.nav-tools-drop {
  position: absolute;
  top: calc(100% + 10px);
  left: 50%;
  transform: translateX(-50%);
  width: 300px;
  background: #fff;
  border: 1px solid var(--navy-12);
  border-radius: 12px;
  box-shadow: 0 12px 40px rgba(13,27,42,.14);
  padding: .5rem;
  z-index: 600;
  opacity: 0;
  pointer-events: none;
  transform: translateX(-50%) translateY(-6px);
  transition: opacity .18s ease, transform .18s ease;
}
.nav-tools-drop.open {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.nav-tools-drop-head {
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--slate);
  padding: .4rem .75rem .5rem;
  border-bottom: 1px solid var(--navy-06);
  margin-bottom: .35rem;
}
.nav-tools-item {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .65rem .75rem;
  border-radius: 8px;
  text-decoration: none;
  color: var(--navy);
  transition: background .13s;
  position: relative;
}
.nav-tools-item:hover {
  background: var(--off);
}
.nav-tools-item--maker {
  background: rgba(26, 86, 219, .04);
  border: 1px solid rgba(26, 86, 219, .1);
  margin-top: .35rem;
}
.nav-tools-item--maker:hover {
  background: var(--blue-l);
}
.nav-tools-ico {
  font-size: 1.3rem;
  flex-shrink: 0;
  width: 32px;
  text-align: center;
}
.nav-tools-text {
  display: flex;
  flex-direction: column;
  gap: 1px;
  flex: 1;
}
.nav-tools-name {
  font-size: .82rem;
  font-weight: 600;
  line-height: 1.3;
}
.nav-tools-desc {
  font-size: .71rem;
  color: var(--slate);
  line-height: 1.4;
}
.nav-tools-badge {
  font-size: .58rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  background: var(--blue);
  color: #fff;
  padding: .18rem .5rem;
  border-radius: 100px;
  flex-shrink: 0;
}

/* ── GENERATE CALENDAR BUTTON ── */
.btn-cal-gen {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: .5rem 1.1rem;
  border-radius: 8px;
  font-family: var(--sans);
  font-size: .78rem;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
  line-height: 1;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, #1a56db 0%, #6d28d9 100%);
  color: #fff;
  border: none;
  box-shadow: 0 2px 12px rgba(26, 86, 219, .35);
  transition: box-shadow .2s, transform .15s;
}
.btn-cal-gen::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, #6d28d9 0%, #1a56db 100%);
  opacity: 0;
  transition: opacity .3s ease;
}
.btn-cal-gen:hover {
  box-shadow: 0 4px 20px rgba(26, 86, 219, .5);
  transform: translateY(-1px);
}
.btn-cal-gen:hover::before { opacity: 1; }
.btn-cal-gen svg {
  position: relative;
  z-index: 1;
  flex-shrink: 0;
}
.btn-cal-gen span, .btn-cal-gen > * { position: relative; z-index: 1; }

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  .btn-cal-gen { display: none; }
}
@media (max-width: 768px) {
  nav { padding: 0 1rem; }
  .nav-bc { display: none; }
  .desk-links { display: none; }
  .nav-center-links { display: none; }
  .nav-mob-trigger { display: flex; }
}
