/* ═══════════════════════════════════════════════════════
   SASHIOTO — Sistema de Diseño Kintsugi para WordPress
   Versión: 1.0.0  |  Once Marketing
═══════════════════════════════════════════════════════ */

/* ─── CUSTOM PROPERTIES ─── */
:root {
  --sk-void:        #000e02;
  --sk-ceramic:     #0d1f0e;
  --sk-gold:        #C9A84C;
  --sk-gold-light:  #E8C96A;
  --sk-gold-pale:   #F5E4A8;
  --sk-gold-dark:   #8B6914;
  --sk-gold-glow:   #D4AF37;
  --sk-sage:        #EDF1C7;
  --sk-ash:         #A8A090;
  --sk-dill:        #4a5e3a;
  --sk-crimson:     #8B1A1A;
  --sk-font-tenor:  'Tenor Sans', serif;
  --sk-font-public: 'Public Sans', sans-serif;
  --sk-font-nanum:  'Nanum Myeongjo', serif;
  --sk-container:   1200px;
  --sk-radius:      0px;
}

/* ─── RESET SCOPE ─── */
.sk-section, .sk-section * { box-sizing: border-box; margin: 0; padding: 0; }

/* ─── BASE ─── */
.sk-section {
  position: relative;
  background-color: var(--sk-void);
  color: var(--sk-sage);
  font-family: var(--sk-font-public);
  font-weight: 200;
  -webkit-font-smoothing: antialiased;
  overflow: hidden;
}

.sk-container {
  max-width: var(--sk-container);
  margin: 0 auto;
  padding: 7rem 2rem;
}

/* ─── FONT UTILITIES ─── */
.sk-tenor { font-family: var(--sk-font-tenor) !important; }
.sk-nanum { font-family: var(--sk-font-nanum) !important; }

/* ─── COLOR UTILITIES ─── */
.sk-text-gold {
  background: linear-gradient(135deg, #8B6914 0%, #C9A84C 40%, #E8C96A 65%, #C9A84C 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.sk-text-gold-flat { color: var(--sk-gold); }
.sk-gold-muted     { color: rgba(201,168,76,.6); }
.sk-gold-dim       { color: rgba(201,168,76,.35); font-size: .7rem; letter-spacing: .2em; margin-top: .3rem; }

/* ─── TYPOGRAPHY SCALE ─── */
.sk-section-title {
  font-family: var(--sk-font-tenor);
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--sk-sage);
  line-height: 1;
}

.sk-label-jp {
  font-family: var(--sk-font-nanum);
  font-size: .7rem;
  letter-spacing: .5em;
  color: rgba(201,168,76,.55);
  text-transform: uppercase;
  margin-bottom: 1rem;
}

.sk-body-text {
  font-family: var(--sk-font-public);
  font-weight: 200;
  font-size: .95rem;
  line-height: 1.8;
  letter-spacing: .05em;
  color: var(--sk-ash);
}

.sk-section-desc {
  font-family: var(--sk-font-public);
  font-weight: 200;
  font-size: .875rem;
  letter-spacing: .1em;
  color: var(--sk-ash);
  max-width: 360px;
  margin: 1.5rem auto 0;
}

/* ─── SECTION HEADER ─── */
.sk-section-header { text-align: center; margin-bottom: 5rem; }

/* ─── DIVIDER KANJI ─── */
.sk-divider-kanji {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  max-width: 240px;
  margin: 1.5rem auto 0;
}
.sk-divider-kanji::before,
.sk-divider-kanji::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,168,76,.5), transparent);
}

/* ─── GRID HELPERS ─── */
.sk-grid-2 { display: grid; grid-template-columns: 1fr; gap: 3rem; }
.sk-grid-3 { display: grid; grid-template-columns: 1fr; gap: 2rem; }
@media (min-width: 768px) {
  .sk-grid-2 { grid-template-columns: 1fr 1fr; }
  .sk-grid-3 { grid-template-columns: 1fr 1fr 1fr; }
}

/* ─── CRACK WRAPS ─── */
.sk-section-crack-top,
.sk-section-crack-bottom { position: absolute; left: 0; right: 0; z-index: 2; pointer-events: none; }
.sk-section-crack-top    { top: 0; height: 60px; }
.sk-section-crack-bottom { bottom: 0; height: 60px; }
.sk-crack-wrap { width: 100%; }
.sk-crack-svg  { width: 100%; height: 100%; overflow: visible; display: block; }

