/*
Theme Name:        Por La Sushi
Theme URI:         https://porlasushi.cl
Author:            Por La Sushi
Author URI:        https://porlasushi.cl
Description:       Tema oficial de Por La Sushi — Fusión Nikkei · Ceviche & Sushi. Diseñado para funcionar con Elementor y Elementor Pro.
Version:           1.0.0
Requires at least: 6.0
Tested up to:      6.5
Requires PHP:      8.0
License:           Proprietary
License URI:       https://porlasushi.cl
Text Domain:       porlasushi
Tags:              full-width-template, custom-colors, custom-fonts, elementor, restaurant
*/

/* ─── BRAND VARIABLES ─── */
:root {
  --pls-purple-deep:   #1a0a2e;
  --pls-purple-mid:    #2d1054;
  --pls-purple-main:   #4a1a8c;
  --pls-gold:          #f5c842;
  --pls-gold-light:    #ffe47a;
  --pls-cream:         #fdf6e3;
  --pls-white:         #ffffff;
  --pls-text-muted:    #c9b8e8;
  --pls-green-fresh:   #6bc96e;
  --pls-red-spicy:     #e84040;
  --pls-border:        rgba(245,200,66,0.2);

  --pls-font-heading:  'Bebas Neue', 'Impact', sans-serif;
  --pls-font-body:     'Outfit', 'Segoe UI', sans-serif;

  --pls-radius-sm:     8px;
  --pls-radius-md:     16px;
  --pls-radius-lg:     24px;
  --pls-radius-full:   9999px;

  --pls-shadow-glow:   0 0 40px rgba(245,200,66,0.25);
  --pls-shadow-card:   0 8px 40px rgba(0,0,0,0.4);
}

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

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  font-family: var(--pls-font-body);
  background-color: var(--pls-purple-deep);
  color: var(--pls-white);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* ─── TYPOGRAPHY ─── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--pls-font-heading);
  line-height: 1.05;
  letter-spacing: 0.03em;
  color: var(--pls-white);
}

h1 { font-size: clamp(3rem, 8vw, 7rem); }
h2 { font-size: clamp(2rem, 5vw, 4rem); }
h3 { font-size: clamp(1.5rem, 3vw, 2.5rem); }
h4 { font-size: 1.5rem; }
h5 { font-size: 1.2rem; }
h6 { font-size: 1rem; }

p { margin-bottom: 1em; color: var(--pls-text-muted); }
p:last-child { margin-bottom: 0; }

a {
  color: var(--pls-gold);
  text-decoration: none;
  transition: color 0.2s ease, opacity 0.2s ease;
}
a:hover { color: var(--pls-gold-light); }

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

ul, ol { padding-left: 1.5rem; }

strong, b { font-weight: 700; color: var(--pls-white); }

/* ─── LAYOUT ─── */
.container {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 5vw;
}

.container-narrow {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 5vw;
}

.container-wide {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 3vw;
}

/* ─── SECTION BASE ─── */
.pls-section {
  padding: 6rem 5vw;
  position: relative;
}

.pls-section--dark {
  background: var(--pls-purple-deep);
}

.pls-section--darker {
  background: linear-gradient(180deg, #0f0518 0%, #1a0a2e 100%);
}

.pls-section--gradient {
  background: linear-gradient(180deg, #1a0a2e 0%, #0f0518 50%, #1a0a2e 100%);
}

/* ─── HEADER ─── */
#masthead {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 9999;
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 5vw;
  background: linear-gradient(180deg, rgba(26,10,46,0.98) 0%, rgba(26,10,46,0.9) 100%);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--pls-border);
  transition: background 0.3s ease;
}

#masthead.scrolled {
  background: rgba(15,5,24,0.98);
  box-shadow: 0 4px 30px rgba(0,0,0,0.5);
}

.site-branding { display: flex; align-items: center; gap: 0.75rem; }

.site-title {
  font-family: var(--pls-font-heading);
  font-size: 1.9rem;
  letter-spacing: 0.04em;
  color: var(--pls-gold);
  line-height: 1;
}
.site-title a { color: inherit; text-decoration: none; }
.site-title span { color: var(--pls-white); }

