/* ===== Bali Llama Event Rentals — Stylesheet ===== */
:root{
  --terracotta:#c4654a;
  --terracotta-dark:#a04e36;
  --sage:#87a878;
  --sage-dark:#5e7e52;
  --cream:#faf6ef;
  --cream-2:#f0ebe1;
  --sand:#e8dcc4;
  --ink:#2b2622;
  --muted:#6b5f54;
  --line:#e3d9c8;
  --white:#ffffff;
  --shadow-sm:0 4px 14px rgba(43,38,34,.06);
  --shadow-md:0 14px 40px rgba(43,38,34,.10);
  --shadow-lg:0 30px 70px rgba(43,38,34,.18);
  --radius:14px;
  --maxw:1200px;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Inter',system-ui,-apple-system,sans-serif;
  --t:cubic-bezier(.2,.7,.2,1);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--sans);font-size:17px;line-height:1.7;color:var(--ink);background:var(--cream);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--terracotta);text-decoration:none;transition:color .25s var(--t)}
a:hover{color:var(--terracotta-dark)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.15;color:var(--ink);margin:0 0 .6em}
h1{font-size:clamp(2.4rem,5.5vw,4.6rem);letter-spacing:-.01em}
h1 em{font-style:italic;color:var(--terracotta)}
h2{font-size:clamp(1.9rem,3.5vw,3rem)}
h3{font-size:1.4rem}
h4{font-size:1.05rem;text-transform:uppercase;letter-spacing:.12em;font-family:var(--sans);font-weight:600}
p{margin:0 0 1em}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.narrow{max-width:760px;margin:0 auto}
.center{text-align:center}
.muted{color:var(--muted)}
.small{font-size:.88rem}
.eyebrow{display:inline-block;font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--terracotta);margin-bottom:1rem;padding:.4rem .9rem;border:1px solid var(--terracotta);border-radius:99px}
.lead{font-size:1.15rem;color:var(--muted);max-width:680px}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:.6rem 1rem;z-index:9999}
.skip-link:focus{left:.5rem;top:.5rem}

