
/*
Theme Name: Mesa Norte Restaurante
Theme URI: https://produccionweb.com/demos/estandar/restaurante-fusion/
Author: ProduccionWeb.com
Author URI: https://produccionweb.com/
Description: Demo Estandar para Gastronomia, generado como ejemplo comercial de ProduccionWeb.com.
Version: 1.0.5
Text Domain: produccionweb-demo-estandar-restaurante-fusion
*/
:root {
  --demo-primary: #263A30;
  --demo-secondary: #6BD6B2;
  --demo-accent: #FF6B6B;
  --demo-support: #F4C95D;
  --demo-dark: #090F0C;
  --demo-soft: #F7F4EF;
  --demo-text: #f7fbff;
  --demo-muted: #b7c7d6;
  --demo-line: rgba(255,255,255,.14);
  --demo-panel: rgba(255,255,255,.065);
  --demo-radius: 8px;
  color-scheme: dark;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--demo-text);
  background:
    linear-gradient(90deg, rgba(255,255,255,.028) 1px, transparent 1px) 0 0 / 54px 54px,
    linear-gradient(0deg, rgba(255,255,255,.022) 1px, transparent 1px) 0 0 / 54px 54px,
    var(--demo-dark);
  line-height: 1.62;
  overflow-x: hidden;
}
body.demo-variant-studio, body.demo-variant-restaurant, body.demo-variant-realestate {
  background:
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px) 0 0 / 48px 48px,
    linear-gradient(180deg, var(--demo-dark), #101820 56%, var(--demo-dark));
}
a { color: inherit; text-decoration: none; }
img, canvas, svg { max-width: 100%; }
h1, h2, h3 { margin: 0; line-height: 1.04; letter-spacing: 0; color: var(--demo-text); }
h1 { font-size: clamp(2.2rem, 3.7vw, 3.65rem); max-width: 12ch; }
h2 { font-size: clamp(1.75rem, 2.9vw, 3.05rem); max-width: 14ch; }
h3 { font-size: clamp(1.18rem, 2vw, 1.58rem); }
p { margin: 0 0 1rem; color: var(--demo-muted); }
ul { list-style: none; margin: 0; padding: 0; }
.screen-reader-text,.skip-link { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); }
.skip-link:focus { width:auto; height:auto; clip:auto; z-index:999; top:12px; left:12px; padding:10px 14px; background:#fff; color:#111; }
.demo-wrap { width: min(1180px, calc(100% - 32px)); margin: 0 auto; }
.demo-header { position: sticky; top: 0; z-index: 50; background: rgba(4,8,13,.86); border-bottom: 1px solid var(--demo-line); backdrop-filter: blur(18px); }
.demo-nav { min-height: 74px; display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.demo-brand { display: inline-flex; align-items: center; gap: 12px; min-width: 220px; font-weight: 950; line-height: 1; }
.demo-mark { width: 42px; height: 42px; display: grid; place-items: center; border: 1px solid color-mix(in srgb, var(--demo-secondary) 65%, white); background: linear-gradient(135deg, color-mix(in srgb, var(--demo-secondary) 24%, transparent), color-mix(in srgb, var(--demo-accent) 16%, transparent)); }
.demo-brand small { display: block; margin-top: 4px; color: var(--demo-accent); font-size: .72rem; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; }
.demo-menu { display: flex; align-items: center; gap: 2px; }
.demo-menu li { list-style: none; margin: 0; padding: 0; }
.demo-menu a { display: inline-flex; align-items: center; min-height: 40px; padding: 8px 10px; color: #eef5fb; font-size: .91rem; font-weight: 850; }
.demo-menu a:hover, .demo-menu .current-menu-item > a { color: var(--demo-secondary); }
.demo-header-cta { display:inline-flex; align-items:center; justify-content:center; min-height:42px; padding:0 16px; border:1px solid color-mix(in srgb, var(--demo-accent) 58%, transparent); background:color-mix(in srgb, var(--demo-accent) 18%, transparent); font-weight:900; }
.demo-menu-toggle { display:none; width:42px; height:42px; border:1px solid var(--demo-line); background:rgba(255,255,255,.06); color:var(--demo-text); }
.demo-hero { position:relative; min-height:calc(100vh - 74px); display:flex; align-items:center; overflow:hidden; border-bottom:1px solid var(--demo-line); }
.demo-canvas { position:absolute; inset:0; width:100%; height:100%; opacity:.86; }
.demo-hero:after { content:""; position:absolute; inset:0; pointer-events:none; background:linear-gradient(90deg, var(--demo-dark) 0%, color-mix(in srgb, var(--demo-dark) 88%, transparent) 46%, transparent 100%), linear-gradient(0deg,var(--demo-dark),transparent 48%); }
.demo-hero-grid { position:relative; z-index:2; display:grid; grid-template-columns:minmax(0,1fr) minmax(320px,.72fr); gap:42px; align-items:center; padding:70px 0; }
.demo-kicker { display:inline-flex; align-items:center; gap:10px; margin-bottom:18px; color:var(--demo-secondary); font-size:.8rem; font-weight:950; letter-spacing:.12em; text-transform:uppercase; }
.demo-kicker:before { content:""; width:34px; height:2px; background:currentColor; }
.demo-hero p { max-width:650px; font-size:clamp(1.02rem,1.5vw,1.22rem); }
.demo-actions { display:flex; flex-wrap:wrap; gap:12px; margin-top:28px; }
.demo-btn { display:inline-flex; align-items:center; justify-content:center; min-height:48px; padding:0 18px; border:1px solid var(--demo-line); background:rgba(255,255,255,.06); color:var(--demo-text); font-weight:950; transition:transform .2s ease,border-color .2s ease,background .2s ease; }
.demo-btn:hover { transform:translateY(-2px); border-color:color-mix(in srgb, var(--demo-secondary) 70%, transparent); }
.demo-btn.primary { border-color:color-mix(in srgb, var(--demo-secondary) 55%, transparent); background:linear-gradient(135deg,var(--demo-secondary),color-mix(in srgb,var(--demo-secondary) 58%, var(--demo-primary))); color:#031018; }
.demo-btn.accent { border-color:color-mix(in srgb, var(--demo-accent) 60%, transparent); background:color-mix(in srgb, var(--demo-accent) 15%, transparent); }
.demo-stage { perspective:1200px; min-height:520px; position:relative; display:grid; align-content:center; gap:16px; }
.demo-hero-photo { margin:0; position:relative; overflow:hidden; border:1px solid color-mix(in srgb,var(--demo-secondary) 32%, transparent); background:#071018; box-shadow:0 26px 84px rgba(0,0,0,.36); transform-style:preserve-3d; }
.demo-hero-photo img { display:block; width:100%; height:100%; min-height:280px; object-fit:cover; opacity:.9; transform:scale(1.035); }
.demo-hero-photo:after { content:""; position:absolute; inset:0; pointer-events:none; background:linear-gradient(90deg,rgba(0,0,0,.52),transparent 54%),linear-gradient(0deg,rgba(0,0,0,.48),transparent 56%); }
.demo-photo-label { position:absolute; left:16px; bottom:16px; z-index:2; display:grid; gap:2px; max-width:78%; padding:12px 14px; border:1px solid rgba(255,255,255,.16); background:rgba(4,8,13,.72); backdrop-filter:blur(12px); color:#fff; }
.demo-photo-label span { color:var(--demo-secondary); font-size:.7rem; font-weight:950; letter-spacing:.11em; text-transform:uppercase; }
.demo-photo-label strong { font-size:.95rem; line-height:1.1; }
.demo-stage-panel { position:relative; padding:22px; border:1px solid var(--demo-line); background:linear-gradient(145deg,rgba(255,255,255,.09),rgba(255,255,255,.035)); box-shadow:0 26px 90px rgba(0,0,0,.34); transform:rotateX(9deg) rotateY(-12deg); transform-style:preserve-3d; }
.demo-stage-top { display:flex; justify-content:space-between; gap:16px; padding-bottom:16px; border-bottom:1px solid var(--demo-line); }
.demo-stage-top span { display:block; color:var(--demo-muted); font-size:.85rem; }
.demo-layer { margin-top:15px; padding:16px; border:1px solid color-mix(in srgb,var(--demo-secondary) 30%, transparent); background:rgba(0,0,0,.16); transform:translateZ(var(--z)); }
.demo-layer strong { display:block; font-size:1rem; }
.demo-layer span { color:var(--demo-muted); font-size:.9rem; }
.demo-bar { height:7px; margin-top:12px; background:linear-gradient(90deg,var(--demo-secondary),var(--demo-support),var(--demo-accent)); transform-origin:left; animation:demoBar 4.5s ease-in-out infinite; }
.demo-metrics { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-top:16px; }
.demo-metrics article { padding:14px; border:1px solid var(--demo-line); background:rgba(0,0,0,.18); }
.demo-metrics strong { display:block; color:var(--demo-accent); font-size:1.6rem; line-height:1; }
.demo-metrics span { color:var(--demo-muted); font-size:.78rem; }
.demo-section { padding:96px 0; position:relative; }
.demo-section.band { background:rgba(255,255,255,.035); border-top:1px solid var(--demo-line); border-bottom:1px solid var(--demo-line); }
.demo-head { display:grid; grid-template-columns:minmax(0,.86fr) minmax(260px,.55fr); gap:34px; align-items:end; margin-bottom:34px; }
.demo-head p { max-width:540px; font-size:1.06rem; }
.demo-grid-2 { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px; }
.demo-grid-3 { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px; }
.demo-grid-4 { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:16px; }
.demo-card { border:1px solid var(--demo-line); background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035)); box-shadow:0 18px 52px rgba(0,0,0,.18); padding:24px; }
.demo-card .num { display:inline-grid; place-items:center; width:38px; height:38px; margin-bottom:18px; border:1px solid color-mix(in srgb,var(--demo-accent) 56%, transparent); color:var(--demo-accent); font-weight:950; }
.demo-card p { margin-top:12px; }
.demo-card ul { display:grid; gap:8px; margin-top:16px; }
.demo-card li { color:#dce8f1; font-size:.92rem; }
.demo-card li:before { content:"+ "; color:var(--demo-support); font-weight:900; }
.demo-visual { min-height:430px; position:relative; overflow:hidden; border:1px solid var(--demo-line); background:linear-gradient(135deg,color-mix(in srgb,var(--demo-secondary) 18%, transparent),transparent 42%),linear-gradient(315deg,color-mix(in srgb,var(--demo-accent) 16%, transparent),transparent 44%),rgba(255,255,255,.04); }
.demo-visual:before,.demo-visual:after { content:""; position:absolute; border:1px solid rgba(255,255,255,.16); background:rgba(255,255,255,.04); }
.demo-visual:before { width:50%; height:46%; left:13%; bottom:18%; transform:skewX(-12deg); }
.demo-visual:after { width:32%; height:64%; right:12%; top:14%; }
.demo-orbit { position:absolute; inset:16%; border:2px solid color-mix(in srgb,var(--demo-secondary) 46%, transparent); transform:rotate(-16deg); }
.demo-orbit.two { inset:28% 10%; border-color:color-mix(in srgb,var(--demo-accent) 44%, transparent); transform:rotate(18deg); }
.demo-inner-hero { padding:104px 0 70px; border-bottom:1px solid var(--demo-line); background:linear-gradient(90deg,color-mix(in srgb,var(--demo-secondary) 12%, transparent),transparent 46%); }
.demo-inner-hero p { max-width:720px; font-size:1.12rem; }
.demo-copy-grid { display:grid; grid-template-columns:minmax(0,.9fr) minmax(300px,.52fr); gap:36px; }
.demo-rich > * + * { margin-top:18px; }
.demo-aside { align-self:start; position:sticky; top:100px; }
.demo-aside .demo-card + .demo-card { margin-top:16px; }
.demo-contact { display:grid; grid-template-columns:.86fr 1.14fr; gap:28px; }
.demo-form { display:grid; gap:14px; }
.demo-form label { display:grid; gap:7px; color:#eef5fb; font-weight:850; }
.demo-form input,.demo-form select,.demo-form textarea { width:100%; min-height:48px; border:1px solid var(--demo-line); background:rgba(255,255,255,.06); color:var(--demo-text); padding:12px 13px; font:inherit; }
.demo-form textarea { min-height:140px; resize:vertical; }
.demo-form button { border:0; cursor:pointer; }
.demo-footer { padding:54px 0 32px; border-top:1px solid var(--demo-line); background:#03070d; }
.demo-footer-grid { display:grid; grid-template-columns:1.2fr .8fr .8fr; gap:24px; }
.demo-footer a { color:var(--demo-muted); }
.demo-footer-bottom { display:flex; justify-content:space-between; gap:12px; margin-top:34px; padding-top:20px; border-top:1px solid var(--demo-line); color:var(--demo-muted); font-size:.9rem; }
body.demo-variant-legal h1, body.demo-variant-legal h2 { font-family: Georgia, "Times New Roman", serif; }
body.demo-variant-studio h1 { max-width: 9ch; }
body.demo-variant-restaurant .demo-visual { border-radius: 0 80px 0 0; }
body.demo-variant-fitness .demo-stage-panel { transform: rotateX(6deg) rotateY(-16deg) skewY(-1deg); }
body.demo-variant-cyber .demo-canvas { opacity: 1; }
body.demo-variant-realestate .demo-card { background: linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.028)); }
body.demo-variant-legal .demo-hero-photo { width:92%; justify-self:end; transform:translateX(12px) rotateZ(-1deg); }
body.demo-variant-legal .demo-stage-panel { width:88%; margin-top:-54px; justify-self:start; }
body.demo-variant-studio .demo-stage { min-height:560px; }
body.demo-variant-studio .demo-hero-photo { position:absolute; right:0; top:4%; width:92%; height:390px; transform:rotateZ(1deg) translateZ(-10px); }
body.demo-variant-studio .demo-stage-panel { width:70%; margin-top:310px; justify-self:start; transform:rotateX(6deg) rotateY(8deg); }
body.demo-variant-restaurant .demo-stage { min-height:565px; }
body.demo-variant-restaurant .demo-hero-photo { position:absolute; inset:18px 0 auto 34px; height:388px; clip-path:polygon(0 0,100% 0,92% 100%,0 88%); }
body.demo-variant-restaurant .demo-stage-panel { width:76%; margin-top:326px; justify-self:end; background:linear-gradient(145deg,rgba(16,32,25,.86),rgba(8,13,10,.86)); }
body.demo-variant-fitness .demo-hero-photo { width:96%; justify-self:end; clip-path:polygon(9% 0,100% 0,91% 100%,0 100%); transform:translateX(10px) rotateZ(1deg); }
body.demo-variant-fitness .demo-stage-panel { width:78%; margin-top:-74px; justify-self:start; }
body.demo-variant-cyber .demo-hero-photo { height:260px; border-color:color-mix(in srgb,var(--demo-secondary) 52%, transparent); }
body.demo-variant-cyber .demo-hero-photo img { opacity:.76; filter:saturate(1.1) contrast(1.08); }
body.demo-variant-cyber .demo-stage-panel { width:88%; margin-top:-32px; justify-self:end; background:linear-gradient(145deg,rgba(3,10,23,.92),rgba(3,8,18,.78)); }
body.demo-variant-realestate .demo-stage { min-height:560px; }
body.demo-variant-realestate .demo-hero-photo { height:390px; transform:translateY(-8px); }
body.demo-variant-realestate .demo-stage-panel { width:78%; margin-top:-86px; justify-self:start; background:linear-gradient(145deg,rgba(18,30,29,.82),rgba(7,16,19,.82)); }
@keyframes demoBar { 0%,100% { transform:scaleX(.28); opacity:.58; } 50% { transform:scaleX(1); opacity:1; } }
@media (max-width: 980px) {
  .demo-menu-toggle { display:inline-grid; place-items:center; }
  .demo-header-cta { display:none; }
  .demo-menu { position:absolute; left:16px; right:16px; top:74px; display:none; padding:12px; border:1px solid var(--demo-line); background:rgba(5,9,15,.98); box-shadow:0 24px 80px rgba(0,0,0,.36); }
  .demo-menu.is-open { display:grid; }
  .demo-menu a { width:100%; }
  .demo-hero-grid,.demo-head,.demo-copy-grid,.demo-contact,.demo-footer-grid { grid-template-columns:1fr; }
  .demo-stage { min-height:420px; }
  .demo-stage-panel { transform:rotateX(5deg) rotateY(-5deg); }
  .demo-grid-4,.demo-grid-3 { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .demo-aside { position:static; }
}
@media (max-width: 680px) {
  html,body { max-width:100%; overflow-x:hidden; }
  .demo-wrap { width:min(calc(100vw - 40px), 350px); max-width:350px; margin-left:auto; margin-right:auto; }
  .demo-brand { min-width:0; }
  .demo-section { padding:70px 0; }
  .demo-hero { min-height:auto; }
  .demo-hero-copy,.demo-stage,.demo-stage-panel,.demo-card,.demo-visual,.demo-hero-photo { min-width:0; max-width:100%; overflow:hidden; }
  .demo-hero-grid { display:block; padding:58px 0 72px; }
  .demo-hero h1 { max-width:12ch; font-size:clamp(1.8rem,7.8vw,2.25rem); line-height:1.12; overflow-wrap:normal; word-break:normal; }
  .demo-hero p,.demo-card p,.demo-card li,.demo-layer span,.demo-layer strong,.demo-stage-top span,.demo-metrics span { max-width:100%; overflow-wrap:break-word; word-break:normal; }
  .demo-kicker { font-size:.72rem; }
  .demo-kicker:before { width:24px; }
  .demo-actions { display:grid; max-width:100%; }
  .demo-btn { width:100%; }
  .demo-stage { min-height:auto; margin-top:28px; }
  .demo-hero-photo { position:relative!important; inset:auto!important; width:100%!important; height:auto!important; justify-self:auto!important; transform:none!important; clip-path:none!important; }
  .demo-hero-photo img { min-height:220px; transform:none; }
  .demo-photo-label { left:12px; right:12px; bottom:12px; max-width:none; }
  .demo-stage-panel { width:100%!important; margin:16px 0 0!important; justify-self:auto!important; transform:none; padding:16px; }
  .demo-layer { transform:none; padding:14px; }
  .demo-stage-top { display:grid; grid-template-columns:1fr; gap:8px; }
  .demo-bar { max-width:100%; }
  .demo-metrics,.demo-grid-4,.demo-grid-3,.demo-grid-2 { grid-template-columns:1fr; }
  .demo-visual { min-height:340px; }
  .demo-footer-bottom { display:grid; }
}
@media (prefers-reduced-motion:reduce) {
  *,*:before,*:after { animation:none!important; transition:none!important; scroll-behavior:auto!important; }
}