.site-description {
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--pls-text-muted);
  opacity: 0.7;
}

.custom-logo-link img { height: 45px; width: auto; }

/* ─── NAVIGATION ─── */
#site-navigation { display: flex; align-items: center; }

.main-navigation ul {
  display: flex;
  list-style: none;
  padding: 0; margin: 0;
  gap: 0.25rem;
  align-items: center;
}

.main-navigation ul li a {
  display: block;
  color: var(--pls-text-muted);
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.5rem 0.8rem;
  border-radius: var(--pls-radius-full);
  transition: all 0.2s ease;
}

.main-navigation ul li a:hover,
.main-navigation ul li.current-menu-item > a {
  color: var(--pls-gold);
  background: rgba(245,200,66,0.08);
}

.main-navigation ul li.menu-cta > a {
  background: var(--pls-gold);
  color: var(--pls-purple-deep) !important;
  font-weight: 700;
  padding: 0.45rem 1.2rem;
  transition: all 0.2s ease;
}

.main-navigation ul li.menu-cta > a:hover {
  background: var(--pls-gold-light);
  transform: scale(1.04);
  box-shadow: var(--pls-shadow-glow);
}

/* Mobile menu toggle */
.menu-toggle {
  display: none;
  background: none;
  border: 1.5px solid rgba(255,255,255,0.2);
  border-radius: var(--pls-radius-sm);
  padding: 0.4rem 0.6rem;
  cursor: pointer;
  color: var(--pls-white);
  font-size: 1.2rem;
  transition: border-color 0.2s;
}
.menu-toggle:hover { border-color: var(--pls-gold); color: var(--pls-gold); }

/* ─── FOOTER ─── */
#colophon {
  position: relative;
  z-index: 1;
  background: rgba(0,0,0,0.5);
  border-top: 1px solid var(--pls-border);
  padding: 3rem 5vw 2rem;
}

.footer-inner {
  max-width: 1280px;
  margin: 0 auto;
  text-align: center;
}

.footer-logo {
  font-family: var(--pls-font-heading);
  font-size: 2.5rem;
  letter-spacing: 0.05em;
  color: var(--pls-gold);
  margin-bottom: 0.3rem;
}
.footer-logo span { color: var(--pls-white); }

.footer-tagline {
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--pls-text-muted);
  margin-bottom: 1.5rem;
}

.footer-nav ul {
  display: flex; flex-wrap: wrap; justify-content: center;
  list-style: none; padding: 0; margin: 0 0 1.5rem;
  gap: 1.5rem;
}
.footer-nav ul li a {
  color: var(--pls-text-muted);
  font-size: 0.82rem;
  transition: color 0.2s;
}
.footer-nav ul li a:hover { color: var(--pls-gold); }

.site-info {
  font-size: 0.72rem;
  color: rgba(255,255,255,0.2);
  letter-spacing: 0.05em;
}

.footer-social { display: flex; justify-content: center; gap: 1rem; margin-bottom: 1.5rem; }
.footer-social a {
  display: flex; align-items: center; justify-content: center;
  width: 38px; height: 38px;
  border-radius: 50%;
  border: 1px solid var(--pls-border);
  color: var(--pls-text-muted);
  font-size: 1rem;
  transition: all 0.2s;
}
.footer-social a:hover {
  border-color: var(--pls-gold);
  color: var(--pls-gold);
  background: rgba(245,200,66,0.1);
}

/* ─── MAIN CONTENT AREA ─── */
#primary { padding-top: 70px; }

.entry-title { font-family: var(--pls-font-heading); color: var(--pls-white); }
.entry-content { color: var(--pls-text-muted); }

/* ─── BUTTONS ─── */
.btn, button, input[type="submit"], input[type="button"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-family: var(--pls-font-body);
  font-weight: 700;
  font-size: 0.88rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.8rem 2rem;
  border-radius: var(--pls-radius-full);
  border: none;
  cursor: pointer;
  transition: all 0.2s ease;
  text-decoration: none;
  line-height: 1;
}