/* ----- Header ----- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(250,246,239,.85);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:all .3s var(--t)}
.site-header.scrolled{border-bottom-color:var(--line);box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink)}
.brand img{width:48px;height:48px;object-fit:contain}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text strong{font-family:var(--serif);font-size:1.3rem;font-weight:600;color:var(--ink)}
.brand-text em{font-style:normal;font-size:.62rem;letter-spacing:.25em;text-transform:uppercase;color:var(--sage-dark);margin-top:3px}
.site-nav{display:flex;align-items:center;gap:28px}
.site-nav a{color:var(--ink);font-size:.94rem;font-weight:500;position:relative;padding:6px 0}
.site-nav a:not(.nav-cta)::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--terracotta);transform:scaleX(0);transform-origin:right;transition:transform .35s var(--t)}
.site-nav a:not(.nav-cta):hover::after{transform:scaleX(1);transform-origin:left}
.nav-cta{background:var(--terracotta);color:#fff !important;padding:10px 20px !important;border-radius:99px;transition:background .25s var(--t),transform .25s var(--t)}
.nav-cta:hover{background:var(--terracotta-dark);transform:translateY(-1px)}
.nav-toggle{display:none;background:none;border:0;width:42px;height:42px;flex-direction:column;justify-content:center;align-items:center;gap:5px;cursor:pointer}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);transition:.3s var(--t)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ----- Buttons ----- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border-radius:99px;font-family:var(--sans);font-size:.95rem;font-weight:600;letter-spacing:.02em;cursor:pointer;border:0;transition:all .3s var(--t);text-decoration:none}
.btn-primary{background:var(--terracotta);color:#fff;box-shadow:0 6px 20px rgba(196,101,74,.35)}
.btn-primary:hover{background:var(--terracotta-dark);color:#fff;transform:translateY(-2px);box-shadow:0 10px 28px rgba(196,101,74,.45)}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);padding:10px 18px}

/* ----- Hero ----- */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;color:#fff}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;animation:slowZoom 18s ease-out forwards}
@keyframes slowZoom{from{transform:scale(1.1)}to{transform:scale(1)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(43,38,34,.25) 0%,rgba(43,38,34,.55) 60%,rgba(43,38,34,.7) 100%)}
.hero-content{position:relative;z-index:2;padding:120px 24px;color:#fff;max-width:1100px}
.hero-content .eyebrow{color:#fff;border-color:rgba(255,255,255,.6)}
.hero-content h1{color:#fff}
.hero-content h1 em{color:#f5d3a3}
.hero-content .lead{color:rgba(255,255,255,.92);max-width:640px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin:30px 0 50px}
.hero-actions .btn-outline{color:#fff;border-color:#fff}
.hero-actions .btn-outline:hover{background:#fff;color:var(--ink)}
.hero-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:30px;max-width:680px;padding:30px 0;border-top:1px solid rgba(255,255,255,.25)}
.hero-stats div{display:flex;flex-direction:column}
.hero-stats strong{font-family:var(--serif);font-size:2.6rem;color:#f5d3a3;font-weight:600}
.hero-stats span{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.85);margin-top:4px}

/* ----- Page hero ----- */
.page-hero{padding:120px 0 80px;background:linear-gradient(180deg,var(--cream-2) 0%,var(--cream) 100%);text-align:center}
.page-hero .lead{margin:0 auto}

/* ----- Sections ----- */
.section{padding:100px 0}
.bg-cream{background:var(--cream-2)}
.section-head{text-align:center;max-width:760px;margin:0 auto 60px}
.section-head .lead{margin:0 auto}

/* ----- Layouts ----- */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.grid{display:grid;gap:30px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.img-frame{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md)}
.img-frame img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--t)}
.img-frame:hover img{transform:scale(1.05)}

/* ----- Cards ----- */
.card{display:block;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);color:var(--ink);transition:transform .35s var(--t),box-shadow .35s var(--t)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);color:var(--ink)}
.card-img{aspect-ratio:1/1;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--t)}
.card:hover .card-img img{transform:scale(1.08)}
.card-body{padding:22px 24px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line)}
.card-body h3{margin:0;font-size:1.15rem}
.card-body span{color:var(--terracotta);font-size:.85rem;font-weight:600;letter-spacing:.05em}