/* ─── ANIMATIONS ─── */
@keyframes sk-fade-up {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes sk-gold-pulse {
  0%, 100% { opacity: .35; }
  50%       { opacity: .9; }
}
@keyframes sk-pan-glow {
  0%   { transform: translate(0, 0); }
  50%  { transform: translate(3%, 2%); }
  100% { transform: translate(0, 0); }
}
@keyframes sk-crack-draw {
  from { stroke-dashoffset: 2000; }
  to   { stroke-dashoffset: 0; }
}
@keyframes sk-spin {
  to { transform: rotate(360deg); }
}

.sk-fade-up { opacity: 0; animation: sk-fade-up .9s ease forwards; }

/* Crack paths animation */
.sk-animated .sk-crack-path       { animation: sk-crack-draw 2.2s ease-out forwards; }
.sk-animated .sk-crack-path.sk-main  { animation-delay: .3s; }
.sk-animated .sk-crack-path.sk-sub1  { animation-delay: .6s; }
.sk-animated .sk-crack-path.sk-sub2  { animation-delay: .9s; }
.sk-animated .sk-glow-path        { animation: sk-gold-pulse 3s ease-in-out infinite; }
.sk-animated .sk-dot {
  animation: sk-fade-up .4s ease forwards;
}
.sk-animated .sk-dot:nth-child(1) { animation-delay: 1.2s; }
.sk-animated .sk-dot:nth-child(2) { animation-delay: 1.4s; }
.sk-animated .sk-dot:nth-child(3) { animation-delay: 1.6s; }
.sk-animated .sk-dot:nth-child(4) { animation-delay: 1.8s; }
.sk-animated .sk-dot:nth-child(5) { animation-delay: 2.0s; }

/* ═════════════════════════════════════════════════════
   HERO
═════════════════════════════════════════════════════ */
.sk-hero { min-height: 100vh; display: flex; align-items: center; justify-content: center; }
.sk-hero-inner { position: relative; z-index: 10; text-align: center; padding: 0 2rem; max-width: 900px; }

/* Glows */
.sk-hero-glow { position: absolute; border-radius: 50%; pointer-events: none; }
.sk-glow-center {
  top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 800px; height: 800px;
  background: radial-gradient(circle, rgba(201,168,76,.06) 0%, transparent 70%);
  animation: sk-pan-glow 12s ease-in-out infinite;
}
.sk-glow-tl {
  top: -10%; left: -10%; width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(212,175,55,.05) 0%, transparent 65%);
  animation: sk-pan-glow 18s ease-in-out infinite reverse;
}
.sk-glow-br {
  bottom: 0; right: 0; width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(139,105,20,.05) 0%, transparent 65%);
}

/* Grid overlay */
.sk-grid-overlay {
  position: absolute; inset: 0; pointer-events: none; opacity: .035;
  background-image:
    linear-gradient(var(--sk-gold) 1px, transparent 1px),
    linear-gradient(90deg, var(--sk-gold) 1px, transparent 1px);
  background-size: 80px 80px;
}

.sk-hero-kanji {
  font-family: var(--sk-font-nanum);
  font-size: .8rem;
  letter-spacing: .6em;
  color: rgba(201,168,76,.55);
  margin-bottom: 3rem;
}

.sk-hero-title {
  font-family: var(--sk-font-tenor);
  font-size: clamp(3rem, 10vw, 7rem);
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--sk-sage);
  line-height: 1;
  margin-bottom: 1rem;
}

.sk-hero-crack { margin: 2rem auto; max-width: 640px; height: 70px; }

