/*
Theme Name: Ladakh Atlas
Theme URI: https://example.com/ladakh-atlas-theme
Author: Shreyans Jain
Description: A quiet, paper-textured WordPress theme designed to pair with the Ladakh Atlas plugin. Cream linen background, deep sepia ink, brass accents — the same vocabulary as the atlas itself, so the [ladakh_atlas] and [ladakh_admin] shortcodes feel native. Two page templates: "Atlas (full bleed)" for the public atlas, and "Trip Admin" for the dashboard.
Version: 1.2.1
Tested up to: 6.5
Requires at least: 6.0
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ladakh-atlas-theme
Tags: blog, custom-menu, custom-logo, threaded-comments, translation-ready
*/

:root {
  --paper:        #f1e8d2;
  --paper-2:      #e8dcbe;
  --paper-3:      #f7eed7;
  --paper-shadow: #b9985d;
  --ink:          #1c1610;
  --ink-soft:     #574231;
  --ink-faded:    #93795a;
  --gold:         #8a5d22;
  --gold-bright:  #b08540;
  --crimson:      #7a2a1c;
  --forest:       #2b4a32;
  --hairline:      rgba(70,50,25,.32);
  --hairline-soft: rgba(70,50,25,.12);
  --serif:   "EB Garamond", "Iowan Old Style", Georgia, serif;
  --display: "Cormorant Garamond", "EB Garamond", Georgia, serif;
  --mono:    "JetBrains Mono", "IBM Plex Mono", monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--serif);
  font-size: 18px;
  line-height: 1.65;
  color: var(--ink);
  background-color: #ece2c6;
  background-image:
    repeating-linear-gradient(0deg,  rgba(70,50,20,.012) 0 2px, transparent 2px 5px),
    repeating-linear-gradient(90deg, rgba(70,50,20,.010) 0 2px, transparent 2px 5px),
    radial-gradient(ellipse at 50% 120%, rgba(60,40,8,.18) 0%, transparent 55%),
    radial-gradient(ellipse at 50% 30%, #f6ecd1 0%, #efe2c2 45%, #ddc99a 100%);
  background-attachment: fixed;
  min-height: 100vh;
  font-feature-settings: "liga", "kern", "onum";
}

/* ===== Typography ===== */
h1, h2, h3, h4 {
  font-family: var(--display);
  font-weight: 500;
  color: var(--ink);
  letter-spacing: .01em;
  line-height: 1.15;
  margin: 0 0 .5em;
  text-wrap: balance;
}
h1 { font-size: clamp(36px, 6vw, 64px); }
h2 { font-size: clamp(26px, 4vw, 38px); }
h3 { font-size: 22px; }
h4 { font-size: 18px; }
p  { margin: 0 0 1em; text-wrap: pretty; }
a  { color: var(--gold); text-decoration: none; border-bottom: 1px solid var(--hairline-soft); padding-bottom: 1px; transition: color .15s, border-color .15s; }
a:hover { color: var(--ink); border-bottom-color: var(--ink); }
em, i { font-style: italic; }
strong, b { font-weight: 600; }
small { font-size: 13px; color: var(--ink-faded); }
hr {
  border: 0;
  height: 1px;
  background: var(--hairline);
  margin: 32px 0;
}
blockquote {
  margin: 24px 0;
  padding: 4px 0 4px 22px;
  border-left: 1px solid var(--ink-faded);
  font-family: var(--display);
  font-style: italic;
  font-size: 19px;
  color: var(--ink-soft);
  line-height: 1.5;
}
code, pre {
  font-family: var(--mono);
  font-size: 14px;
  background: var(--paper-2);
  padding: 2px 6px;
  border-radius: 2px;
}
pre {
  padding: 14px 18px;
  overflow-x: auto;
  line-height: 1.5;
}
img, svg, video {
  max-width: 100%;
  height: auto;
}