.btn-primary, .wp-block-button__link {
  background: var(--pls-gold);
  color: var(--pls-purple-deep) !important;
  box-shadow: 0 4px 20px rgba(245,200,66,0.35);
}
.btn-primary:hover, .wp-block-button__link:hover {
  background: var(--pls-gold-light);
  transform: translateY(-2px);
  box-shadow: 0 8px 35px rgba(245,200,66,0.55);
  color: var(--pls-purple-deep) !important;
}

.btn-outline {
  background: transparent;
  color: var(--pls-white) !important;
  border: 1.5px solid rgba(255,255,255,0.3);
}
.btn-outline:hover {
  border-color: var(--pls-gold);
  color: var(--pls-gold) !important;
}

/* ─── ELEMENTOR OVERRIDES ─── */
.elementor-section-wrap > .elementor-section:first-child,
.elementor-top-section:first-child { margin-top: 0 !important; }

/* Elementor full-width canvas */
.elementor-template-full-width #primary {
  padding-top: 0;
}

/* Fix Elementor default gaps */
.elementor-widget-wrap { gap: 0; }

/* Ensure Elementor widgets inherit font */
.elementor-widget-heading .elementor-heading-title {
  font-family: var(--pls-font-heading) !important;
}
.elementor-widget-text-editor { color: var(--pls-text-muted); }

/* ─── ELEMENTOR CUSTOM CLASSES (usable as CSS classes in Elementor) ─── */

/* Gold heading accent */
.pls-accent { color: var(--pls-gold) !important; }

/* Section label (small uppercase) */
.pls-label {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--pls-gold);
  opacity: 0.85;
  display: block;
  margin-bottom: 0.5rem;
}

/* Badge pill */
.pls-badge {
  display: inline-block;
  background: rgba(245,200,66,0.15);
  border: 1px solid rgba(245,200,66,0.4);
  color: var(--pls-gold);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.35rem 1.1rem;
  border-radius: var(--pls-radius-full);
}

/* Card styles */
.pls-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--pls-radius-md);
  padding: 1.5rem;
  transition: all 0.3s ease;
}
.pls-card:hover {
  border-color: rgba(245,200,66,0.35);
  transform: translateY(-3px);
  box-shadow: var(--pls-shadow-card);
}

.pls-card--promo {
  background: linear-gradient(135deg, rgba(74,26,140,0.4), rgba(26,10,46,0.6));
  border-color: var(--pls-border);
}

/* Divider with title */
.pls-divider {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin: 2rem 0 1.5rem;
}
.pls-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(to right, rgba(245,200,66,0.4), transparent);
}

/* Glow effects */
.pls-glow { box-shadow: var(--pls-shadow-glow); }
.pls-glow-text { text-shadow: 0 0 30px rgba(245,200,66,0.5); }