.sk-hero-tagline {
  font-family: var(--sk-font-public);
  font-weight: 200;
  font-size: clamp(.95rem, 2vw, 1.15rem);
  letter-spacing: .12em;
  color: var(--sk-ash);
  line-height: 1.6;
  max-width: 400px;
  margin: 0 auto;
}
.sk-hero-sub {
  display: block;
  font-family: var(--sk-font-nanum);
  font-size: .8rem;
  letter-spacing: .25em;
  color: rgba(201,168,76,.55);
  margin-top: .5rem;
}
.sk-hero-quote {
  font-family: var(--sk-font-nanum);
  font-size: .7rem;
  letter-spacing: .35em;
  color: rgba(201,168,76,.4);
  margin-top: 1.5rem;
}
.sk-hero-scroll {
  display: flex; flex-direction: column; align-items: center;
  gap: .75rem; margin-top: 5rem;
}
.sk-hero-scroll-label {
  font-family: var(--sk-font-tenor);
  font-size: .55rem; letter-spacing: .5em; text-transform: uppercase;
  color: rgba(201,168,76,.5);
}
.sk-hero-scroll-line {
  width: 1px; height: 56px;
  background: linear-gradient(180deg, rgba(201,168,76,.7), transparent);
  animation: sk-gold-pulse 2.5s ease-in-out infinite;
}

/* ═════════════════════════════════════════════════════
   RESERVAS
═════════════════════════════════════════════════════ */
.sk-reservas .sk-container { padding-top: 8rem; padding-bottom: 8rem; }

.sk-fieldset { border: none; margin-bottom: 3rem; }
.sk-legend {
  font-family: var(--sk-font-nanum);
  font-size: .6rem; letter-spacing: .4em; text-transform: uppercase;
  color: rgba(201,168,76,.55);
  width: 100%; padding-bottom: .6rem;
  border-bottom: 1px solid rgba(201,168,76,.1);
  margin-bottom: 2rem;
}
.sk-field { display: flex; flex-direction: column; }
.sk-label {
  font-family: var(--sk-font-tenor);
  font-size: .55rem; letter-spacing: .35em; text-transform: uppercase;
  color: rgba(201,168,76,.65);
  margin-bottom: .75rem;
}
.sk-input {
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(74,94,58,.5);
  color: var(--sk-sage);
  padding: .75rem 0;
  font-family: var(--sk-font-public);
  font-weight: 200;
  font-size: .875rem;
  letter-spacing: .05em;
  outline: none;
  transition: border-color .35s ease, box-shadow .35s ease;
  width: 100%;
  -webkit-appearance: none;
  appearance: none;
}
.sk-input::placeholder { color: rgba(74,94,58,.6); }
.sk-input:focus        { border-color: var(--sk-gold); box-shadow: 0 2px 0 rgba(201,168,76,.25); }
.sk-input.sk-date      { color-scheme: dark; }
.sk-select             { cursor: pointer; }
.sk-textarea           { resize: none; }

/* Personas buttons */
.sk-personas { display: flex; flex-wrap: wrap; gap: .5rem; padding-top: .5rem; }
.sk-persona-btn {
  width: 2rem; height: 2rem;
  background: transparent;
  border: 1px solid rgba(201,168,76,.2);
  color: rgba(201,168,76,.7);
  font-family: var(--sk-font-tenor);
  font-size: .75rem;
  cursor: pointer;
  transition: all .2s ease;
}
.sk-persona-btn:hover,
.sk-persona-btn.sk-active {
  background: var(--sk-gold);
  border-color: var(--sk-gold);
  color: var(--sk-void);
}

/* Submit */
.sk-form-footer { text-align: center; padding-top: 1rem; }
.sk-form-note {
  font-family: var(--sk-font-nanum);
  font-size: .6rem; letter-spacing: .3em;
  color: rgba(201,168,76,.3);
  margin-top: 1rem;
}
.sk-form-error {
  background: rgba(139,26,26,.15);
  border: 1px solid rgba(139,26,26,.3);
  color: #e87878;
  padding: .75rem 1rem;
  font-size: .8rem;
  margin-bottom: 1.5rem;
}

