/*! Sayed Zyada Theme — Pre-built CSS (Tailwind + Custom) v1.0.0 */

/* ── Google Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400&family=Inter:wght@300;400;500;600;700&family=Cairo:wght@300;400;500;600;700;800&family=Amiri:ital,wght@0,400;0,700;1,400&display=swap');

/* ── CSS Reset & Base ── */
*,::before,::after{box-sizing:border-box;border-width:0;border-style:solid}
html{line-height:1.5;-webkit-text-size-adjust:100%;tab-size:4;font-family:Cairo,Tajawal,sans-serif;scroll-behavior:smooth}
body{margin:0;line-height:inherit}
h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit;font-family:'Playfair Display',Georgia,serif}
a{color:inherit;text-decoration:inherit}
img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}
img,video{max-width:100%;height:auto}
*{--tw-ring-inset:;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000}

/* ── CSS Variables ── */
:root {
  --sz-primary: #C4A882;
  --sz-secondary: #E55B2D;
  --sz-accent: #1A6B8A;
  --sz-dark: #0D0E12;
  --sz-light: #FAFAF8;
  --color-sand-50: #FAF7F2;
  --color-sand-100: #F5EFE4;
  --color-sand-200: #EBE0CC;
  --color-sand-300: #D4C4A0;
  --color-sand-400: #C4A882;
  --color-sand-500: #B08B5A;
  --color-sand-600: #8B6935;
  --color-sand-700: #6B4F1E;
  --color-sand-800: #4A350B;
  --color-dark: #0D0E12;
  --color-dark-2: #12141A;
  --color-dark-3: #1A1D25;
  --color-dark-4: #22263A;
  --color-sunset-500: #E55B2D;
  --color-ocean-500: #1A6B8A;
}