/* ===== Layout shell ===== */
.site {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* ===== Header ===== */
.site-header {
  padding: 40px 32px 32px;
  border-bottom: 1px solid var(--hairline);
  text-align: center;
  background:
    linear-gradient(180deg, rgba(255,250,232,.5), rgba(255,250,232,.1));
}
.site-header.is-compact { padding: 24px 32px 20px; }
.site-header .site-eyebrow {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .42em;
  text-transform: uppercase;
  color: var(--gold);
  text-indent: .42em;
  margin-bottom: 16px;
}
.site-header .site-title {
  font-family: var(--display);
  font-weight: 500;
  font-size: clamp(32px, 5vw, 52px);
  margin: 0;
  letter-spacing: .03em;
}
.site-header .site-title a {
  color: var(--ink);
  border-bottom: none;
}
.site-header .site-title a:hover { color: var(--gold); }
.site-header .site-description {
  font-family: var(--display);
  font-style: italic;
  font-size: 16px;
  color: var(--ink-soft);
  margin: 10px auto 0;
  max-width: 600px;
}

/* ===== Nav ===== */
.site-nav {
  margin-top: 20px;
  display: flex;
  justify-content: center;
  gap: 26px;
  flex-wrap: wrap;
}
.site-nav a {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--ink-soft);
  border-bottom: 1px solid transparent;
  padding: 4px 0;
  text-indent: .28em;
}
.site-nav a:hover,
.site-nav a.current,
.site-nav .current-menu-item > a {
  color: var(--ink);
  border-bottom-color: var(--gold);
}

/* ===== Content shell — full bleed site-wide ===== */
.site-main {
  flex: 1;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}
.site-main.is-wide { max-width: none; }
.site-main.is-full { max-width: none; padding: 0; }

/* ===== Article ===== */
.entry {
  background: transparent;
  padding: 0;
  box-shadow: none;
  position: relative;
}
.entry::before, .entry::after { display: none; }
.entry > * { position: relative; z-index: 1; }
.entry-meta {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold);
  text-indent: .32em;
  margin-bottom: 12px;
}
.entry-title { margin-bottom: 24px; }
.entry-content {
  font-size: 18px;
  line-height: 1.7;
}
.entry-content > :first-child { margin-top: 0; }
.entry-content > :last-child  { margin-bottom: 0; }
.entry-content figure { margin: 32px 0; }
.entry-content figure figcaption {
  font-family: var(--display);
  font-style: italic;
  color: var(--ink-faded);
  font-size: 14px;
  text-align: center;
  margin-top: 8px;
}

/* ===== Posts archive ===== */
.posts-grid {
  display: grid;
  gap: 28px;
}
.post-card {
  background: var(--paper-3);
  border: 1px solid var(--hairline);
  padding: 28px 32px;
  border-radius: 2px;
}
.post-card .entry-meta { margin-bottom: 8px; }
.post-card h2 { margin: 0 0 8px; font-size: 26px; }
.post-card h2 a { color: var(--ink); border-bottom: none; }
.post-card h2 a:hover { color: var(--gold); }
.post-card .excerpt { margin: 0; font-style: italic; color: var(--ink-soft); }
.post-card .read-more {
  display: inline-block;
  margin-top: 14px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  border-bottom-color: var(--gold);
}

/* ===== Page header (above content) ===== */
.page-header {
  text-align: center;
  margin-bottom: 36px;
}
.page-header .eyebrow {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .42em;
  text-transform: uppercase;
  color: var(--gold);
  text-indent: .42em;
  margin-bottom: 16px;
}

/* ===== Footer ===== */
.site-footer {
  border-top: 1px solid var(--hairline);
  padding: 40px 32px 60px;
  text-align: center;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--ink-faded);
  text-indent: .32em;
}
.site-footer .footer-ornament {
  color: var(--gold);
  font-size: 14px;
  margin-bottom: 18px;
  letter-spacing: 0;
  text-indent: 0;
}
.site-footer a { color: var(--ink-soft); border-bottom-color: var(--hairline-soft); }
.site-footer a:hover { color: var(--ink); border-bottom-color: var(--ink); }