/* Buttons */
.sk-btn-primary {
  display: inline-flex; align-items: center; gap: .75rem;
  border: 1px solid var(--sk-gold);
  color: var(--sk-gold);
  background: transparent;
  font-family: var(--sk-font-tenor);
  font-size: .6rem; letter-spacing: .4em; text-transform: uppercase;
  padding: 1rem 3rem;
  cursor: pointer;
  transition: background .4s ease, box-shadow .4s ease;
}
.sk-btn-primary:hover {
  background: rgba(201,168,76,.07);
  box-shadow: 0 0 24px rgba(201,168,76,.1);
}
.sk-btn-primary:disabled { opacity: .35; cursor: not-allowed; }
.sk-btn-spinner {
  width: .75rem; height: .75rem; border-radius: 50%;
  border: 1px solid rgba(201,168,76,.4);
  border-top-color: var(--sk-gold);
  animation: sk-spin .8s linear infinite;
}
.sk-btn-gold {
  display: flex; align-items: center; justify-content: center; gap: .5rem;
  border: 1px solid var(--sk-gold);
  color: var(--sk-gold);
  background: transparent;
  font-family: var(--sk-font-tenor);
  font-size: .6rem; letter-spacing: .35em; text-transform: uppercase;
  padding: .85rem 1.5rem;
  text-decoration: none;
  transition: background .3s ease, color .3s ease;
}
.sk-btn-gold:hover { background: var(--sk-gold); color: var(--sk-void); }
.sk-btn-outline {
  display: flex; align-items: center; justify-content: center;
  border: 1px solid rgba(201,168,76,.25);
  color: rgba(201,168,76,.6);
  background: transparent;
  font-family: var(--sk-font-tenor);
  font-size: .6rem; letter-spacing: .35em; text-transform: uppercase;
  padding: .85rem 1.5rem;
  text-decoration: none;
  cursor: pointer;
  transition: border-color .3s ease, color .3s ease;
}
.sk-btn-outline:hover { border-color: var(--sk-gold); color: var(--sk-gold); }

/* Success state */
.sk-reservas-success { text-align: center; padding: 5rem 0; }
.sk-success-icon {
  width: 4rem; height: 4rem; border-radius: 50%;
  border: 1px solid rgba(201,168,76,.5);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--sk-font-nanum); font-size: 1.5rem; color: var(--sk-gold);
  margin: 0 auto 1.5rem;
}
.sk-success-title {
  font-family: var(--sk-font-tenor); font-size: 1.5rem;
  letter-spacing: .2em; color: var(--sk-sage); margin-bottom: 1rem;
}
.sk-success-email { color: var(--sk-ash); font-size: .85rem; letter-spacing: .1em; }
.sk-success-meta  {
  font-family: var(--sk-font-nanum); color: rgba(201,168,76,.35);
  font-size: .65rem; letter-spacing: .3em; margin-top: .5rem;
}

/* ═════════════════════════════════════════════════════
   CARTA
═════════════════════════════════════════════════════ */
.sk-carta-nav {
  display: flex; flex-wrap: wrap; justify-content: center; gap: .25rem; margin-bottom: 4rem;
}
.sk-cat-btn {
  display: flex; flex-direction: column; align-items: center;
  padding: .6rem 1.25rem;
  background: transparent;
  border: 1px solid rgba(201,168,76,.12);
  color: var(--sk-dill);
  font-family: var(--sk-font-tenor);
  font-size: .6rem; letter-spacing: .3em; text-transform: uppercase;
  cursor: pointer;
  transition: all .3s ease;
}
.sk-cat-btn.sk-active { background: var(--sk-gold); border-color: var(--sk-gold); color: var(--sk-void); }
.sk-cat-btn:hover:not(.sk-active) { border-color: rgba(201,168,76,.4); color: var(--sk-sage); }
.sk-cat-jp { font-family: var(--sk-font-nanum); font-size: .55rem; letter-spacing: .3em; opacity: .7; margin-bottom: .2rem; }

.sk-platos { }
.sk-cat-group.sk-hidden { display: none; }

