/*
Theme Name:  Little Morni
Theme URI:   https://littlemorni.com
Author:      Little Morni Family Resort
Description: Custom theme for Little Morni Boutique Resort, Morni Hills. Quiet Luxury aesthetic — no dependencies, no page builders.
Version:     1.0.0
License:     GNU General Public License v2 or later
Text Domain: littlemorni
*/

/* ============================================================
   1. GOOGLE FONTS IMPORT
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:wght@400&family=Manrope:wght@300;400;600&display=swap');


/* ============================================================
   2. DESIGN TOKENS — CSS CUSTOM PROPERTIES
   ============================================================ */
:root {

  /* --- Color Palette: Earth-derived Opulence --- */

  /* Primary — Midnight Emerald */
  --color-primary:                #000f0a;
  --color-on-primary:             #ffffff;
  --color-primary-container:      #122620;
  --color-on-primary-container:   #798e86;
  --color-primary-fixed:          #d1e8de;
  --color-primary-fixed-dim:      #b5ccc2;
  --color-on-primary-fixed:       #0b1f19;
  --color-on-primary-fixed-var:   #374b44;
  --color-inverse-primary:        #b5ccc2;

  /* Secondary — Burnished Bronze */
  --color-secondary:              #735c00;
  --color-on-secondary:           #ffffff;
  --color-secondary-container:    #fed65b;
  --color-on-secondary-container: #745c00;
  --color-secondary-fixed:        #ffe088;
  --color-secondary-fixed-dim:    #e9c349;
  --color-on-secondary-fixed:     #241a00;
  --color-on-secondary-fixed-var: #574500;

  /* Tertiary — Champagne / Sand */
  --color-tertiary:               #0b0c09;
  --color-on-tertiary:            #ffffff;
  --color-tertiary-container:     #22221f;
  --color-on-tertiary-container:  #8b8985;
  --color-tertiary-fixed:         #e5e2dd;
  --color-tertiary-fixed-dim:     #c9c6c2;
  --color-on-tertiary-fixed:      #1c1c19;
  --color-on-tertiary-fixed-var:  #474743;

  /* Surfaces */
  --color-background:             #fff8f0;
  --color-on-background:          #1f1b12;
  --color-surface:                #fff8f0;
  --color-surface-dim:            #e1d9cb;
  --color-surface-bright:         #fff8f0;
  --color-surface-variant:        #eae1d3;
  --color-on-surface:             #1f1b12;
  --color-on-surface-variant:     #424845;
  --color-surface-tint:           #4e635b;

  /* Surface containers (tonal layers) */
  --color-surface-lowest:         #ffffff;
  --color-surface-low:            #fbf3e4;
  --color-surface-container:      #f6edde;
  --color-surface-high:           #f0e7d9;
  --color-surface-highest:        #eae1d3;

  /* Inverse */
  --color-inverse-surface:        #343026;
  --color-inverse-on-surface:     #f9f0e1;

  /* Outlines */
  --color-outline:                #727875;
  --color-outline-variant:        #c2c8c4;

  /* Error */
  --color-error:                  #ba1a1a;
  --color-on-error:               #ffffff;
  --color-error-container:        #ffdad6;
  --color-on-error-container:     #93000a;


  /* --- Typography Scale --- */

  --font-serif:   'EB Garamond', Georgia, serif;
  --font-sans:    'Manrope', system-ui, sans-serif;

  /* Display — hero headlines */
  --fs-display:         64px;
  --fw-display:         400;
  --lh-display:         1.1;
  --ls-display:         -0.02em;

  /* Display — mobile */
  --fs-display-mobile:  40px;
  --lh-display-mobile:  1.2;
  --ls-display-mobile:  -0.01em;

  /* Headline medium */
  --fs-headline-md:     32px;
  --lh-headline-md:     1.3;

  /* Headline small */
  --fs-headline-sm:     24px;
  --lh-headline-sm:     1.4;

  /* Body large */
  --fs-body-lg:         18px;
  --fw-body-lg:         300;
  --lh-body-lg:         1.6;
  --ls-body-lg:         0.01em;

  /* Body medium */
  --fs-body-md:         16px;
  --fw-body-md:         400;
  --lh-body-md:         1.6;

  /* Label caps — nav, overlines, tags */
  --fs-label:           12px;
  --fw-label:           600;
  --lh-label:           1.0;
  --ls-label:           0.15em;


  /* --- Border Radius --- */

  --radius-sm:    0.125rem;
  --radius:       0.25rem;
  --radius-md:    0.375rem;
  --radius-lg:    0.5rem;
  --radius-xl:    0.75rem;
  --radius-full:  9999px;


  /* --- Spacing System (8px base unit) --- */

  --space-1:          8px;
  --space-2:          16px;
  --space-3:          24px;
  --space-4:          32px;
  --space-5:          40px;
  --space-6:          48px;
  --space-8:          64px;
  --space-10:         80px;
  --space-12:         96px;
  --space-15:         120px;

  --container-max:    1440px;
  --gutter:           32px;
  --margin-desktop:   80px;
  --margin-mobile:    24px;
  --section-padding:  120px;


  /* --- Shadows — Ambient, Emerald-tinted --- */

  --shadow-xs:  0 1px 4px rgba(0, 15, 10, 0.05);
  --shadow-sm:  0 2px 8px rgba(0, 15, 10, 0.06);
  --shadow-md:  0 4px 20px rgba(0, 15, 10, 0.07);
  --shadow-lg:  0 8px 40px rgba(0, 15, 10, 0.08);


  /* --- Transitions --- */

  --transition-fast:    150ms ease;
  --transition-base:    250ms ease;
  --transition-slow:    400ms ease;
  --transition-enter:   600ms cubic-bezier(0.16, 1, 0.3, 1);
}