/* ===== Buttons (matching plugin) ===== */
.btn {
  display: inline-block;
  padding: 12px 22px;
  background: var(--ink);
  color: var(--paper);
  border: 1px solid var(--ink);
  border-radius: 2px;
  font-family: var(--display);
  font-size: 16px;
  font-weight: 500;
  letter-spacing: .01em;
  cursor: pointer;
  transition: transform .15s, box-shadow .15s;
  text-decoration: none;
}
.btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 18px -8px rgba(40,24,4,.55);
  color: var(--paper);
  border-bottom-color: var(--ink);
}
.btn.ghost {
  background: transparent;
  color: var(--ink);
}
.btn.ghost:hover { background: var(--ink); color: var(--paper); }

/* ===== Pagination ===== */
.pagination {
  display: flex;
  justify-content: center;
  gap: 14px;
  margin-top: 40px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
}
.pagination a, .pagination .current {
  padding: 8px 14px;
  border: 1px solid var(--hairline);
  border-radius: 2px;
  text-indent: .22em;
  color: var(--ink-soft);
  background: transparent;
}
.pagination .current { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* ===== Comments ===== */
.comments-area {
  margin-top: 48px;
  background: var(--paper-3);
  border: 1px solid var(--hairline);
  padding: 32px 36px;
}
.comments-area h2.comments-title {
  font-size: 22px;
  margin-bottom: 18px;
}
.comments-list { list-style: none; padding: 0; }
.comment-body {
  border-bottom: 1px solid var(--hairline-soft);
  padding: 18px 0;
}
.comment-body:last-child { border-bottom: none; }
.comment-author { font-family: var(--display); font-weight: 500; font-size: 16px; }
.comment-meta { font-family: var(--mono); font-size: 10px; color: var(--ink-faded); letter-spacing: .14em; }

/* ===== Forms ===== */
form input[type="text"],
form input[type="tel"],
form input[type="email"],
form input[type="url"],
form input[type="password"],
form input[type="search"],
form textarea,
form select {
  width: 100%;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--hairline);
  padding: 8px 0;
  font-family: var(--serif);
  font-size: 16px;
  color: var(--ink);
  outline: none;
}
form input:focus, form textarea:focus, form select:focus { border-bottom-color: var(--ink); }
form label {
  display: block;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 4px;
  text-indent: .32em;
}

/* ===== Search form ===== */
.search-form {
  display: flex;
  gap: 8px;
  align-items: flex-end;
}
.search-form .search-field {
  flex: 1;
  background: var(--paper-3);
  border: 1px solid var(--hairline);
  padding: 8px 12px;
}
.search-form .search-submit {
  padding: 9px 18px;
  background: var(--ink);
  color: var(--paper);
  border: 1px solid var(--ink);
  border-radius: 2px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  cursor: pointer;
}

/* ===== Sticky header on scroll (optional) ===== */
@media (min-width: 700px) {
  .site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    backdrop-filter: blur(6px);
    background: rgba(241, 232, 210, .85);
  }
}

/* ===== Atlas-template overrides: no entry chrome inside [ladakh_atlas] ===== */
.is-atlas-template .site-main { padding: 0; max-width: none; }
.is-atlas-template .entry { background: none; box-shadow: none; padding: 0; }
.is-atlas-template .entry::before,
.is-atlas-template .entry::after { display: none; }
.is-atlas-template .entry-header { display: none; }

/* ===== Admin template ===== */
.is-admin-template .site-main { max-width: 1200px; }

/* ===== WP block-editor compatibility ===== */
.wp-block-image { margin: 32px 0; }
.wp-block-quote { margin: 24px 0; padding-left: 22px; border-left: 1px solid var(--ink-faded); font-family: var(--display); font-style: italic; color: var(--ink-soft); }
.wp-block-pullquote { padding: 18px 0; text-align: center; font-family: var(--display); font-size: 24px; }
.alignwide  { max-width: 960px; margin-left: calc(50% - 480px); margin-right: 0; }
.alignfull  { max-width: 100%; margin-left: calc(-50vw + 50%); margin-right: calc(-50vw + 50%); }

/* ===== Accessibility ===== */
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  -webkit-clip-path: inset(50%);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  word-wrap: normal !important;
}
:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
}

/* ===== WP admin bar offset ===== */
.admin-bar .site-header { top: 32px; }
@media (max-width: 782px) {
  .admin-bar .site-header { top: 46px; }
}