.sk-plato {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 1.5rem; padding: 1.75rem .5rem;
  border-bottom: 1px solid rgba(201,168,76,.06);
  transition: background .3s ease;
}
.sk-plato:hover { background: rgba(232,201,106,.02); }
.sk-plato-info { flex: 1; min-width: 0; }
.sk-plato-nombre-row { display: flex; align-items: baseline; gap: .75rem; margin-bottom: .4rem; }
.sk-plato-nombre {
  font-family: var(--sk-font-tenor); font-size: 1rem; letter-spacing: .12em; color: var(--sk-sage);
  transition: color .3s ease;
}
.sk-plato:hover .sk-plato-nombre { color: var(--sk-gold-light); }
.sk-plato-jp { font-family: var(--sk-font-nanum); font-size: .7rem; color: rgba(201,168,76,.3); }
.sk-plato-desc { font-size: .85rem; color: var(--sk-ash); line-height: 1.65; letter-spacing: .04em; }
.sk-plato-tags { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: .75rem; }
.sk-tag {
  font-family: var(--sk-font-tenor);
  font-size: .5rem; letter-spacing: .25em; text-transform: uppercase;
  padding: .2rem .5rem; border: 1px solid;
}
.sk-tag--vegano      { border-color: rgba(74,94,58,.6);    color: #4a5e3a; }
.sk-tag--sin-gluten  { border-color: rgba(168,160,144,.4); color: var(--sk-ash); }
.sk-tag--picante     { border-color: rgba(139,26,26,.4);   color: #8B1A1A; }
.sk-tag--omakase     { border-color: rgba(201,168,76,.4);  color: var(--sk-gold); }
.sk-plato-precio {
  flex-shrink: 0; text-align: right;
  font-family: var(--sk-font-tenor); font-size: 1.15rem; letter-spacing: .1em; color: var(--sk-sage);
}
.sk-euro { font-family: var(--sk-font-nanum); font-size: .85rem; color: var(--sk-gold); }
.sk-carta-footer {
  text-align: center; margin-top: 3rem;
  font-size: .6rem; letter-spacing: .3em; color: rgba(201,168,76,.25);
}

/* ═════════════════════════════════════════════════════
   HISTORIA
═════════════════════════════════════════════════════ */
.sk-historia-kanji-bg {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--sk-font-nanum);
  font-size: 28vw; font-weight: 700; color: transparent;
  -webkit-text-stroke: 1px rgba(201,168,76,.04);
  pointer-events: none; user-select: none; z-index: 0;
}
.sk-historia .sk-container { position: relative; z-index: 2; }

.sk-historia-foto {
  position: relative; width: 100%; height: 55vh; overflow: hidden; margin-bottom: 6rem;
}
.sk-historia-img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
.sk-historia-foto-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,14,2,.5) 0%, rgba(0,14,2,.1) 50%, rgba(0,14,2,.75) 100%);
  display: flex; align-items: flex-end;
}
.sk-historia-foto-caption {
  position: absolute; bottom: 2rem; right: 2rem;
  font-family: var(--sk-font-nanum); font-size: .6rem; letter-spacing: .4em;
  color: rgba(201,168,76,.35); text-align: right;
}

.sk-historia-mv { margin-bottom: 6rem; align-items: start; }
.sk-historia-vision { padding-top: 3rem; }
.sk-historia-subtitle {
  font-family: var(--sk-font-tenor);
  font-size: clamp(1.4rem, 3vw, 2rem);
  letter-spacing: .1em; color: var(--sk-sage); line-height: 1.35;
  margin: 1rem 0 1.5rem;
}
.sk-blockquote {
  border-left: 2px solid rgba(201,168,76,.35);
  padding-left: 1.25rem; margin-top: 2rem;
  font-family: var(--sk-font-tenor);
  font-size: 1.05rem; letter-spacing: .08em;
  font-style: italic; color: rgba(232,201,106,.65);
}

/* Kintsugi block */
.sk-kintsugi-block {
  position: relative; margin-bottom: 6rem; overflow: hidden;
  background: rgba(13,31,14,.5);
  border: 1px solid rgba(201,168,76,.1);
}
.sk-kintsugi-glow {
  position: absolute; inset: -4rem; pointer-events: none;
  background: radial-gradient(ellipse at 20% 50%, rgba(201,168,76,.04) 0%, transparent 60%);
}
.sk-kintsugi-corner {
  position: absolute; pointer-events: none; z-index: 1; opacity: .6;
}
.sk-corner-tl { top: 0; left: 0; width: 120px; height: 80px; }
.sk-corner-br { bottom: 0; right: 0; width: 120px; height: 80px; }
.sk-kintsugi-inner {
  position: relative; z-index: 2;
  display: grid; grid-template-columns: auto 1fr;
  gap: 2.5rem; padding: 4rem 3rem;
  align-items: start;
}
@media (max-width: 600px) {
  .sk-kintsugi-inner { grid-template-columns: 1fr; }
}
.sk-kintsugi-kanji {
  display: flex; flex-direction: column; align-items: center; gap: .25rem;
}
.sk-kintsugi-kanji-label {
  font-family: var(--sk-font-tenor); font-size: .55rem;
  letter-spacing: .4em; text-transform: uppercase;
  color: rgba(201,168,76,.5); margin-top: .75rem;
}
.sk-kintsugi-separator {
  display: flex; align-items: center; gap: 1rem; margin-top: 2rem;
}
.sk-kintsugi-separator::before {
  content: ''; flex: 1; height: 1px;
  background: linear-gradient(90deg, rgba(201,168,76,.5), transparent);
}