/* ============================================================
   3. RESET & BASE
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-sans);
  font-size: var(--fs-body-md);
  font-weight: var(--fw-body-md);
  line-height: var(--lh-body-md);
  color: var(--color-on-background);
  background-color: var(--color-background);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, video, svg {
  display: block;
  max-width: 100%;
  height: auto;
}

a {
  color: inherit;
  text-decoration: none;
}

ul, ol {
  list-style: none;
}

button, input, select, textarea {
  font: inherit;
  color: inherit;
  background: none;
  border: none;
  outline: none;
}

button { cursor: pointer; }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-serif);
  font-weight: 400;
  color: var(--color-on-surface);
}


/* ============================================================
   4. TYPOGRAPHY UTILITY CLASSES
   ============================================================ */

.type-display {
  font-family: var(--font-serif);
  font-size: var(--fs-display);
  font-weight: var(--fw-display);
  line-height: var(--lh-display);
  letter-spacing: var(--ls-display);
}

.type-headline-md {
  font-family: var(--font-serif);
  font-size: var(--fs-headline-md);
  font-weight: 400;
  line-height: var(--lh-headline-md);
}

.type-headline-sm {
  font-family: var(--font-serif);
  font-size: var(--fs-headline-sm);
  font-weight: 400;
  line-height: var(--lh-headline-sm);
}

.type-body-lg {
  font-family: var(--font-sans);
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-body-lg);
  line-height: var(--lh-body-lg);
  letter-spacing: var(--ls-body-lg);
}

.type-body-md {
  font-family: var(--font-sans);
  font-size: var(--fs-body-md);
  font-weight: var(--fw-body-md);
  line-height: var(--lh-body-md);
}

.type-label {
  font-family: var(--font-sans);
  font-size: var(--fs-label);
  font-weight: var(--fw-label);
  line-height: var(--lh-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
}


/* ============================================================
   5. LAYOUT UTILITIES
   ============================================================ */

.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--margin-desktop);
}

.section {
  padding-block: var(--section-padding);
}

.grid-12 {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--gutter);
}


/* ============================================================
   6. BUTTON COMPONENTS
   ============================================================ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 14px 32px;
  border-radius: var(--radius);
  font-family: var(--font-sans);
  font-size: var(--fs-label);
  font-weight: var(--fw-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  transition:
    background-color var(--transition-base),
    color var(--transition-base),
    border-color var(--transition-base),
    box-shadow var(--transition-base);
  white-space: nowrap;
}

/* Primary — Midnight Emerald fill */
.btn-primary {
  background-color: var(--color-primary);
  color: var(--color-on-primary);
  border: 1px solid var(--color-primary);
}

.btn-primary:hover {
  background-color: var(--color-primary-container);
  border-color: var(--color-primary-container);
  box-shadow: var(--shadow-md);
}

/* Secondary — ghost with Bronze border */
.btn-secondary {
  background-color: transparent;
  color: var(--color-secondary);
  border: 1px solid var(--color-secondary);
}

.btn-secondary:hover {
  background-color: var(--color-secondary-container);
  color: var(--color-on-secondary-container);
}

/* Light ghost — for use on dark/image backgrounds */
.btn-ghost-light {
  background-color: transparent;
  color: var(--color-on-primary);
  border: 1px solid rgba(255, 255, 255, 0.5);
}

.btn-ghost-light:hover {
  background-color: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.8);
}


/* ============================================================
   7. NAVIGATION
   ============================================================ */

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  padding-block: var(--space-3);
  transition:
    background-color var(--transition-slow),
    backdrop-filter var(--transition-slow),
    box-shadow var(--transition-slow);
}

/* Scrolled state — applied via JS */
.site-header.scrolled {
  background-color: rgba(255, 248, 240, 0.88);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: var(--shadow-sm);
}

.site-header__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  padding-block: var(--space-3);
}