/* ── Dark Mode Variables ── */
.dark {
  color-scheme: dark;
}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--color-sand-100)}
::-webkit-scrollbar-thumb{background:var(--color-sand-400);border-radius:9999px}
.dark ::-webkit-scrollbar-track{background:var(--color-dark-3)}
.dark ::-webkit-scrollbar-thumb{background:#8B6935}

/* ── Selection ── */
::selection{background:rgba(196,168,130,.3)}

/* ── Body ── */
body{font-family:'Cairo','Tajawal',sans-serif;background:#FAFAF8;color:#0D0E12;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;direction:rtl}
.dark body,.dark{background:#0D0E12;color:#F5EFE4}

/* ============================================================
   LAYOUT UTILITIES
   ============================================================ */
.min-h-screen{min-height:100vh}
.flex{display:flex}
.inline-flex{display:inline-flex}
.grid{display:grid}
.block{display:block}
.inline-block{display:inline-block}
.hidden{display:none}
.relative{position:relative}
.absolute{position:absolute}
.fixed{position:fixed}
.sticky{position:sticky}
.top-0{top:0}
.bottom-0{bottom:0}
.start-0{inset-inline-start:0}
.end-0{inset-inline-end:0}
.inset-0{top:0;right:0;bottom:0;left:0}
.z-0{z-index:0}
.z-10{z-index:10}
.z-20{z-index:20}
.z-30{z-index:30}
.z-40{z-index:40}
.z-50{z-index:50}
.z-\[50\]{z-index:50}
.z-\[60\]{z-index:60}
.z-\[9999\]{z-index:9999}
.overflow-hidden{overflow:hidden}
.overflow-x-auto{overflow-x:auto}
.overflow-y-auto{overflow-y:auto}

/* ── Flexbox ── */
.flex-col{flex-direction:column}
.flex-row{flex-direction:row}
.flex-wrap{flex-wrap:wrap}
.flex-1{flex:1 1 0%}
.flex-shrink-0{flex-shrink:0}
.items-start{align-items:flex-start}
.items-center{align-items:center}
.items-end{align-items:flex-end}
.justify-start{justify-content:flex-start}
.justify-center{justify-content:center}
.justify-end{justify-content:flex-end}
.justify-between{justify-content:space-between}
.gap-1{gap:.25rem}
.gap-1\.5{gap:.375rem}
.gap-2{gap:.5rem}
.gap-3{gap:.75rem}
.gap-4{gap:1rem}
.gap-5{gap:1.25rem}
.gap-6{gap:1.5rem}
.gap-7{gap:1.75rem}
.gap-8{gap:2rem}
.gap-10{gap:2.5rem}
.gap-12{gap:3rem}
.gap-16{gap:4rem}

/* ── Grid ── */
.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}
.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}

/* ── Spacing ── */
.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}
.px-3{padding-inline:0.75rem}.px-4{padding-inline:1rem}.px-5{padding-inline:1.25rem}
.px-6{padding-inline:1.5rem}.px-7{padding-inline:1.75rem}.px-8{padding-inline:2rem}
.py-1{padding-block:.25rem}.py-1\.5{padding-block:.375rem}.py-2{padding-block:.5rem}
.py-2\.5{padding-block:.625rem}.py-3{padding-block:.75rem}.py-3\.5{padding-block:.875rem}
.py-4{padding-block:1rem}.py-5{padding-block:1.25rem}.py-6{padding-block:1.5rem}
.py-8{padding-block:2rem}.py-10{padding-block:2.5rem}.py-12{padding-block:3rem}
.py-16{padding-block:4rem}.py-20{padding-block:5rem}.py-24{padding-block:6rem}
.py-28{padding-block:7rem}.py-32{padding-block:8rem}.py-40{padding-block:10rem}
.pt-4{padding-top:1rem}.pt-5{padding-top:1.25rem}.pt-6{padding-top:1.5rem}
.pt-8{padding-top:2rem}.pt-12{padding-top:3rem}.pt-16{padding-top:4rem}
.pt-20{padding-top:5rem}.pt-24{padding-top:6rem}.pt-28{padding-top:7rem}.pt-32{padding-top:8rem}
.pb-2{padding-bottom:.5rem}.pb-6{padding-bottom:1.5rem}.pb-8{padding-bottom:2rem}
.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}
.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}
.mb-7{margin-bottom:1.75rem}.mb-8{margin-bottom:2rem}.mb-10{margin-bottom:2.5rem}
.mb-12{margin-bottom:3rem}.mb-14{margin-bottom:3.5rem}.mb-16{margin-bottom:4rem}
.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}
.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}
.mt-8{margin-top:2rem}.mt-10{margin-top:2.5rem}.mt-12{margin-top:3rem}
.mt-16{margin-top:4rem}.mt-auto{margin-top:auto}
.me-1{margin-inline-end:.25rem}.ms-1{margin-inline-start:.25rem}.ms-2{margin-inline-start:.5rem}.ms-4{margin-inline-start:1rem}.ms-6{margin-inline-start:1.5rem}
.mx-auto{margin-inline:auto}.mx-1{margin-inline:.25rem}
.ps-3{padding-inline-start:.75rem}.ps-4{padding-inline-start:1rem}.ps-6{padding-inline-start:1.5rem}.ps-7{padding-inline-start:1.75rem}
.pe-4{padding-inline-end:1rem}

/* ── Sizing ── */
.w-full{width:100%}.h-full{height:100%}
.w-1{width:.25rem}.h-0\.5{height:.125rem}.h-1{height:.25rem}.w-px{width:1px}.h-px{height:1px}
.w-7{width:1.75rem}.h-7{height:1.75rem}
.w-8{width:2rem}.h-8{height:2rem}
.w-9{width:2.25rem}.h-9{height:2.25rem}
.w-10{width:2.5rem}.h-10{height:2.5rem}
.w-12{width:3rem}.h-12{height:3rem}
.w-14{width:3.5rem}.h-14{height:3.5rem}
.w-16{width:4rem}.h-16{height:4rem}
.w-20{width:5rem}.h-20{height:5rem}
.w-24{width:6rem}.h-24{height:6rem}
.w-28{width:7rem}.h-28{height:7rem}
.w-48{width:12rem}.h-48{height:12rem}
.w-60{width:15rem}
.w-64{width:16rem}
.w-80{width:20rem}.h-80{height:20rem}
.min-w-0{min-width:0}
.max-w-sm{max-width:24rem}.max-w-md{max-width:28rem}.max-w-xl{max-width:36rem}
.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}
.max-w-none{max-width:none}
.max-w-8xl{max-width:88rem}
.h-0\.5{height:.125rem}.h-6{height:1.5rem}.h-18{height:4.5rem}.h-20{height:5rem}
.h-64{height:16rem}.h-80{height:20rem}.h-96{height:24rem}
.min-h-\[50vh\]{min-height:50vh}.min-h-\[65vh\]{min-height:65vh}
.min-h-\[75vh\]{min-height:75vh}.min-h-\[80vh\]{min-height:80vh}

