/* Petualang Muda — open trip anak muda. Palet: #06b6d4 (cyan) + #f43f5e (rose), light. */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --cyan:#06b6d4; --cyan-d:#0891b2; --cyan-l:#cffafe;
  --rose:#f43f5e; --rose-d:#e11d48; --rose-l:#ffe4e6;
  --ink:#0f3a44; --muted:#4b6a72; --bg:#f7feff; --card:#ffffff; --line:#d6f1f6;
  --shadow:0 10px 30px rgba(6,182,212,.12);
  --radius:18px;
}
html{scroll-behavior:smooth}
body{
  font-family:-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--ink); background:var(--bg); line-height:1.65; -webkit-font-smoothing:antialiased;
}
a{color:var(--cyan-d);text-decoration:none}
img{max-width:100%}

/* Demo bar */
.demobar{
  background:linear-gradient(90deg,var(--cyan),var(--rose));
  color:#fff;font-size:13.5px;text-align:center;padding:7px 12px;letter-spacing:.2px
}
.demobar a{color:#fff;text-decoration:underline;font-weight:600}
.demobar b{font-weight:800}

/* Header */
.site-head{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line)
}
.nav{
  max-width:1120px;margin:0 auto;display:flex;align-items:center;
  justify-content:space-between;padding:12px 18px;gap:12px
}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:19px;color:var(--ink)}
.brand .logo{
  width:38px;height:38px;border-radius:12px;flex:0 0 auto;
  background:linear-gradient(135deg,var(--cyan),var(--rose));
  display:grid;place-items:center;box-shadow:var(--shadow)
}
.brand small{display:block;font-size:11px;font-weight:600;color:var(--cyan-d);letter-spacing:.4px}
#nav{display:none}
.burger{display:none;cursor:pointer;width:42px;height:42px;border-radius:12px;border:1px solid var(--line);place-items:center;background:#fff}
.burger span,.burger span::before,.burger span::after{
  content:"";display:block;width:20px;height:2px;background:var(--ink);position:relative;transition:.2s
}
.burger span::before{position:absolute;top:-6px}
.burger span::after{position:absolute;top:6px}
.menu{list-style:none;display:flex;align-items:center;gap:6px}
.menu a{
  display:block;padding:9px 13px;border-radius:11px;font-weight:600;color:var(--muted);font-size:15px
}
.menu a:hover{background:var(--cyan-l);color:var(--cyan-d)}
.menu a.active{background:var(--cyan);color:#fff}
.menu .cta{
  background:var(--rose);color:#fff;box-shadow:0 6px 16px rgba(244,63,94,.3)
}
.menu .cta:hover{background:var(--rose-d);color:#fff}

@media(max-width:820px){
  .burger{display:grid}
  .menu{
    position:absolute;left:0;right:0;top:100%;flex-direction:column;align-items:stretch;
    background:#fff;border-bottom:1px solid var(--line);padding:10px 14px;gap:4px;
    box-shadow:var(--shadow);display:none
  }
  .menu a{padding:12px}
  #nav:checked ~ .menu{display:flex}
  .nav{position:relative;flex-wrap:wrap}
}

/* Layout */
main{max-width:1120px;margin:0 auto;padding:0 18px}
section{padding:54px 0}
.eyebrow{
  display:inline-block;font-size:12.5px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--rose-d);background:var(--rose-l);padding:5px 12px;border-radius:999px;margin-bottom:14px
}
h1{font-size:clamp(30px,6vw,52px);line-height:1.08;letter-spacing:-.02em;font-weight:850}
h2{font-size:clamp(24px,4vw,34px);line-height:1.15;letter-spacing:-.01em;font-weight:800;margin-bottom:6px}
h3{font-size:19px;font-weight:800}
.lead{font-size:18px;color:var(--muted);max-width:60ch}
.sec-head{max-width:62ch;margin-bottom:30px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:8px;font-weight:700;cursor:pointer;
  padding:13px 22px;border-radius:13px;border:0;font-size:15.5px;transition:.18s;font-family:inherit
}
.btn-primary{background:var(--cyan);color:#fff;box-shadow:0 8px 20px rgba(6,182,212,.32)}
.btn-primary:hover{background:var(--cyan-d);transform:translateY(-1px)}
.btn-rose{background:var(--rose);color:#fff;box-shadow:0 8px 20px rgba(244,63,94,.3)}
.btn-rose:hover{background:var(--rose-d);transform:translateY(-1px)}
.btn-ghost{background:#fff;color:var(--cyan-d);border:1.5px solid var(--cyan)}
.btn-ghost:hover{background:var(--cyan-l)}
.btn-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}

/* Hero */
.hero{position:relative;overflow:hidden;padding-top:30px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.hero p.lead{margin-top:16px}
.hero-stats{display:flex;gap:26px;margin-top:30px;flex-wrap:wrap}
.hero-stats div b{display:block;font-size:26px;color:var(--cyan-d);font-weight:850;line-height:1}
.hero-stats div span{font-size:13px;color:var(--muted)}
.hero-art{
  position:relative;height:360px;border-radius:26px;overflow:hidden;
  background:
    radial-gradient(120% 90% at 80% 0%,var(--rose-l),transparent 55%),
    linear-gradient(150deg,var(--cyan),var(--cyan-d) 60%,#155e75);
  box-shadow:var(--shadow)
}
.hero-art .peak{position:absolute;bottom:0;left:0;right:0}
.hero-art .sun{
  position:absolute;top:42px;right:54px;width:84px;height:84px;border-radius:50%;
  background:radial-gradient(circle,#fff,var(--rose) 75%);box-shadow:0 0 60px rgba(255,255,255,.6)
}
.hero-art .badge{
  position:absolute;top:22px;left:22px;background:rgba(255,255,255,.92);color:var(--ink);
  font-weight:800;font-size:13px;padding:8px 14px;border-radius:999px;box-shadow:var(--shadow)
}
@media(max-width:820px){.hero-grid{grid-template-columns:1fr;gap:26px}.hero-art{height:260px;order:-1}}

/* Cards / grids */
.grid{display:grid;gap:20px}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.g3,.g4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.g2,.g3,.g4{grid-template-columns:1fr}}

.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;transition:.2s
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--cyan-l)}
.icon{
  width:48px;height:48px;border-radius:13px;display:grid;place-items:center;margin-bottom:14px;
  background:var(--cyan-l);color:var(--cyan-d)
}
.card p{color:var(--muted);margin-top:6px}

/* Trip / paket card */
.trip{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:.2s
}
.trip:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.trip .ph{height:160px;position:relative;color:#fff}
.trip .ph .tag{position:absolute;left:14px;top:14px;background:rgba(255,255,255,.92);color:var(--rose-d);font-weight:800;font-size:12px;padding:5px 11px;border-radius:999px}
.trip .ph .dur{position:absolute;right:14px;bottom:14px;background:rgba(15,58,68,.6);font-weight:700;font-size:12px;padding:4px 10px;border-radius:999px}
.trip .body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:8px;flex:1}
.trip .body h3{font-size:18px}
.trip .where{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px}
.trip ul{list-style:none;font-size:13.5px;color:var(--muted);display:grid;gap:4px;margin:6px 0}
.trip ul li{display:flex;gap:7px;align-items:flex-start}
.trip ul li svg{flex:0 0 auto;margin-top:3px;color:var(--cyan)}
.trip .price{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px dashed var(--line)}
.trip .price b{font-size:21px;color:var(--ink)}
.trip .price small{color:var(--muted);font-size:12px}

/* gradient fills for placeholders */
.gd1{background:linear-gradient(140deg,#06b6d4,#0e7490)}
.gd2{background:linear-gradient(140deg,#f43f5e,#be123c)}
.gd3{background:linear-gradient(140deg,#22d3ee,#0891b2)}
.gd4{background:linear-gradient(140deg,#fb7185,#0891b2)}
.gd5{background:linear-gradient(140deg,#14b8a6,#06b6d4)}
.gd6{background:linear-gradient(140deg,#f97316,#f43f5e)}

/* steps */
.steps{counter-reset:s;display:grid;gap:18px;grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.steps{grid-template-columns:1fr}}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;position:relative}
.step::before{
  counter-increment:s;content:counter(s);font-weight:850;font-size:15px;color:#fff;
  width:34px;height:34px;border-radius:10px;display:grid;place-items:center;
  background:var(--rose);margin-bottom:12px
}

/* feature band */
.band{
  background:linear-gradient(135deg,var(--cyan),var(--cyan-d));color:#fff;border-radius:26px;
  padding:46px 38px;margin:10px 0
}
.band h2{color:#fff}
.band .lead{color:#cffafe}
.band .btn-row .btn-ghost{background:#fff;border-color:#fff}

/* testimonials */
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.quote p{font-size:15.5px}
.quote .who{display:flex;align-items:center;gap:12px;margin-top:16px}
.quote .av{width:44px;height:44px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;color:#fff;font-weight:800}
.stars{color:var(--rose);letter-spacing:2px;font-size:14px}

/* gallery */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:760px){.gal{grid-template-columns:repeat(2,1fr)}}
.gal figure{position:relative;border-radius:16px;overflow:hidden;height:200px;color:#fff}
.gal figure figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:26px 14px 12px;font-weight:700;font-size:14px;
  background:linear-gradient(transparent,rgba(15,58,68,.7))
}
.gal .tall{grid-row:span 2;height:auto}

/* destinasi list */
.dest{display:flex;gap:18px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px;flex-wrap:wrap}
.dest .thumb{width:120px;height:90px;border-radius:13px;flex:0 0 auto;color:#fff;position:relative}
.dest .info{flex:1;min-width:200px}
.dest .info h3{font-size:18px}
.dest .info p{color:var(--muted);font-size:14px;margin-top:4px}
.dest .meta{display:flex;gap:14px;font-size:12.5px;color:var(--cyan-d);font-weight:700;margin-top:8px;flex-wrap:wrap}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}
form{display:grid;gap:14px}
label{font-weight:700;font-size:14px;display:block;margin-bottom:6px}
input,select,textarea{
  width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;font-size:15px;
  font-family:inherit;background:#fff;color:var(--ink)
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-l)}
.formnote{font-size:12.5px;color:var(--rose-d);font-weight:700}
.infoline{display:flex;gap:13px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--line)}
.infoline .ic{width:40px;height:40px;border-radius:11px;flex:0 0 auto;display:grid;place-items:center;background:var(--cyan-l);color:var(--cyan-d)}
.infoline b{display:block}
.infoline span{color:var(--muted);font-size:14px}

/* faq */
.faq details{background:#fff;border:1px solid var(--line);border-radius:14px;padding:4px 18px;margin-bottom:10px}
.faq summary{font-weight:700;cursor:pointer;padding:14px 0;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--cyan-d);font-weight:800;font-size:20px}
.faq details[open] summary::after{content:"−"}
.faq p{color:var(--muted);padding-bottom:14px}

/* pills */
.pills{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px}
.pill{padding:8px 16px;border-radius:999px;border:1.5px solid var(--line);font-weight:700;font-size:14px;color:var(--muted);background:#fff}
.pill.on{background:var(--cyan);color:#fff;border-color:var(--cyan)}

/* page hero (inner) */
.phero{
  background:radial-gradient(110% 120% at 90% 0%,var(--rose-l),transparent 50%),var(--cyan-l);
  border-radius:0 0 30px 30px;margin-bottom:10px
}
.phero .wrap{max-width:1120px;margin:0 auto;padding:46px 18px}

/* footer */
.site-foot{background:#063b46;color:#cfeef3;margin-top:50px}
.foot-grid{max-width:1120px;margin:0 auto;padding:50px 18px 26px;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr;gap:24px}}
.site-foot h4{color:#fff;font-size:15px;margin-bottom:14px;letter-spacing:.5px}
.site-foot a{color:#9fe2ec;display:block;padding:5px 0;font-size:14.5px}
.site-foot a:hover{color:#fff}
.site-foot .brand{color:#fff}
.site-foot .brand small{color:var(--cyan)}
.foot-about{font-size:14px;color:#9fc8cf;margin-top:14px;max-width:38ch}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding:16px 18px;text-align:center;font-size:13px;color:#85b6bd}
.social{display:flex;gap:10px;margin-top:14px}
.social a{width:38px;height:38px;border-radius:11px;background:rgba(255,255,255,.08);display:grid;place-items:center}
.social a:hover{background:var(--cyan)}

.cluster{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.muted{color:var(--muted)}
.center{text-align:center}
