/* Tocte Resto Bar — styles */
:root{
  --bg:#fdfaf4;
  --paper:#f6efe2;
  --ink:#1c1a16;
  --muted:#6b6258;
  --line:#e6dccb;
  --forest:#1f3a2b;
  --forest-2:#2a5238;
  --ember:#c0552b;
  --gold:#b8893a;
  --shadow:0 12px 40px rgba(28,26,22,.10);
  --radius:14px;
  --maxw:1180px;
  --serif:"Playfair Display", Georgia, serif;
  --sans:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block;height:auto}
a{color:var(--forest-2);text-decoration:none}
a:hover{color:var(--ember)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.15;letter-spacing:-.01em;margin:0 0 .5em}
h1{font-size:clamp(2.2rem,5vw,3.8rem)}
h2{font-size:clamp(1.7rem,3.4vw,2.6rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;color:var(--ember);font-weight:600;margin-bottom:.6em;display:inline-block}
.section{padding:96px 0}
.section-tight{padding:64px 0}
.text-center{text-align:center}
.muted{color:var(--muted)}

/* Header */
.topbar{background:var(--forest);color:#f6efe2;font-size:.85rem}
.topbar .container{display:flex;justify-content:space-between;gap:16px;padding-top:8px;padding-bottom:8px;flex-wrap:wrap}
.topbar a{color:#f6efe2}
.header{position:sticky;top:0;z-index:50;background:rgba(253,250,244,.92);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:1.35rem;color:var(--ink)}
.brand img{width:36px;height:36px}
.menu{display:flex;gap:28px;list-style:none;margin:0;padding:0}
.menu a{color:var(--ink);font-weight:500;position:relative;padding:6px 0}
.menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--ember);transition:width .25s ease}
.menu a:hover::after,.menu a.active::after{width:100%}
.btn{display:inline-block;padding:13px 22px;border-radius:999px;font-weight:600;border:1px solid transparent;transition:transform .2s ease,background .25s ease,color .25s ease,box-shadow .25s ease;cursor:pointer}
.btn-primary{background:var(--forest);color:#fff}
.btn-primary:hover{background:var(--ember);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-sm{padding:10px 16px;font-size:.9rem}
.burger{display:none;background:none;border:0;font-size:1.6rem;color:var(--ink);cursor:pointer}

/* Hero */
.hero{position:relative;min-height:90vh;display:flex;align-items:center;color:#f6efe2;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,18,14,.45),rgba(20,18,14,.78)),url("../images/hero.jpg") center/cover no-repeat;z-index:-1}
.hero .container{padding-top:80px;padding-bottom:80px}
.hero-tag{color:#f0c98a;letter-spacing:.3em;font-size:.8rem;text-transform:uppercase}
.hero h1{color:#fff;max-width:14ch}
.hero h1 em{font-style:italic;color:#f0c98a}
.hero p{max-width:560px;color:#f1e7d5;font-size:1.1rem}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.hero-cta .btn-ghost{color:#fff;border-color:#fff}
.hero-cta .btn-ghost:hover{background:#fff;color:var(--ink)}
.hero-facts{display:flex;gap:28px;margin-top:48px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.18);padding-top:24px}
.hero-facts div{min-width:140px}
.hero-facts strong{display:block;font-family:var(--serif);font-size:1.6rem;color:#f0c98a}

/* Marquee */
.marquee{background:var(--forest);color:#f6efe2;overflow:hidden;border-block:1px solid #122318}
.marquee-track{display:flex;gap:48px;padding:14px 0;white-space:nowrap;animation:scroll 32s linear infinite}
.marquee span{font-family:var(--serif);font-style:italic;font-size:1.2rem;color:#f0c98a}
.marquee span::after{content:"·";margin-left:48px;color:#f6efe2}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* Two-col */
.two-col{display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center}
.two-col img{border-radius:var(--radius);box-shadow:var(--shadow)}

/* Cards */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card img{aspect-ratio:4/3;object-fit:cover}
.card-body{padding:22px}
.card h3{margin-bottom:.4em}
.price{float:right;color:var(--ember);font-weight:700;font-family:var(--serif)}

/* Feature row */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.feature{padding:28px;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper)}
.feature .ico{width:46px;height:46px;border-radius:50%;background:var(--forest);color:#f6efe2;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:700;margin-bottom:14px}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center;background:var(--forest);color:#f6efe2;border-radius:var(--radius);padding:46px 24px}
.stats strong{font-family:var(--serif);font-size:2.4rem;color:#f0c98a;display:block}

/* Testimonials */
.quote{background:var(--paper);border-radius:var(--radius);padding:28px;border:1px solid var(--line)}
.quote p{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--ink)}
.quote .who{display:flex;align-items:center;gap:12px;margin-top:14px}
.avatar{width:42px;height:42px;border-radius:50%;background:var(--forest);color:#f6efe2;display:flex;align-items:center;justify-content:center;font-family:var(--serif)}

/* Menu page */
.menu-section{margin-bottom:48px}
.menu-section h2{border-bottom:1px solid var(--line);padding-bottom:.3em;margin-bottom:.8em}
.menu-item{display:flex;justify-content:space-between;gap:24px;padding:18px 0;border-bottom:1px dashed var(--line)}
.menu-item:last-child{border-bottom:0}
.menu-item h4{font-family:var(--serif);font-size:1.15rem;margin:0 0 4px}
.menu-item .desc{color:var(--muted);font-size:.95rem;margin:0}
.menu-item .price{font-size:1.1rem}

/* Forms */
.form{display:grid;gap:16px;background:#fff;padding:32px;border:1px solid var(--line);border-radius:var(--radius)}
.form label{font-weight:600;font-size:.9rem;display:block;margin-bottom:6px}
.form input,.form select,.form textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font:inherit;background:#fdfaf4}
.form input:focus,.form select:focus,.form textarea:focus{outline:2px solid var(--forest);outline-offset:1px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* Footer */
.footer{background:#14110d;color:#cfc4ac;padding:64px 0 24px;margin-top:80px}
.footer h4{color:#f6efe2;font-family:var(--serif);font-size:1.1rem;margin-bottom:16px}
.footer a{color:#cfc4ac}
.footer a:hover{color:#f0c98a}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}
.footer .small{font-size:.85rem;color:#8b8270}
.foot-bottom{border-top:1px solid #2a261e;margin-top:40px;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.85rem;color:#8b8270}

/* Cookie banner */
.cookie{position:fixed;left:24px;right:24px;bottom:24px;background:#1c1a16;color:#f6efe2;padding:20px 24px;border-radius:var(--radius);box-shadow:0 20px 50px rgba(0,0,0,.4);display:none;z-index:100;align-items:center;gap:18px;flex-wrap:wrap;justify-content:space-between;max-width:920px;margin:0 auto}
.cookie.show{display:flex;animation:slideUp .5s ease}
.cookie p{margin:0;font-size:.92rem;flex:1;min-width:260px}
.cookie a{color:#f0c98a;text-decoration:underline}
.cookie .actions{display:flex;gap:10px}
.cookie button{padding:10px 18px;border-radius:999px;border:0;cursor:pointer;font-weight:600}
.cookie .accept{background:#f0c98a;color:#1c1a16}
.cookie .decline{background:transparent;color:#f6efe2;border:1px solid #555}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* Page header */
.page-head{background:var(--paper);padding:80px 0 60px;border-bottom:1px solid var(--line);text-align:center}
.page-head h1{margin-bottom:.2em}
.crumbs{font-size:.85rem;color:var(--muted)}
.crumbs a{color:var(--muted)}

/* Legal pages */
.legal{max-width:780px;margin:0 auto}
.legal h2{margin-top:1.6em;font-size:1.5rem}
.legal h3{margin-top:1.2em}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery img{aspect-ratio:1/1;object-fit:cover;border-radius:10px;transition:transform .35s ease,filter .35s ease}
.gallery img:hover{transform:scale(1.03);filter:brightness(1.06)}

/* Map placeholder */
.map{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;height:360px;display:flex;align-items:center;justify-content:center;color:var(--muted)}
.map iframe{width:100%;height:100%;border:0}

/* Hours */
.hours{list-style:none;padding:0;margin:0}
.hours li{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px dashed var(--line);font-size:.95rem}
.hours li strong{font-family:var(--serif)}

/* Responsive */
@media (max-width: 900px){
  .grid-3,.features,.gallery{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .two-col{grid-template-columns:1fr;gap:32px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
  .menu{position:fixed;top:64px;right:-100%;width:75%;height:calc(100vh - 64px);background:var(--bg);flex-direction:column;padding:30px;gap:20px;border-left:1px solid var(--line);transition:right .3s ease}
  .menu.open{right:0}
  .burger{display:block}
  .section{padding:64px 0}
  .form .row{grid-template-columns:1fr}
}
@media (max-width: 560px){
  .grid-3,.features,.gallery,.grid-2{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero{min-height:80vh}
}