/* Etymology */
.sk-etimologia {
  text-align: center;
  border-top: 1px solid rgba(201,168,76,.1);
  border-bottom: 1px solid rgba(201,168,76,.1);
  padding: 5rem 0; margin-bottom: 6rem;
}
.sk-etimologia-chars {
  display: flex; align-items: center; justify-content: center; gap: 3rem; margin: 2rem 0;
}
.sk-etim-char { display: flex; flex-direction: column; align-items: center; gap: .5rem; }
.sk-etim-kanji { font-family: var(--sk-font-nanum); font-size: 3rem; color: var(--sk-sage); }
.sk-etim-romaji {
  font-family: var(--sk-font-tenor); font-size: .6rem;
  letter-spacing: .3em; text-transform: uppercase; color: rgba(201,168,76,.65);
}
.sk-etim-meaning { font-size: .7rem; color: rgba(168,160,144,.6); letter-spacing: .05em; }
.sk-etim-separator {
  width: 1px; height: 4rem;
  background: linear-gradient(180deg, transparent, rgba(201,168,76,.4), transparent);
}

/* Values grid */
.sk-valores-grid {
  display: grid; grid-template-columns: 1fr;
  gap: 1px; background: rgba(201,168,76,.06);
}
@media (min-width: 640px) { .sk-valores-grid { grid-template-columns: 1fr 1fr; } }
.sk-valor {
  background: var(--sk-void); padding: 2.5rem;
  transition: background .5s ease;
}
.sk-valor:hover { background: #0d1f0e; }
.sk-valor-kanji {
  font-family: var(--sk-font-nanum); font-size: 4.5rem; line-height: 1;
  display: block; margin-bottom: 1rem;
  color: rgba(201,168,76,.1);
  transition: color .5s ease;
}
.sk-valor:hover .sk-valor-kanji { color: rgba(201,168,76,.3); }
.sk-valor-title {
  font-family: var(--sk-font-tenor); font-size: .9rem;
  letter-spacing: .2em; text-transform: uppercase; color: var(--sk-sage); margin-bottom: .75rem;
}
.sk-valor-body { font-size: .85rem; color: var(--sk-ash); line-height: 1.7; }

/* ═════════════════════════════════════════════════════
   UBICACIÓN
═════════════════════════════════════════════════════ */
.sk-ubicacion-grid {
  display: grid; grid-template-columns: 1fr;
  border: 1px solid rgba(201,168,76,.1); overflow: hidden; margin-bottom: 2.5rem;
}
@media (min-width: 900px) { .sk-ubicacion-grid { grid-template-columns: 1fr 380px; } }

.sk-mapa-wrap { position: relative; height: 380px; background: var(--sk-void); }
@media (min-width: 900px) { .sk-mapa-wrap { height: auto; min-height: 420px; } }
.sk-mapa {
  position: absolute; inset: 0; width: 100%; height: 100%; border: 0;
  filter: invert(92%) hue-rotate(180deg) saturate(.3) brightness(.75);
}
.sk-mapa-vignette {
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse at center, transparent 50%, rgba(0,14,2,.5) 100%);
}

.sk-info-panel {
  padding: 2.5rem;
  background: rgba(13,31,14,.6);
  border-top: 1px solid rgba(201,168,76,.08);
  display: flex; flex-direction: column; gap: 2rem;
  backdrop-filter: blur(4px);
}
@media (min-width: 900px) { .sk-info-panel { border-top: none; border-left: 1px solid rgba(201,168,76,.08); } }

.sk-info-block { display: flex; flex-direction: column; gap: .4rem; }
.sk-info-address { font-family: var(--sk-font-tenor); font-size: 1.1rem; letter-spacing: .1em; color: var(--sk-sage); }
.sk-info-subtext { font-size: .85rem; color: var(--sk-ash); letter-spacing: .05em; }