/* ----- Features ----- */
.feature{padding:36px 28px;background:#fff;border-radius:var(--radius);border:1px solid var(--line);transition:transform .3s var(--t),border-color .3s var(--t)}
.feature:hover{transform:translateY(-4px);border-color:var(--terracotta)}
.feature .icon{font-size:2rem;color:var(--terracotta);margin-bottom:14px;display:inline-block}
.feature h3{font-size:1.2rem;margin-bottom:8px}
.feature p{color:var(--muted);margin:0;font-size:.95rem}

/* ----- Steps ----- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-top:40px}
.step{padding:30px 24px;background:#fff;border-radius:var(--radius);position:relative;border:1px solid var(--line)}
.step span{display:inline-block;font-family:var(--serif);font-size:2.4rem;color:var(--terracotta);line-height:1;margin-bottom:8px;font-weight:600}
.step h3{font-size:1.1rem;margin-bottom:6px}
.step p{font-size:.92rem;color:var(--muted);margin:0}

/* ----- Parallax ----- */
.parallax{position:relative;background-size:cover;background-position:center;background-attachment:fixed;color:#fff;padding:140px 0;text-align:center}
.parallax-overlay{position:absolute;inset:0;background:rgba(43,38,34,.55)}
.parallax-content{position:relative}
.parallax-content h2{color:#fff;font-style:italic;max-width:780px;margin:0 auto 14px}
.parallax-content p{color:rgba(255,255,255,.85);letter-spacing:.1em;text-transform:uppercase;font-size:.85rem}

/* ----- Masonry ----- */
.masonry{column-count:4;column-gap:18px;margin-bottom:40px}
.masonry img{width:100%;margin-bottom:18px;border-radius:var(--radius);break-inside:avoid;box-shadow:var(--shadow-sm);transition:transform .4s var(--t)}
.masonry img:hover{transform:scale(1.02)}
.masonry-lg{column-count:3;column-gap:22px}
.masonry-lg figure{margin:0 0 22px;break-inside:avoid;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);background:#fff;transition:transform .4s var(--t)}
.masonry-lg figure:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.masonry-lg img{width:100%;display:block}
.masonry-lg figcaption{padding:14px 18px;font-size:.88rem;color:var(--muted);font-style:italic}

/* ----- CTA band ----- */
.cta-band{background:linear-gradient(135deg,var(--terracotta) 0%,#d68066 100%);color:#fff;padding:90px 0;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.12),transparent 60%)}
.cta-inner{position:relative}
.cta-band h2{color:#fff;margin-bottom:14px}
.cta-band p{color:rgba(255,255,255,.9);max-width:600px;margin:0 auto 28px}
.cta-band .btn-primary{background:#fff;color:var(--terracotta-dark)}
.cta-band .btn-primary:hover{background:var(--ink);color:#fff}

/* ----- Lists ----- */
.check-list{list-style:none;padding:0;margin:1.5em 0}
.check-list li{padding:8px 0;border-bottom:1px dashed var(--line);display:flex;gap:10px;align-items:baseline}
.check-list li span{color:var(--terracotta);font-weight:700}

/* ----- Service cards ----- */
.service-card{padding:40px 32px;background:#fff;border-radius:var(--radius);border:1px solid var(--line);transition:all .3s var(--t)}
.service-card:hover{border-color:var(--terracotta);box-shadow:var(--shadow-md);transform:translateY(-4px)}
.service-card .price{margin-top:auto;color:var(--terracotta);font-family:var(--serif);font-size:1.35rem;font-weight:600;border-top:1px solid var(--line);padding-top:14px;margin-bottom:0}

/* ----- Timeline ----- */
.timeline{display:grid;gap:30px;max-width:760px;margin:40px auto 0;position:relative}
.timeline::before{content:"";position:absolute;left:80px;top:10px;bottom:10px;width:2px;background:var(--line)}
.t-item{display:grid;grid-template-columns:80px 1fr;gap:30px;padding-left:0;position:relative}
.t-item::before{content:"";position:absolute;left:74px;top:8px;width:14px;height:14px;border-radius:50%;background:var(--terracotta);box-shadow:0 0 0 4px var(--cream-2)}
.t-item span{font-family:var(--serif);font-size:1.4rem;color:var(--terracotta);font-weight:600;text-align:right}
.t-item h3{margin-bottom:6px;font-size:1.15rem}
.t-item p{margin:0;color:var(--muted);font-size:.95rem}

/* ----- FAQ ----- */
.faq{background:#fff;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:14px;padding:6px 26px;transition:border-color .3s var(--t)}
.faq[open]{border-color:var(--terracotta);box-shadow:var(--shadow-sm)}
.faq summary{font-family:var(--serif);font-size:1.2rem;font-weight:600;padding:18px 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.6rem;color:var(--terracotta);transition:transform .3s var(--t);font-family:var(--sans);line-height:1}
.faq[open] summary::after{transform:rotate(45deg)}
.faq p{padding:0 0 20px;color:var(--muted);margin:0}

/* ----- Contact form ----- */
.contact-form{background:#fff;padding:38px;border-radius:var(--radius);border:1px solid var(--line);display:flex;flex-direction:column;gap:18px;box-shadow:var(--shadow-sm)}
.contact-form label{display:flex;flex-direction:column;font-size:.85rem;font-weight:600;color:var(--ink);letter-spacing:.04em;text-transform:uppercase;gap:8px}
.contact-form input,.contact-form select,.contact-form textarea{padding:13px 16px;border:1.5px solid var(--line);border-radius:10px;font-family:var(--sans);font-size:1rem;background:var(--cream);color:var(--ink);transition:border-color .25s var(--t),background .25s var(--t);text-transform:none;letter-spacing:0;font-weight:400}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:0;border-color:var(--terracotta);background:#fff}
.contact-form textarea{resize:vertical;min-height:120px}

/* ----- Testimonial blockquotes ----- */
blockquote{margin:0;padding:30px 28px;background:#fff;border-radius:var(--radius);border-left:4px solid var(--terracotta);font-family:var(--serif);font-size:1.1rem;font-style:italic;color:var(--ink);line-height:1.6}
blockquote cite{display:block;margin-top:14px;font-style:normal;font-family:var(--sans);font-size:.82rem;color:var(--muted);letter-spacing:.05em;text-transform:uppercase}

/* ----- Legal ----- */
.legal h2{font-size:1.3rem;margin-top:2em}
.legal ul{padding-left:1.4em}
.legal li{margin-bottom:.4em}

/* ----- Footer ----- */
.site-footer{background:var(--ink);color:rgba(255,255,255,.78);padding:80px 0 30px;margin-top:60px}
.site-footer .brand-text strong,.site-footer .brand-text em{color:#fff}
.site-footer h4{color:#fff;margin-bottom:18px}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer ul li{margin-bottom:8px}
.site-footer a{color:rgba(255,255,255,.78)}
.site-footer a:hover{color:#fff}
.site-footer address{font-style:normal;line-height:1.8}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:50px;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-bottom{padding-top:24px;text-align:center;font-size:.85rem;color:rgba(255,255,255,.55)}
.footer-grid .muted{color:rgba(255,255,255,.6)}

/* ----- Cookie banner ----- */
.cookie-banner{position:fixed;bottom:20px;left:20px;right:20px;z-index:200;background:var(--ink);color:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:18px 22px;animation:slideUp .5s var(--t)}
@keyframes slideUp{from{transform:translateY(120%);opacity:0}to{transform:translateY(0);opacity:1}}
.cookie-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;padding:0}
.cookie-inner p{margin:0;font-size:.92rem;color:rgba(255,255,255,.85);flex:1;min-width:260px}
.cookie-inner a{color:#f5d3a3}
.cookie-actions{display:flex;gap:10px}
.cookie-actions .btn-ghost{color:rgba(255,255,255,.85)}
.cookie-actions .btn-ghost:hover{color:#fff}

/* ----- Back to top ----- */
#to-top{position:fixed;bottom:24px;right:24px;width:48px;height:48px;border-radius:50%;background:var(--terracotta);color:#fff;border:0;font-size:1.4rem;cursor:pointer;box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transform:translateY(20px);transition:all .3s var(--t);z-index:90}
#to-top.show{opacity:1;pointer-events:auto;transform:translateY(0)}
#to-top:hover{background:var(--terracotta-dark);transform:translateY(-3px)}

/* ----- Reveal animations ----- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--t),transform .8s var(--t)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ----- Responsive ----- */
@media (max-width:960px){
  .two-col,.grid-2,.grid-3{grid-template-columns:1fr}
  .steps{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
  .masonry{column-count:2}
  .masonry-lg{column-count:2}
  .nav-toggle{display:flex}
  .site-nav{position:fixed;top:0;right:0;bottom:0;width:80%;max-width:340px;background:var(--cream);flex-direction:column;align-items:flex-start;padding:90px 32px;gap:18px;transform:translateX(100%);transition:transform .4s var(--t);box-shadow:var(--shadow-lg)}
  .site-nav.open{transform:translateX(0)}
  .site-nav a{font-size:1.15rem;width:100%;padding:8px 0;border-bottom:1px solid var(--line)}
  .nav-cta{align-self:stretch;text-align:center}
  .hero-content{padding:80px 24px}
  .hero-stats{grid-template-columns:1fr;gap:18px;text-align:left}
  .section{padding:70px 0}
  .page-hero{padding:80px 0 50px}
  .parallax{background-attachment:scroll;padding:90px 0}
  .timeline::before{left:54px}
  .t-item{grid-template-columns:54px 1fr;gap:18px}
  .t-item::before{left:48px}
}
@media (max-width:560px){
  .masonry{column-count:1}
  .masonry-lg{column-count:1}
  .steps{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .cookie-actions{width:100%;justify-content:flex-end}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
  .reveal{opacity:1;transform:none}
}