/* Tag pills */
.pls-tag { 
  display: inline-block;
  font-size: 0.7rem; font-weight: 600;
  letter-spacing: 0.07em; text-transform: uppercase;
  padding: 0.2rem 0.7rem; border-radius: var(--pls-radius-full);
}
.pls-tag--veggie  { background: rgba(107,201,110,0.15); color: #6bc96e; border: 1px solid rgba(107,201,110,0.3); }
.pls-tag--spicy   { background: rgba(232,64,64,0.15);   color: #e84040; border: 1px solid rgba(232,64,64,0.3);   }
.pls-tag--premium { background: rgba(245,200,66,0.12);  color: #f5c842; border: 1px solid rgba(245,200,66,0.3);  }
.pls-tag--new     { background: rgba(255,120,60,0.15);  color: #ff9060; border: 1px solid rgba(255,120,60,0.3);  }

/* Noise overlay (apply to sections) */
.pls-noise::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
  opacity: 0.35;
  z-index: 0;
}

/* Orb gradient backgrounds */
.pls-bg-radial {
  background: radial-gradient(ellipse 80% 60% at 50% 40%, #3a1270 0%, #1a0a2e 70%);
}

.pls-orb {
  position: absolute; border-radius: 50%;
  filter: blur(80px); pointer-events: none;
}
.pls-orb--1 { width: 500px; height: 500px; background: #6b23d4; opacity: 0.25; }
.pls-orb--2 { width: 400px; height: 400px; background: #f5c842; opacity: 0.1;  }
.pls-orb--3 { width: 300px; height: 300px; background: #3a8fff; opacity: 0.08; }

/* Animate orb */
@keyframes pls-float { 0%,100%{transform:translateY(0) scale(1)} 50%{transform:translateY(-25px) scale(1.04)} }
.pls-orb--animated { animation: pls-float 8s ease-in-out infinite; }

/* ─── UTILITY CLASSES ─── */
.pls-text-gold  { color: var(--pls-gold) !important; }
.pls-text-muted { color: var(--pls-text-muted) !important; }
.pls-text-white { color: var(--pls-white) !important; }
.pls-text-green { color: var(--pls-green-fresh) !important; }
.pls-text-red   { color: var(--pls-red-spicy) !important; }

.pls-bg-deep  { background-color: var(--pls-purple-deep) !important; }
.pls-bg-mid   { background-color: var(--pls-purple-mid)  !important; }
.pls-bg-main  { background-color: var(--pls-purple-main) !important; }
.pls-bg-black { background-color: #0a0012 !important; }

.pls-border     { border: 1px solid var(--pls-border) !important; }
.pls-border-gold { border: 1.5px solid var(--pls-gold) !important; }

.pls-rounded-sm { border-radius: var(--pls-radius-sm) !important; }
.pls-rounded-md { border-radius: var(--pls-radius-md) !important; }
.pls-rounded-lg { border-radius: var(--pls-radius-lg) !important; }
.pls-rounded    { border-radius: var(--pls-radius-full) !important; }

.pls-font-heading { font-family: var(--pls-font-heading) !important; }
.pls-font-body    { font-family: var(--pls-font-body) !important; }

/* ─── WOOCOMMERCE (si se usa en el futuro) ─── */
.woocommerce .button,
.woocommerce button.button {
  background: var(--pls-gold) !important;
  color: var(--pls-purple-deep) !important;
  font-weight: 700;
  border-radius: var(--pls-radius-full) !important;
}

/* ─── FORMS ─── */
input[type="text"], input[type="email"], input[type="tel"],
input[type="url"], input[type="search"], textarea, select {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--pls-radius-sm);
  color: var(--pls-white);
  font-family: var(--pls-font-body);
  font-size: 0.9rem;
  padding: 0.75rem 1rem;
  width: 100%;
  transition: border-color 0.2s ease;
  outline: none;
}
input:focus, textarea:focus, select:focus {
  border-color: var(--pls-gold);
  box-shadow: 0 0 0 3px rgba(245,200,66,0.15);
}
::placeholder { color: rgba(255,255,255,0.3); }

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--pls-purple-deep); }
::-webkit-scrollbar-thumb { background: var(--pls-purple-main); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--pls-gold); }

/* ─── RESPONSIVE ─── */
@media (max-width: 768px) {
  #masthead { padding: 0 1.25rem; }

  .main-navigation { display: none; position: absolute; top: 70px; left: 0; right: 0; padding: 1rem; background: rgba(15,5,24,0.98); border-bottom: 1px solid var(--pls-border); }
  .main-navigation.toggled { display: flex; flex-direction: column; }
  .main-navigation ul { flex-direction: column; gap: 0.25rem; }
  .main-navigation ul li a { font-size: 1rem; padding: 0.75rem 1rem; }
  .menu-toggle { display: flex; align-items: center; justify-content: center; }

  .pls-section { padding: 3.5rem 1.25rem; }
  h1 { font-size: clamp(2.8rem, 14vw, 5rem); }
  h2 { font-size: clamp(1.8rem, 8vw, 3rem); }
}

@media (max-width: 480px) {
  .pls-section { padding: 2.5rem 1rem; }
}

/* Print */
@media print {
  #masthead, .main-navigation { position: static; }
  body { background: white; color: black; }
}