.sk-horario { list-style: none; display: flex; flex-direction: column; gap: .6rem; }
.sk-horario li {
  display: flex; justify-content: space-between; align-items: flex-start;
  font-size: .75rem; gap: 1rem;
}
.sk-horario li > span:first-child {
  font-family: var(--sk-font-tenor); letter-spacing: .2em; text-transform: uppercase;
  color: rgba(201,168,76,.65); min-width: 80px; font-size: .65rem;
}
.sk-horario li > span:last-child { color: var(--sk-sage); text-align: right; line-height: 1.5; }
.sk-horario li.sk-closed > span { color: rgba(74,94,58,.5); }

.sk-contacto { list-style: none; display: flex; flex-direction: column; gap: .5rem; }
.sk-contacto a {
  font-size: .85rem; color: var(--sk-ash); text-decoration: none; letter-spacing: .05em;
  transition: color .3s ease;
}
.sk-contacto a:hover { color: var(--sk-gold); }

.sk-info-ctas { display: flex; flex-direction: column; gap: .75rem; }
.sk-pin-icon { width: 1rem; height: 1rem; fill: currentColor; }

.sk-transporte {
  display: grid; grid-template-columns: 1fr;
  gap: 1px; background: rgba(201,168,76,.06);
}
@media (min-width: 640px) { .sk-transporte { grid-template-columns: repeat(3, 1fr); } }
.sk-transporte-item {
  background: var(--sk-void); padding: 1.5rem 2rem;
  display: flex; align-items: flex-start; gap: 1rem;
}
.sk-transporte-icon { font-size: 1.25rem; margin-top: .2rem; }
.sk-transporte-title { font-family: var(--sk-font-tenor); font-size: .75rem; letter-spacing: .2em; text-transform: uppercase; color: var(--sk-sage); margin-bottom: .3rem; }
.sk-transporte-detail { font-size: .75rem; color: rgba(168,160,144,.65); line-height: 1.5; }

/* ─── Responsive (mobile global) ─── */
@media (max-width: 640px) {
  .sk-container { padding: 5rem 1.25rem; }
  .sk-hero-title { font-size: 3.2rem; }
  .sk-kintsugi-inner { padding: 2rem 1.5rem; }
}

/* ─── Scrollbar ─── */
.sk-section::-webkit-scrollbar       { width: 3px; }
.sk-section::-webkit-scrollbar-track { background: var(--sk-void); }
.sk-section::-webkit-scrollbar-thumb { background: rgba(201,168,76,.3); border-radius: 2px; }

/* ─── Selection ─── */
.sk-section ::selection { background: rgba(201,168,76,.15); color: var(--sk-gold-pale); }

/* ═════════════════════════════════════════════════════
   NAVEGACIÓN PRINCIPAL — Fija, Kintsugi
═════════════════════════════════════════════════════ */
.sk-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 2.5rem;
  height: 64px;
  background: rgba(0,14,2,0.72);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid transparent;
  transition: border-color .4s ease, background .4s ease;
  font-family: var(--sk-font-tenor);
}

/* Borde dorado al hacer scroll */
.sk-nav--scrolled {
  border-bottom-color: rgba(201,168,76,.22);
  background: rgba(0,14,2,0.92);
}

/* Logo */
.sk-nav-logo {
  text-decoration: none;
  font-family: var(--sk-font-tenor);
  font-size: .95rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--sk-sage);
  display: flex;
  align-items: center;
  gap: .6rem;
  line-height: 1;
}
.sk-nav-logo-gold {
  background: linear-gradient(135deg, #8B6914 0%, #C9A84C 40%, #E8C96A 65%, #C9A84C 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.sk-nav-logo-jp {
  font-size: .65rem;
  letter-spacing: .3em;
  color: rgba(201,168,76,.45);
  margin-left: .2rem;
}

/* Links de navegación */
.sk-nav-links {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 2.5rem;
}
.sk-nav-link {
  text-decoration: none;
  font-family: var(--sk-font-tenor);
  font-size: .6rem;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: rgba(237,241,199,.6);
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .2rem;
  padding-bottom: .2rem;
  transition: color .3s ease;
}
.sk-nav-link::after {
  content: '';
  position: absolute;
  bottom: 0; left: 50%;
  transform: translateX(-50%) scaleX(0);
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent, #C9A84C, transparent);
  transition: transform .35s ease;
}
.sk-nav-link:hover { color: var(--sk-gold-light); }
.sk-nav-link:hover::after { transform: translateX(-50%) scaleX(1); }
.sk-nav-jp {
  font-size: .5rem;
  letter-spacing: .2em;
  color: rgba(201,168,76,.35);
}

/* Hamburger mobile */
.sk-nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 28px; height: 28px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}
.sk-nav-toggle span {
  display: block;
  height: 1px;
  background: rgba(201,168,76,.7);
  transition: transform .3s ease, opacity .3s ease;
}