/* SVG logo — centered, constrained height */
.site-logo {
  display: block;
  text-align: center;
}

.site-logo__img {
  height: 56px;
  width: auto;
  display: block;
  /* White on hero, darkens on scroll */
  filter: brightness(0) invert(1);
  transition: filter var(--transition-base);
}

.site-header.scrolled .site-logo__img {
  filter: none; /* show natural SVG colours on frosted nav */
}

/* Fallback text logo */
.site-logo:not(:has(.site-logo__img)) {
  font-family: var(--font-serif);
  font-size: 20px;
  letter-spacing: 0.04em;
  color: var(--color-on-primary);
  transition: color var(--transition-base);
}

.site-header.scrolled .site-logo:not(:has(.site-logo__img)) {
  color: var(--color-primary);
}

/* Nav row — centred below logo */
.site-nav {
  display: flex;
  align-items: center;
  gap: var(--space-5);
}

.site-nav__link {
  font-family: var(--font-sans);
  font-size: var(--fs-label);
  font-weight: var(--fw-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.85);
  position: relative;
  padding-bottom: 3px;
  transition: color var(--transition-base);
}

/* Bronze underline on hover/active */
.site-nav__link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 1px;
  background-color: var(--color-secondary-fixed-dim);
  transition: width var(--transition-base);
}

.site-nav__link:hover::after,
.site-nav__link.active::after {
  width: 100%;
}

.site-header.scrolled .site-nav__link {
  color: var(--color-on-surface-variant);
}

.site-header.scrolled .site-nav__link::after {
  background-color: var(--color-secondary);
}

.site-nav__cta {
  margin-left: var(--space-3);
}

/* Mobile hamburger */
.site-nav__toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: var(--space-1);
  cursor: pointer;
  background: none;
  border: none;
}

.site-nav__toggle span {
  display: block;
  width: 24px;
  height: 1.5px;
  background-color: var(--color-on-primary);
  transition: transform var(--transition-base), opacity var(--transition-base);
}

.site-header.scrolled .site-nav__toggle span {
  background-color: var(--color-primary);
}


/* ============================================================
   8. CARD COMPONENTS
   ============================================================ */

.card {
  background-color: var(--color-surface-low);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-xs);
  transition: box-shadow var(--transition-base);
}

.card:hover {
  box-shadow: var(--shadow-md);
}

.card__image {
  overflow: hidden;
  aspect-ratio: 4 / 3;
}

.card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.card:hover .card__image img {
  transform: scale(1.04);
}

.card__body {
  padding: var(--space-4);
}

.card__overline {
  font-family: var(--font-sans);
  font-size: var(--fs-label);
  font-weight: var(--fw-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--color-secondary);
  margin-bottom: var(--space-1);
}

.card__title {
  font-family: var(--font-serif);
  font-size: var(--fs-headline-sm);
  line-height: var(--lh-headline-sm);
  color: var(--color-on-surface);
  margin-bottom: var(--space-2);
}

.card__description {
  font-size: var(--fs-body-md);
  color: var(--color-on-surface-variant);
  line-height: var(--lh-body-md);
}


/* ============================================================
   9. BOOKING WIDGET
   ============================================================ */

.booking-widget {
  background-color: var(--color-surface-low);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-5);
  box-shadow: var(--shadow-lg);
  display: flex;
  align-items: flex-end;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.booking-widget__field {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  flex: 1;
  min-width: 140px;
}

.booking-widget__label {
  font-family: var(--font-sans);
  font-size: var(--fs-label);
  font-weight: var(--fw-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--color-secondary);
}

.booking-widget__input {
  font-family: var(--font-serif);
  font-size: var(--fs-headline-sm);
  color: var(--color-on-surface);
  background: transparent;
  border-bottom: 1px solid var(--color-outline-variant);
  padding-bottom: var(--space-1);
  transition: border-color var(--transition-base);
  width: 100%;
}

.booking-widget__input:focus {
  border-color: var(--color-secondary);
  outline: none;
}

.booking-widget__input::placeholder {
  color: var(--color-on-surface-variant);
  font-family: var(--font-serif);
}

.booking-widget__divider {
  width: 1px;
  height: 48px;
  background-color: var(--color-outline-variant);
  flex-shrink: 0;
}

.booking-widget__submit {
  flex-shrink: 0;
}


/* ============================================================
   10. FORM ELEMENTS
   ============================================================ */

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.form-label {
  font-family: var(--font-sans);
  font-size: var(--fs-label);
  font-weight: var(--fw-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--color-secondary);
}

.form-input,
.form-select,
.form-textarea {
  width: 100%;
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--color-outline-variant);
  background: transparent;
  color: var(--color-on-surface);
  font-size: var(--fs-body-md);
  transition: border-color var(--transition-base);
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  border-color: var(--color-secondary);
}