/* ── Colors — Backgrounds ── */
.bg-white{background-color:#fff}
.bg-transparent{background-color:transparent}
.bg-sand-50{background-color:#FAF7F2}.bg-sand-100{background-color:#F5EFE4}
.bg-sand-400{background-color:#C4A882}.bg-sand-500{background-color:#B08B5A}
.bg-sand-600{background-color:#8B6935}
.bg-dark{background-color:#0D0E12}.bg-dark-2{background-color:#12141A}
.bg-dark-3{background-color:#1A1D25}.bg-dark-4{background-color:#22263A}
.bg-ocean-900{background-color:#041520}
.bg-gray-50{background-color:#F9FAFB}.bg-gray-100{background-color:#F3F4F6}
.dark .dark\:bg-dark{background-color:#0D0E12}
.dark .dark\:bg-dark-2{background-color:#12141A}
.dark .dark\:bg-dark-3{background-color:#1A1D25}

/* ── Colors — Text ── */
.text-white{color:#fff}.text-black{color:#000}
.text-dark{color:#0D0E12}
.text-sand-100{color:#F5EFE4}.text-sand-200{color:#EBE0CC}
.text-sand-300{color:#D4C4A0}.text-sand-400{color:#C4A882}
.text-sand-500{color:#B08B5A}.text-sand-600{color:#8B6935}
.text-sand-700{color:#6B4F1E}
.text-sunset-500{color:#E55B2D}
.text-gray-400{color:#9CA3AF}.text-gray-500{color:#6B7280}
.text-gray-600{color:#4B5563}.text-gray-700{color:#374151}
.dark .dark\:text-sand-100{color:#F5EFE4}
.dark .dark\:text-sand-200{color:#EBE0CC}
.dark .dark\:text-sand-300{color:#D4C4A0}
.dark .dark\:text-sand-400{color:#C4A882}
.dark .dark\:text-sand-500{color:#B08B5A}

/* ── Typography ── */
.font-heading{font-family:'Playfair Display',Georgia,serif}
.font-body{font-family:Inter,'Helvetica Neue',sans-serif}
.font-arabic{font-family:Amiri,'Noto Naskh Arabic',serif}
.font-arabic-ui{font-family:Cairo,Tajawal,sans-serif}
.text-xs{font-size:.75rem;line-height:1rem}
.text-sm{font-size:.875rem;line-height:1.25rem}
.text-base{font-size:1rem;line-height:1.5rem}
.text-lg{font-size:1.125rem;line-height:1.75rem}
.text-xl{font-size:1.25rem;line-height:1.75rem}
.text-2xl{font-size:1.5rem;line-height:2rem}
.text-3xl{font-size:1.875rem;line-height:2.25rem}
.text-4xl{font-size:2.25rem;line-height:2.5rem}
.text-5xl{font-size:3rem;line-height:1}
.text-6xl{font-size:3.75rem;line-height:1}
.text-7xl{font-size:4.5rem;line-height:1}
.text-8xl{font-size:6rem;line-height:1}
.font-light{font-weight:300}.font-normal{font-weight:400}
.font-medium{font-weight:500}.font-semibold{font-weight:600}
.font-bold{font-weight:700}.font-black{font-weight:900}
.leading-none{line-height:1}.leading-tight{line-height:1.25}
.leading-snug{line-height:1.375}.leading-normal{line-height:1.5}
.leading-relaxed{line-height:1.625}.leading-loose{line-height:2}
.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}
.tracking-widest{letter-spacing:.1em}.tracking-\[0\.3em\]{letter-spacing:.3em}
.uppercase{text-transform:uppercase}
.text-center{text-align:center}.text-start{text-align:start}.text-end{text-align:end}
.not-italic{font-style:normal}.italic{font-style:italic}
.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

/* ── Borders ── */
.rounded{border-radius:.25rem}.rounded-lg{border-radius:.5rem}
.rounded-xl{border-radius:.75rem}.rounded-2xl{border-radius:1rem}
.rounded-full{border-radius:9999px}
.rounded-e-xl{border-start-end-radius:.75rem;border-end-end-radius:.75rem}
.border{border-width:1px}.border-2{border-width:2px}.border-4{border-width:4px}
.border-t{border-top-width:1px}.border-b{border-bottom-width:1px}
.border-s{border-inline-start-width:1px}.border-s-2{border-inline-start-width:2px}
.border-s-4{border-inline-start-width:4px}
.border-transparent{border-color:transparent}
.border-white{border-color:#fff}
.border-gray-100{border-color:#F3F4F6}.border-gray-200{border-color:#E5E7EB}
.border-sand-100{border-color:#F5EFE4}.border-sand-200{border-color:#EBE0CC}
.border-sand-300{border-color:#D4C4A0}.border-sand-400{border-color:#C4A882}
.border-sand-600{border-color:#8B6935}
.dark .dark\:border-dark-4{border-color:#22263A}
.dark .dark\:border-sand-600{border-color:#8B6935}

/* ── Opacity ── */
.opacity-0{opacity:0}.opacity-100{opacity:1}
.opacity-5{opacity:.05}.opacity-10{opacity:.1}
.opacity-20{opacity:.2}.opacity-30{opacity:.3}.opacity-40{opacity:.4}.opacity-60{opacity:.6}

/* ── Shadow ── */
.shadow-sm{box-shadow:0 1px 2px 0 rgb(0 0 0/.05)}
.shadow-md{box-shadow:0 4px 6px -1px rgb(0 0 0/.1),0 2px 4px -2px rgb(0 0 0/.1)}
.shadow-lg{box-shadow:0 10px 15px -3px rgb(0 0 0/.1),0 4px 6px -4px rgb(0 0 0/.1)}
.shadow-xl{box-shadow:0 20px 25px -5px rgb(0 0 0/.1),0 8px 10px -6px rgb(0 0 0/.1)}
.shadow-2xl{box-shadow:0 25px 50px -12px rgb(0 0 0/.25)}

/* ── Background Utilities ── */
.bg-cover{background-size:cover}
.bg-center{background-position:center}
.bg-fixed{background-attachment:fixed}
.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--tw-gradient-stops))}
.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}
.bg-gradient-to-t{background-image:linear-gradient(to top,var(--tw-gradient-stops))}
.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}
.from-dark\/90{--tw-gradient-from:rgba(13,14,18,.9);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,rgb(13 14 18/0))}
.from-dark\/95{--tw-gradient-from:rgba(13,14,18,.95)}
.via-dark\/70{--tw-gradient-via:rgba(13,14,18,.7)}
.to-dark\/90{--tw-gradient-to:rgba(13,14,18,.9)}
.from-dark{--tw-gradient-from:#0D0E12;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,rgb(13 14 18/0))}
.via-dark-3{--tw-gradient-via:#1A1D25}
.to-dark-2{--tw-gradient-to:#12141A}
.to-ocean-900{--tw-gradient-to:#041520}

/* ── Background Sizes ── */
.bg-hero-overlay{background-image:linear-gradient(to bottom,rgba(13,14,18,.3) 0%,rgba(13,14,18,.7) 60%,rgba(13,14,18,.95) 100%)}
.bg-card-overlay{background-image:linear-gradient(to top,rgba(13,14,18,.9) 0%,rgba(13,14,18,.4) 50%,transparent 100%)}

/* ── Aspect Ratios ── */
.aspect-video{aspect-ratio:16/9}
.aspect-\[16\/9\]{aspect-ratio:16/9}
.aspect-\[4\/5\]{aspect-ratio:4/5}
.aspect-\[4\/3\]{aspect-ratio:4/3}
.aspect-\[3\/4\]{aspect-ratio:3/4}
.aspect-\[3\/2\]{aspect-ratio:3/2}
.aspect-\[21\/9\]{aspect-ratio:21/9}

/* ── Object Fit ── */
.object-cover{object-fit:cover}
.object-center{object-position:center}

/* ── Transitions ── */
.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.transition-colors{transition-property:color,background-color,border-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.duration-200{transition-duration:200ms}
.duration-300{transition-duration:300ms}
.duration-400{transition-duration:400ms}
.duration-500{transition-duration:500ms}
.duration-700{transition-duration:700ms}
.duration-1000{transition-duration:1000ms}
.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}

/* ── Transform ── */
.translate-y-0{transform:translateY(0)}
.translate-y-2{transform:translateY(.5rem)}
.translate-y-4{transform:translateY(1rem)}
.-translate-y-0\.5{transform:translateY(-.125rem)}
.-translate-y-1{transform:translateY(-.25rem)}
.-translate-y-full{transform:translateY(-100%)}
.-translate-x-1\/2{transform:translateX(-50%)}
.scale-105{transform:scale(1.05)}
.scale-110{transform:scale(1.1)}
.rotate-45{transform:rotate(45deg)}
.rotate-90{transform:rotate(90deg)}

/* ── Hover States ── */
.hover\:opacity-100:hover{opacity:1}
.hover\:scale-105:hover{transform:scale(1.05)}
.hover\:-translate-y-1:hover{transform:translateY(-.25rem)}
.hover\:-translate-y-0\.5:hover{transform:translateY(-.125rem)}
.hover\:shadow-xl:hover{box-shadow:0 20px 25px -5px rgb(0 0 0/.1),0 8px 10px -6px rgb(0 0 0/.1)}
.hover\:shadow-2xl:hover{box-shadow:0 25px 50px -12px rgb(0 0 0/.25)}
.hover\:bg-sand-400:hover{background-color:#C4A882}
.hover\:bg-sand-500:hover{background-color:#B08B5A}
.hover\:bg-sand-600:hover{background-color:#8B6935}
.hover\:text-white:hover{color:#fff}
.hover\:text-sand-200:hover{color:#EBE0CC}
.hover\:text-sand-300:hover{color:#D4C4A0}
.hover\:text-sand-500:hover{color:#B08B5A}
.hover\:text-sand-600:hover{color:#8B6935}
.hover\:border-sand-400:hover{border-color:#C4A882}
.hover\:bg-white\/10:hover{background-color:rgba(255,255,255,.1)}
.hover\:bg-white\/30:hover{background-color:rgba(255,255,255,.3)}

/* ── Backdrop Blur ── */
.backdrop-blur-sm{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.backdrop-blur-xl{backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}

/* ── Blur ── */
.blur-3xl{filter:blur(64px)}

/* ── Pointer Events ── */
.pointer-events-none{pointer-events:none}
.pointer-events-auto{pointer-events:auto}

/* ── Other Utilities ── */
.cursor-pointer{cursor:pointer}
.select-none{user-select:none}
.will-change-\[width\]{will-change:width}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}
.whitespace-nowrap{white-space:nowrap}
.list-none{list-style:none}

/* ── Line Clamp ── */
.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

/* ── Scrollbar Hide ── */
.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}
.scrollbar-hide::-webkit-scrollbar{display:none}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes fadeIn{0%{opacity:0}100%{opacity:1}}
@keyframes fadeUp{0%{opacity:0;transform:translateY(30px)}100%{opacity:1;transform:translateY(0)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes slideInLeft{0%{opacity:0;transform:translateX(40px)}100%{opacity:1;transform:translateX(0)}}
@keyframes slideInRight{0%{opacity:0;transform:translateX(-40px)}100%{opacity:1;transform:translateX(0)}}
@keyframes spin{to{transform:rotate(360deg)}}

.animate-fade-in{animation:fadeIn .6s ease-out forwards}
.animate-fade-up{animation:fadeUp .7s ease-out forwards}
.animate-float{animation:float 6s ease-in-out infinite}
.animate-pulse-slow{animation:pulse 3s cubic-bezier(.4,0,.6,1) infinite}
.animate-spin{animation:spin 1s linear infinite}

.sz-fade-in{opacity:0;animation:fadeIn .6s ease-out forwards}
.sz-fade-up{opacity:0;animation:fadeUp .7s ease-out forwards}

/* ============================================================
   HEADER COMPONENT
   ============================================================ */
#site-header {
  transition: transform .5s cubic-bezier(.4,0,.2,1), box-shadow .3s ease;
}

#header-inner {
  border-bottom: 1px solid transparent;
  transition: all .4s ease;
}

#site-header.scrolled #header-inner {
  background: rgba(255,255,255,.95);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom-color: rgba(0,0,0,.08);
  box-shadow: 0 4px 24px rgba(0,0,0,.08);
}

.dark #site-header.scrolled #header-inner {
  background: rgba(13,14,18,.95);
  border-bottom-color: rgba(196,168,130,.1);
}

.h-18{height:4.5rem}
.h-20{height:5rem}
.lg\:h-20{height:5rem}

/* Nav Links */
.sz-nav-link {
  position: relative;
  padding: .5rem 1rem;
  font-size: .875rem;
  font-weight: 500;
  color: rgba(255,255,255,.9);
  border-radius: .5rem;
  transition: color .2s, background .2s;
}

.sz-nav-link:hover {
  color: #fff;
  background: rgba(255,255,255,.1);
}

.scrolled .sz-nav-link {
  color: #0D0E12;
}

.dark .scrolled .sz-nav-link {
  color: #EBE0CC;
}

.scrolled .sz-nav-link:hover {
  color: #8B6935;
  background: #FAF7F2;
}

.sz-nav-link.active::after {
  content: '';
  position: absolute;
  bottom: 0;
  inset-inline-start: 50%;
  transform: translateX(-50%);
  width: 4px;
  height: 4px;
  border-radius: 9999px;
  background: #C4A882;
}

/* Icon Button */
.sz-icon-btn {
  padding: .5rem;
  border-radius: .5rem;
  transition: all .2s;
  color: rgba(255,255,255,.9);
}

.sz-icon-btn:hover {
  color: #fff;
  background: rgba(255,255,255,.1);
}

.scrolled .sz-icon-btn {
  color: #0D0E12;
}

.dark .scrolled .sz-icon-btn {
  color: #EBE0CC;
}

.scrolled .sz-icon-btn:hover {
  background: #F3F4F6;
}

.dark .scrolled .sz-icon-btn:hover {
  background: #1A1D25;
}

/* Reading Progress */
#reading-progress {
  will-change: width;
  height: 3px;
}

/* Scroll Top */
#scroll-top {
  transition: opacity .3s, transform .3s;
}

#scroll-top.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* ============================================================
   HERO SECTION
   ============================================================ */
.sz-hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sz-slide {
  transition: opacity 1s ease;
}

.sz-slide-dot {
  border-radius: 9999px;
  transition: all .3s ease;
  border: none;
  cursor: pointer;
}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.sz-reveal-left,
.sz-reveal-right,
.sz-reveal-up {
  opacity: 0;
  transition: opacity .7s ease, transform .7s ease;
}

.sz-reveal-left  { transform: translateX(40px); }
.sz-reveal-right { transform: translateX(-40px); }
.sz-reveal-up    { transform: translateY(30px); }

.sz-reveal-left.revealed,
.sz-reveal-right.revealed,
.sz-reveal-up.revealed {
  opacity: 1;
  transform: translate(0);
}

/* ============================================================
   SEARCH OVERLAY
   ============================================================ */
#search-overlay {
  display: none;
}

#search-overlay.flex {
  display: flex;
}

.sz-search-input {
  width: 100%;
  padding: 1rem 1.5rem;
  font-size: 1.125rem;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.2);
  color: #fff;
  border-radius: .75rem;
  backdrop-filter: blur(4px);
  outline: none;
  transition: border-color .2s, background .2s;
  font-family: inherit;
}

.sz-search-input::placeholder { color: rgba(255,255,255,.5); }
.sz-search-input:focus { border-color: #C4A882; background: rgba(255,255,255,.2); }

.sz-search-btn {
  padding: 1rem;
  background: #B08B5A;
  color: #fff;
  border-radius: .75rem;
  border: none;
  cursor: pointer;
  transition: background .2s;
  flex-shrink: 0;
}

.sz-search-btn:hover { background: #C4A882; }

.sz-search-form {
  display: flex;
  align-items: center;
  gap: .5rem;
}

/* ============================================================
   CATEGORY FILTER BAR
   ============================================================ */
.sz-filter-btn {
  white-space: nowrap;
  padding: .5rem 1rem;
  border-radius: 9999px;
  font-size: .875rem;
  font-weight: 500;
  transition: all .2s;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}

/* ============================================================
   ARTICLE CARDS
   ============================================================ */
.sz-article-card {
  background: #fff;
  border-radius: 1rem;
  overflow: hidden;
  border: 1px solid #F3F4F6;
  box-shadow: 0 1px 2px rgba(0,0,0,.05);
  transition: box-shadow .4s, transform .4s;
  display: flex;
  flex-direction: column;
}

.sz-article-card:hover {
  box-shadow: 0 25px 50px rgba(0,0,0,.15);
  transform: translateY(-4px);
}

.dark .sz-article-card {
  background: #1A1D25;
  border-color: #22263A;
}

/* ============================================================
   DESTINATION CARDS
   ============================================================ */
.sz-dest-card {
  border-radius: 1rem;
  overflow: hidden;
  background: #0D0E12;
  box-shadow: 0 4px 20px rgba(0,0,0,.15);
  transition: box-shadow .5s, transform .5s;
}

.sz-dest-card:hover {
  box-shadow: 0 25px 60px rgba(0,0,0,.3);
}

/* ============================================================
   PAGINATION
   ============================================================ */
.sz-page-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: .75rem;
  font-size: .875rem;
  font-weight: 500;
  background: #fff;
  border: 1px solid #E5E7EB;
  color: #4B5563;
  transition: all .2s;
  text-decoration: none;
}

.sz-page-btn:hover {
  border-color: #C4A882;
  color: #8B6935;
}

.dark .sz-page-btn {
  background: #1A1D25;
  border-color: #22263A;
  color: #C4A882;
}

.sz-page-current {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: .75rem;
  font-size: .875rem;
  font-weight: 700;
  background: #B08B5A;
  color: #fff;
  box-shadow: 0 4px 6px rgba(176,139,90,.3);
}

.sz-page-arrow {
  color: #B08B5A;
}

.sz-page-dots {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  color: #9CA3AF;
}

/* ============================================================
   POST CONTENT (Prose)
   ============================================================ */
.sz-post-content {
  font-family: 'Cairo', sans-serif;
  font-size: 1.125rem;
  line-height: 1.8;
  color: #374151;
  max-width: 72ch;
}

.dark .sz-post-content { color: #D4C4A0; }

.sz-post-content h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.75rem;
  font-weight: 700;
  color: #0D0E12;
  margin-top: 3rem;
  margin-bottom: 1.25rem;
  line-height: 1.3;
}

.dark .sz-post-content h2 { color: #F5EFE4; }

.sz-post-content h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.375rem;
  font-weight: 600;
  color: #0D0E12;
  margin-top: 2rem;
  margin-bottom: 1rem;
}

.dark .sz-post-content h3 { color: #EBE0CC; }

.sz-post-content p {
  margin-bottom: 1.5rem;
}

.sz-post-content a {
  color: #8B6935;
  text-decoration: underline;
  text-decoration-color: #D4C4A0;
  text-underline-offset: 2px;
  transition: color .2s;
}

.sz-post-content a:hover { color: #B08B5A; }

.sz-post-content blockquote {
  border-inline-start: 4px solid #C4A882;
  padding: 1rem 1.5rem;
  margin: 2rem 0;
  background: #FAF7F2;
  border-start-end-radius: .75rem;
  border-end-end-radius: .75rem;
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-size: 1.2rem;
  color: #6B4F1E;
}

.dark .sz-post-content blockquote {
  background: #1A1D25;
  color: #D4C4A0;
}

.sz-post-content img {
  border-radius: 1rem;
  box-shadow: 0 20px 60px rgba(0,0,0,.15);
  margin: 2rem 0;
  width: 100%;
}

.sz-post-content ul,.sz-post-content ol {
  margin-inline-start: 1.5rem;
  margin-bottom: 1.5rem;
}

.sz-post-content li { margin-bottom: .5rem; }

/* ============================================================
   TOC
   ============================================================ */
#sz-toc-list a {
  display: block;
  padding: .375rem .75rem;
  font-size: .875rem;
  color: #6B7280;
  border-inline-start: 2px solid transparent;
  text-decoration: none;
  transition: all .2s;
}

#sz-toc-list a:hover,
#sz-toc-list a.active {
  color: #8B6935;
  border-inline-start-color: #C4A882;
  font-weight: 500;
}

.dark #sz-toc-list a { color: #C4A882; }
.dark #sz-toc-list a:hover, .dark #sz-toc-list a.active { color: #D4C4A0; }

/* ============================================================
   MOBILE MENU
   ============================================================ */
#mobile-menu {
  z-index: 40;
}

#mobile-menu .menu-item a {
  display: flex;
  align-items: center;
  padding: 1rem;
  font-size: 1.125rem;
  font-weight: 500;
  color: #EBE0CC;
  border-radius: .75rem;
  transition: all .2s;
  text-decoration: none;
  border-bottom: 1px solid rgba(34,38,58,.5);
}

#mobile-menu .menu-item a:hover {
  color: #fff;
  background: #1A1D25;
}

#mobile-menu .current-menu-item a { color: #C4A882; }

/* ============================================================
   BUTTONS
   ============================================================ */
.sz-btn-primary {
  padding: .875rem 1.75rem;
  background: #B08B5A;
  color: #fff;
  font-weight: 600;
  border-radius: 9999px;
  transition: all .3s;
  box-shadow: 0 10px 25px rgba(176,139,90,.3);
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  text-decoration: none;
  border: none;
  cursor: pointer;
}

.sz-btn-primary:hover {
  background: #C4A882;
  box-shadow: 0 15px 35px rgba(176,139,90,.4);
  transform: translateY(-2px);
}

.sz-btn-outline {
  padding: .875rem 1.75rem;
  border: 2px solid #C4A882;
  color: #8B6935;
  font-weight: 600;
  border-radius: 9999px;
  transition: all .3s;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  text-decoration: none;
  background: transparent;
  cursor: pointer;
}

.sz-btn-outline:hover {
  background: #C4A882;
  color: #fff;
}

.dark .sz-btn-outline {
  color: #C4A882;
  border-color: #8B6935;
}

.dark .sz-btn-outline:hover {
  background: #8B6935;
  color: #fff;
}

/* ============================================================
   GLASS EFFECT
   ============================================================ */
.glass {
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.12);
}

.glass-dark {
  background: rgba(13,14,18,.7);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(196,168,130,.1);
}

/* ============================================================
   FOOTER
   ============================================================ */
#site-footer a {
  transition: color .2s;
  text-decoration: none;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (min-width: 640px) {
  .sm\:text-center{text-align:center}
  .sm\:flex{display:flex}
  .sm\:flex-row{flex-direction:row}
  .sm\:items-center{align-items:center}
  .sm\:col-span-2{grid-column:span 2}
  .sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .sm\:text-xl{font-size:1.25rem;line-height:1.75rem}
  .sm\:text-2xl{font-size:1.5rem;line-height:2rem}
  .sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}
  .sm\:text-4xl{font-size:2.25rem;line-height:2.5rem}
  .sm\:text-5xl{font-size:3rem;line-height:1}
  .sm\:px-6{padding-inline:1.5rem}
  .sm\:gap-4{gap:1rem}
  .sm\:col-span-1{grid-column:span 1}
  .sm\:h-80{height:20rem}
  .sm\:aspect-\[21\/9\]{aspect-ratio:21/9}
}

@media (min-width: 768px) {
  .md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .md\:col-span-2{grid-column:span 2}
  .md\:flex-row{flex-direction:row}
  .md\:items-center{align-items:center}
  .md\:text-xl{font-size:1.25rem}
}

@media (min-width: 1024px) {
  .lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .lg\:grid-cols-\[1fr_300px\]{grid-template-columns:1fr 300px}
  .lg\:col-span-2{grid-column:span 2}
  .lg\:flex{display:flex}
  .lg\:hidden{display:none}
  .lg\:block{display:block}
  .lg\:px-8{padding-inline:2rem}
  .lg\:py-16{padding-block:4rem}
  .lg\:py-20{padding-block:5rem}
  .lg\:py-28{padding-block:7rem}
  .lg\:py-32{padding-block:8rem}
  .lg\:py-40{padding-block:10rem}
  .lg\:gap-16{gap:4rem}
  .lg\:gap-20{gap:5rem}
  .lg\:text-4xl{font-size:2.25rem;line-height:2.5rem}
  .lg\:text-5xl{font-size:3rem;line-height:1}
  .lg\:text-6xl{font-size:3.75rem;line-height:1}
  .lg\:text-7xl{font-size:4.5rem;line-height:1}
  .lg\:order-1{order:1}
  .lg\:order-2{order:2}
  .lg\:col-span-1{grid-column:span 1}
  .lg\:mt-16{margin-top:4rem}
  .lg\:h-96{height:24rem}
  .lg\:min-h-\[75vh\]{min-height:75vh}
  .lg\:sticky{position:sticky}
  .top-28{top:7rem}
}

@media (min-width: 1280px) {
  .xl\:grid-cols-\[1fr_320px\]{grid-template-columns:1fr 320px}
  .xl\:text-8xl{font-size:6rem;line-height:1}
  .xl\:text-5xl{font-size:3rem;line-height:1}
  .xl\:col-span-2{grid-column:span 2}
}

/* ── Hidden helpers ── */
@media (max-width: 1023px) {
  .lg\:hidden { display: none; }
}

/* ============================================================
   PRINT
   ============================================================ */
@media print {
  #site-header,#site-footer,#reading-progress,#scroll-top,
  .sz-share-buttons,[id="related-articles"] { display: none !important; }
  body { font-size: 12pt; color: #000; background: #fff; }
}