/* Menú abierto (mobile) */
.sk-nav--open .sk-nav-links {
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 64px; left: 0; right: 0;
  background: rgba(0,14,2,.97);
  border-top: 1px solid rgba(201,168,76,.12);
  padding: 2.5rem 2rem;
  gap: 2rem;
  animation: sk-fade-up .3s ease forwards;
}

@media (max-width: 768px) {
  .sk-nav-toggle { display: flex; }
  .sk-nav-links  { display: none; }
  .sk-nav--open .sk-nav-links { display: flex; }
  .sk-nav-link {
    font-size: .75rem;
    letter-spacing: .3em;
    color: rgba(237,241,199,.75);
  }
}

/* ═════════════════════════════════════════════════════
   FOOTER — Kintsugi
═════════════════════════════════════════════════════ */
.sk-footer {
  position: relative;
  background: var(--sk-void);
  border-top: 1px solid rgba(201,168,76,.08);
  overflow: hidden;
}
.sk-footer-crack {
  position: absolute;
  top: -1px; left: 0; right: 0;
  height: 60px;
  pointer-events: none;
}
.sk-footer-inner {
  max-width: var(--sk-container);
  margin: 0 auto;
  padding: 6rem 2rem 3rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2.5rem;
}

/* Brand */
.sk-footer-kanji {
  font-size: 1.5rem;
  color: rgba(201,168,76,.3);
  letter-spacing: .4em;
  margin-bottom: .5rem;
}
.sk-footer-logo {
  font-family: var(--sk-font-tenor);
  font-size: clamp(1.8rem, 5vw, 3rem);
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--sk-sage);
  font-weight: 400;
}
.sk-footer-tagline {
  font-size: .6rem;
  letter-spacing: .5em;
  color: rgba(201,168,76,.45);
  text-transform: uppercase;
  margin-top: .5rem;
}

/* Nav footer */
.sk-footer-nav {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  gap: .75rem 1.5rem;
}
.sk-footer-nav-link {
  text-decoration: none;
  font-family: var(--sk-font-tenor);
  font-size: .55rem;
  letter-spacing: .4em;
  text-transform: uppercase;
  color: rgba(237,241,199,.45);
  transition: color .3s ease;
}
.sk-footer-nav-link:hover { color: var(--sk-gold); }
.sk-footer-nav-sep { color: rgba(201,168,76,.2); }

/* Contacto */
.sk-footer-contact {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .5rem 2rem;
}
.sk-footer-contact-link {
  text-decoration: none;
  font-size: .8rem;
  color: rgba(168,160,144,.55);
  letter-spacing: .05em;
  transition: color .3s ease;
}
.sk-footer-contact-link:hover { color: var(--sk-gold); }

/* Divider */
.sk-footer-divider {
  width: 120px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,168,76,.3), transparent);
}

/* Copyright */
.sk-footer-copy {
  font-size: .7rem;
  letter-spacing: .08em;
  color: rgba(168,160,144,.3);
  line-height: 1.6;
}
.sk-footer-copy-sep { margin: 0 .5rem; }
.sk-footer-copy-credit a {
  color: rgba(201,168,76,.4);
  text-decoration: none;
  transition: color .3s ease;
}
.sk-footer-copy-credit a:hover { color: var(--sk-gold); }


/* ─── White stripe / Elementor section gap fix ─── */
.elementor-section.elementor-top-section { margin: 0 !important; padding: 0 !important; }
.elementor-widget { margin: 0 !important; padding: 0 !important; }

/* ─── Instagram link in footer (styled like contact links) ─── */
.sk-footer-instagram {
  letter-spacing: .06em;
}