.form-input::placeholder,
.form-textarea::placeholder {
  color: var(--color-on-surface-variant);
}

.form-textarea {
  resize: vertical;
  min-height: 120px;
}

.form-select {
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
}


/* ============================================================
   11. SECTION OVERLINES & DIVIDERS
   ============================================================ */

.section-overline {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.section-overline__line {
  width: 40px;
  height: 1px;
  background-color: var(--color-secondary-fixed-dim);
  flex-shrink: 0;
}

.section-overline__text {
  font-family: var(--font-sans);
  font-size: var(--fs-label);
  font-weight: var(--fw-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--color-secondary);
}

.section-title {
  font-family: var(--font-serif);
  font-size: var(--fs-headline-md);
  line-height: var(--lh-headline-md);
  color: var(--color-on-surface);
  margin-bottom: var(--space-3);
}

.section-body {
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-body-lg);
  line-height: var(--lh-body-lg);
  color: var(--color-on-surface-variant);
  max-width: 560px;
}


/* ============================================================
   12. FOOTER
   ============================================================ */

.site-footer {
  background-color: var(--color-inverse-surface);
  color: var(--color-inverse-on-surface);
  padding-block: var(--space-15);
}

.site-footer a {
  color: var(--color-inverse-on-surface);
  opacity: 0.7;
  transition: opacity var(--transition-fast);
}

.site-footer a:hover {
  opacity: 1;
}

.site-footer__logo {
  font-family: var(--font-serif);
  font-size: 22px;
  color: var(--color-inverse-on-surface);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-3);
}

.site-footer__tagline {
  font-size: var(--fs-body-md);
  color: var(--color-inverse-on-surface);
  opacity: 0.6;
  margin-bottom: var(--space-6);
  max-width: 280px;
  line-height: 1.6;
}

.site-footer__heading {
  font-family: var(--font-sans);
  font-size: var(--fs-label);
  font-weight: var(--fw-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--color-secondary-fixed-dim);
  margin-bottom: var(--space-3);
}

.site-footer__links {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.site-footer__bottom {
  margin-top: var(--space-10);
  padding-top: var(--space-4);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.site-footer__copy {
  font-size: var(--fs-label);
  letter-spacing: 0.05em;
  opacity: 0.45;
  text-transform: uppercase;
}

/* Footer 4-column grid */
.site-footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: var(--space-10);
  align-items: start;
}

/* Contact block inside brand column */
.site-footer__contact {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  font-style: normal;
  margin-top: var(--space-4);
}

.site-footer__contact a,
.site-footer__address {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--fs-body-md);
  color: var(--color-inverse-on-surface);
  opacity: 0.65;
  transition: opacity var(--transition-fast);
}

.site-footer__contact a:hover {
  opacity: 1;
}

.site-footer__contact .material-symbols-outlined {
  font-size: 16px;
  flex-shrink: 0;
}

/* Social icons row */
.site-footer__social {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.site-footer__social a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: var(--radius-full);
  opacity: 0.6;
  transition: opacity var(--transition-fast), border-color var(--transition-fast);
}

.site-footer__social a:hover {
  opacity: 1;
  border-color: var(--color-secondary-fixed-dim);
}

.site-footer__social .material-symbols-outlined {
  font-size: 18px;
}

/* Footer responsive */
@media (max-width: 768px) {
  .site-footer__grid {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }
}


/* ============================================================
   13. UTILITY CLASSES
   ============================================================ */

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.overflow-clip  { overflow: hidden; }

.img-cover {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.text-accent    { color: var(--color-secondary); }
.font-serif     { font-family: var(--font-serif); }
.font-sans      { font-family: var(--font-sans); }


/* ============================================================
   14. RESPONSIVE BREAKPOINTS
   ============================================================ */

@media (max-width: 1024px) {
  :root {
    --margin-desktop:   48px;
    --section-padding:  80px;
  }
}

@media (max-width: 768px) {
  :root {
    --margin-desktop:   var(--margin-mobile);
    --section-padding:  64px;
  }

  .type-display {
    font-size: var(--fs-display-mobile);
    line-height: var(--lh-display-mobile);
    letter-spacing: var(--ls-display-mobile);
  }

  .grid-12 {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }

  .booking-widget {
    flex-direction: column;
    padding: var(--space-4);
  }

  .booking-widget__divider {
    width: 100%;
    height: 1px;
  }

  .booking-widget__field {
    width: 100%;
  }

  /* Nav collapses to hamburger */
  .site-nav {
    display: none;
    position: fixed;
    inset: 0;
    background-color: var(--color-inverse-surface);
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-6);
    z-index: 99;
  }

  .site-nav.open {
    display: flex;
  }

  .site-nav__link {
    font-size: 18px;
    color: var(--color-inverse-on-surface);
  }

  .site-nav__toggle {
    display: flex;
    z-index: 101;
  }
}
