/* ============ Porto Travel — Custom Styles ============ */

:root{
  --cream:#faede3;
  --peach:#f6d9c6;
  --salmon:#fdcfb0;
  --blue:#9ab9e1;
  --blue-dark:#7ba2d4;
  --blue-soft:#e0ebf5;
  --azulejo:#2c4a86;
  --ink:#1c2530;
  --ink-2:#2a3340;
  --body:#33404e;
  --body-soft:#5a6675;
  --slate:#3d4a5c;
  --line:rgba(40,50,64,.22);
  --maxw:1200px;
  --serif:"Marcellus",Georgia,serif;
  --sans:"General Sans","Hanken Grotesk",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans);
  background:var(--peach);
  color:var(--body);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 1.85rem;}
.serif{font-family:var(--serif);font-weight:400;color:var(--ink);letter-spacing:-.01em;}
.eyebrow{font-size:13px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--body-soft);}

/* ============ placeholders ============ */
.ph{position:relative;overflow:hidden;background:#cdd9e6;}
.ph::before{
  content:"";position:absolute;inset:0;
  background-image:none;
}
.ph .ph-label{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:ui-monospace,"SF Mono",Menlo,monospace;font-size:11px;letter-spacing:.04em;
  color:rgba(255,255,255,.92);text-align:center;line-height:1.5;
  padding:7px 12px;border:1px solid rgba(255,255,255,.55);border-radius:6px;
  background:rgba(20,30,45,.30);backdrop-filter:blur(2px);max-width:78%;text-transform:uppercase;
}
.ph.sky{background:linear-gradient(180deg,#7fa9d4 0%,#a9c5e0 48%,#d7b79a 70%,#c98f63 100%);}
.ph.sunset{background:linear-gradient(160deg,#dab39a 0%,#cf9a78 45%,#b96f4d 100%);}
.ph.azul{background:linear-gradient(150deg,#dfe7f2 0%,#9fbbdf 55%,#5d80b8 100%);}
.ph.warm{background:linear-gradient(150deg,#e0a86f 0%,#c87a52 50%,#9c4f3e 100%);}
.ph.alley{background:linear-gradient(180deg,#8db4d8 0%,#c9905f 55%,#5a4a40 100%);}

/* ============ azulejo patterns ============ */
.azulejo-band{
  height:170px;width:100%;
  background:url("imedia/images/azulejo-band.png") center/cover repeat-x;
  opacity:.92;
}

/* ============ header ============ */
header.site{
  background:var(--cream);position:sticky;top:0;z-index:50;
  padding:0 1.85rem;
}
.header-inner{display:flex;align-items:stretch;max-width:1440px;margin:0 auto;}
.header-left{flex:1;display:flex;align-items:center;gap:48px;padding:22px 40px;}
.logo{display:flex;flex-direction:column;line-height:1;}
.logo .agency{font-size:8px;letter-spacing:.32em;color:var(--ink);font-weight:700;margin-bottom:1px;}
.logo .name{font-family:var(--serif);font-style:italic;font-weight:500;font-size:34px;color:#23406e;letter-spacing:-.01em;display:flex;align-items:baseline;}
.logo .name .dot{display:inline-block;width:9px;height:9px;border:2px solid #23406e;border-radius:50%;margin:0 1px;transform:translateY(-2px);}
nav.main{display:flex;gap:36px;}
nav.main a{font-size:15px;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);padding:6px 0;position:relative;transition:color .2s;white-space:nowrap;}
nav.main a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--ink);transition:width .25s;}
nav.main a:hover{color:#23406e;}
nav.main a:hover::after{width:100%;}
.consult{
  background:var(--salmon);color:var(--ink);
  display:flex;align-items:center;padding:0 56px;
  font-size:14px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;
  cursor:pointer;position:relative;overflow:hidden;
}
.consult span{position:relative;z-index:1;font-weight:500;}
.consult::before{
  content:"";position:absolute;inset:0;background:var(--blue-soft);
  transform:scaleX(0);transform-origin:left center;
  transition:transform .45s cubic-bezier(.7,0,.2,1);z-index:0;
}
.consult:hover::before{transform:scaleX(1);}

.hero .wrap{max-width:100%;margin:0;padding:0 1.85rem;}

/* ============ hero ============ */
.hero{padding:0 0 28px;}
.hero-img{
  position:relative;height:560px;border-radius:3px;overflow:hidden;
  color:#fff;
}
.hero-img::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(20,34,55,.42),rgba(20,34,55,.06) 60%);}
.hero-content{position:relative;z-index:2;padding:10% 6%;max-width:820px;}
.hero .eyebrow{color:rgba(255,255,255,.92);}
.hero h1{font-family:var(--serif);font-weight:300;color:#fff;font-size:60px;line-height:1.02;letter-spacing:-.02em;margin:24px 0 0;}
.hero .ph-label{left:auto;right:24px;top:auto;bottom:24px;transform:none;}
.hero .btn-cream{
  margin-top:38px;display:inline-flex;align-items:center;background:var(--cream);color:var(--ink);
  padding:22px 38px;font-size:14px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  border:1px solid rgba(20,34,55,.65);position:relative;overflow:hidden;
}
.hero .btn-cream span{position:relative;z-index:1;}
.hero .btn-cream::before{
  content:"";position:absolute;inset:0;background:var(--salmon);
  transform:scaleX(0);transform-origin:left center;
  transition:transform .45s cubic-bezier(.7,0,.2,1);z-index:0;
}
.hero .btn-cream:hover::before{transform:scaleX(1);}

/* ============ intro question ============ */
.intro{text-align:center;padding:46px 0 18px;}
.intro .kicker{font-weight:600;font-size:17px;color:var(--ink);margin-bottom:24px;}
.intro h2{font-family:var(--serif);font-weight:400;color:var(--ink);font-size:42px;line-height:1.16;max-width:900px;margin:0 auto;letter-spacing:-.01em;}

/* ============ features ============ */
.features{padding:54px 0 40px;}
.features .wrap{border-bottom:1px solid #2d3641;padding-bottom:40px;}
.feat-grid{display:grid;grid-template-columns:1fr 1fr;column-gap:0;}
.feat{display:flex;gap:30px;align-items:flex-start;padding:40px 50px;}
.feat:nth-child(odd){border-right:1px solid #2d3641;}
.feat.border-top{border-top:none;}
.feat .ico{flex:none;width:62px;height:62px;color:var(--ink);}
.feat .ico svg{width:100%;height:100%;}
.feat h4{font-size:25px;font-weight:500;color:var(--ink);font-family:var(--sans);margin-bottom:12px;letter-spacing:-.01em;}
.feat p{font-size:18px;color:var(--body);}
.feat p b{font-weight:700;color:var(--ink-2);}

/* ============ rooftop two-col ============ */
.rooftop{padding:64px 0 60px;}
.rooftop-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;}
.rooftop .ph{aspect-ratio:5/6;border-radius:18px;}
.rooftop h3{font-family:var(--serif);font-weight:400;font-size:36px;line-height:1.18;color:var(--ink);margin-bottom:26px;letter-spacing:-.01em;}
ul.checklist{list-style:none;display:flex;flex-direction:column;gap:18px;margin-bottom:30px;}
ul.checklist li{position:relative;padding-left:30px;font-size:19px;color:var(--body);line-height:1.45;}
ul.checklist li::before{content:"";position:absolute;left:6px;top:11px;width:7px;height:7px;border-radius:50%;background:var(--ink);}
.rooftop .lead{font-size:18px;color:var(--body);line-height:1.6;margin-bottom:34px;}
.btn-blue{
  display:inline-flex;align-items:center;justify-content:center;background:var(--blue);color:#fff;
  padding:20px 60px;font-size:14px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  border:none;cursor:pointer;transition:background .2s,transform .2s;border-radius:2px;
}
.btn-blue:hover{background:var(--blue-dark);transform:translateY(-2px);}

/* ============ about / über mich ============ */
.about{padding:48px 0 80px;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:start;}
.about .label{margin-bottom:18px;}
.about h3{font-family:var(--serif);font-weight:400;font-size:36px;line-height:1.12;color:var(--ink);margin-bottom:26px;letter-spacing:-.01em;}
.about p{font-size:18px;color:var(--body);line-height:1.6;}
.about p em{font-style:italic;}
.about-list{list-style:none;margin-top:14px;}
.about-list li{display:flex;gap:24px;align-items:flex-start;padding:22px 0;border-bottom:1px solid var(--line);}
.about-list li:first-child{border-top:1px solid var(--line);}
.about-list .ico{flex:none;width:46px;height:46px;color:var(--ink);}
.about-list .ico svg{width:100%;height:100%;}
.about-list span{font-family:var(--serif);font-weight:500;font-size:22px;line-height:1.2;color:var(--ink);}
/* right media */
.about-media{position:relative;}
.about-media .ph{aspect-ratio:4/5;border-radius:18px;}
.float-card{
  position:absolute;background:var(--cream);border:2px solid var(--blue);border-radius:22px;
  padding:22px 26px;text-align:center;box-shadow:0 18px 40px rgba(30,40,60,.18);
}
.float-stack{position:absolute;bottom:34px;left:50%;transform:translateX(-70%);width:62%;display:flex;flex-direction:column;gap:15px;}
.float-card.people{position:relative;bottom:auto;left:auto;transform:none;width:100%;}
.avatars{display:flex;justify-content:center;align-items:center;margin-bottom:14px;}
.avatars .av{width:58px;height:58px;border-radius:50%;border:3px solid var(--cream);margin-left:-12px;overflow:hidden;background:#b7c4d4;}
.avatars .av:first-child{margin-left:0;width:46px;height:46px;}
.avatars .av.sm{width:46px;height:46px;}
.avatars .av img{width:100%;height:100%;object-fit:cover;display:block;}
.float-card.people p{font-family:var(--serif);font-size:19px;color:var(--ink);line-height:1.3;}
.float-card.insider{
  position:relative;bottom:auto;left:auto;transform:none;width:100%;display:flex;align-items:center;gap:16px;justify-content:center;
  border:none;border-radius:18px;padding:18px 22px;
}
.float-card.insider svg{width:34px;height:34px;flex:none;color:var(--ink);}
.float-card.insider p{font-size:18px;color:var(--ink);font-weight:500;}

/* ============ tours ============ */
.tours{padding:30px 0 80px;}
.tours h3{text-align:center;font-family:var(--serif);font-weight:400;font-size:36px;color:var(--ink);margin-bottom:50px;}
.tour-grid{display:grid;grid-template-columns:1fr 1fr;gap:34px 34px;}
.tour-card{position:relative;display:flex;flex-direction:column;cursor:pointer;}
.tour-media{border-radius:14px;overflow:hidden;}
.tour-media .ph{aspect-ratio:16/10;transition:transform .5s ease;}
.tour-card:hover .tour-media .ph{transform:scale(1.05);}
.tour-info{
  position:absolute;bottom:20px;left:20px;right:20px;z-index:2;
  background:#fff;border-radius:14px;padding:26px 30px;box-shadow:0 16px 34px rgba(30,40,60,.14);
}
.tour-info .cap{font-size:15px;font-weight:300;letter-spacing:.06em;color:var(--body-soft);margin-bottom:10px;}
.tour-info .ttl{font-family:var(--serif);font-weight:400;font-size:27px;color:var(--ink);line-height:1.1;}
.tour-card.dark .tour-info{background:#fff;}
.tour-card.dark .tour-info .cap{color:var(--body-soft);}
.tour-card.dark .tour-info .ttl{color:var(--ink);}

/* expand on hover */
.tour-expand{
  max-height:none;overflow:visible;opacity:1;
}
.tour-card:hover .tour-expand{max-height:none;opacity:1;}
.tour-expand-inner{padding-top:18px;display:flex;flex-direction:column;gap:12px;}
.tour-price{font-family:var(--serif);font-size:22px;color:var(--ink);font-weight:400;}
.tour-card.dark .tour-price{color:var(--ink);}
.tour-meta-row{display:flex;gap:22px;}
.tour-meta-item{display:flex;flex-direction:column;gap:2px;}
.tour-meta-item .lbl{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--body-soft);}
.tour-card.dark .tour-meta-item .lbl{color:var(--body-soft);}
.tour-meta-item .val{font-size:14px;color:var(--ink);font-weight:500;}
.tour-card.dark .tour-meta-item .val{color:var(--ink);}
.tour-desc{font-size:16px;color:var(--body);line-height:1.5;}
.tour-card.dark .tour-desc{color:var(--body);}
.tour-book{
  display:inline-flex;align-items:center;justify-content:center;width:100%;
  background:var(--salmon);color:var(--ink);border:none;border-radius:9px;
  padding:14px 20px;font-size:12px;font-weight:500;letter-spacing:.13em;text-transform:uppercase;
  cursor:pointer;position:relative;overflow:hidden;margin-top:4px;
}
.tour-book span{position:relative;z-index:1;}
.tour-book::before{
  content:"";position:absolute;inset:0;background:var(--blue-soft);border-radius:9px;
  transform:scaleX(0);transform-origin:left center;
  transition:transform .45s cubic-bezier(.7,0,.2,1);z-index:0;
}
.tour-book:hover::before{transform:scaleX(1);}

/* ============ contact ============ */
.contact{background:var(--blue-soft);padding:90px 0 96px;}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:start;}
.contact .label{color:var(--body-soft);margin-bottom:24px;}
.contact h3{font-family:var(--serif);font-weight:400;font-size:36px;line-height:1.02;color:var(--ink);margin-bottom:30px;letter-spacing:-.02em;}
.contact .lead{font-size:18px;color:var(--body);line-height:1.6;margin-bottom:40px;max-width:480px;}
form .field{margin-bottom:20px;}
form label{display:block;font-size:19px;color:var(--body-soft);}
form input,form textarea{
  width:100%;border:none;border-bottom:1px solid #9fb4cf;background:transparent;
  font-family:var(--sans);font-size:17px;color:var(--ink);padding:4px 0 10px;outline:none;transition:border-color .2s;
}
form textarea{resize:vertical;min-height:96px;}
form input:focus,form textarea:focus{border-color:var(--ink);}
form .field.invalid input,form .field.invalid textarea{border-color:#c0563f;}
.req-note{font-size:18px;color:var(--ink);margin:8px 0 28px;}
.req-note.err{color:#c0563f;font-weight:600;}
.req-note.ok{color:#2f7d52;font-weight:600;}
.btn-outline{
  display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--ink);
  border:1px solid var(--ink);padding:20px 44px;font-size:14px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  cursor:pointer;transition:background .2s,color .2s;
}
.btn-outline:hover{background:var(--ink);color:var(--blue-soft);}
.contact-media{position:relative;}
.contact-media .ph{aspect-ratio:3/4.1;border-radius:18px;color:#fff;}
.contact-media .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,30,45,0) 45%,rgba(15,22,34,.66));}
.contact-media .cap{
  position:absolute;z-index:3;left:34px;right:34px;bottom:42px;text-align:center;
  color:#fff;font-size:24px;font-family:var(--sans);font-weight:400;line-height:1.35;
}

/* ============ footer ============ */
footer.site{position:relative;background:url("imedia/images/footer-tiles.png") center/cover no-repeat;color:#e9eef5;overflow:hidden;}
footer.site::before{
  content:"";position:absolute;inset:0;opacity:.92;
  background:var(--slate);
}
.footer-inner{position:relative;z-index:2;padding:80px 0 36px;}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:50px;}
.footer-top h3{font-family:var(--serif);font-weight:400;font-size:36px;line-height:1.05;color:#f3e9df;margin-bottom:28px;letter-spacing:-.01em;}
.footer-top p{font-size:18px;color:#dfe6ef;line-height:1.55;max-width:460px;margin-bottom:34px;}
.follow{display:flex;align-items:center;gap:22px;}
.follow .lbl{font-size:20px;color:#eef2f8;}
.follow .icons{display:flex;gap:16px;}
.follow .icons a{width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:#dfe6ef;transition:color .2s,transform .2s;}
.follow .icons a:hover{color:#fff;transform:translateY(-2px);}
.follow .icons svg{width:22px;height:22px;}
.footer-col h4{font-size:14px;letter-spacing:.14em;text-transform:uppercase;color:#90a8c8;font-weight:700;margin-bottom:26px;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:16px;}
.footer-col li{font-size:19px;color:#e6ecf4;}
.footer-col li a{transition:color .2s;}
.footer-col li a:hover{color:#fff;}
.footer-rule{height:1px;background:rgba(174,191,214,.4);margin:54px 0 28px;}
.footer-bottom{display:flex;justify-content:space-between;font-size:18px;color:#dfe6ef;}
.footer-bottom .links{display:flex;gap:8px;}
.footer-bottom a:hover{color:#fff;}

/* ============ booking calendar modal ============ */
.cal-overlay{
  position:fixed;inset:0;z-index:100;display:none;
  align-items:center;justify-content:center;padding:28px;
  background:rgba(22,30,45,.52);backdrop-filter:blur(3px);
  opacity:0;transition:opacity .3s ease;
}
.cal-overlay.open{display:flex;opacity:1;}
.cal-modal{
  background:var(--cream);width:100%;max-width:980px;max-height:90vh;overflow:hidden;
  border-radius:6px;box-shadow:0 30px 80px rgba(15,22,34,.45);
  display:grid;grid-template-columns:1.05fr 1fr;
  transform:translateY(18px) scale(.985);transition:transform .35s cubic-bezier(.7,0,.2,1);
}
.cal-overlay.open .cal-modal{transform:none;}
.cal-close{
  position:absolute;top:18px;right:18px;width:42px;height:42px;border-radius:50%;
  border:1px solid rgba(20,34,55,.4);background:var(--cream);color:var(--ink);
  display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:3;transition:background .2s,transform .2s;
}
.cal-close:hover{background:var(--salmon);transform:rotate(90deg);}
.cal-close svg{width:18px;height:18px;}
.cal-left{padding:42px 40px 40px;border-right:1px solid var(--line);display:flex;flex-direction:column;}
.cal-left .eyebrow{margin-bottom:12px;}
.cal-left h3{font-family:var(--serif);font-weight:400;font-size:30px;color:var(--ink);line-height:1.1;letter-spacing:-.01em;margin-bottom:26px;}
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;}
.cal-nav .month{font-family:var(--serif);font-size:22px;color:var(--ink);text-transform:capitalize;}
.cal-nav button{
  width:38px;height:38px;border-radius:50%;border:1px solid rgba(20,34,55,.32);
  background:transparent;color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,opacity .2s;
}
.cal-nav button:hover{background:var(--peach);}
.cal-nav button[disabled]{opacity:.3;cursor:default;background:transparent;}
.cal-nav button svg{width:16px;height:16px;}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px;}
.cal-dow span{text-align:center;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--body-soft);}
.cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;}
.cal-day{
  aspect-ratio:1;border:none;background:transparent;border-radius:9px;cursor:pointer;
  font-family:var(--sans);font-size:15px;font-weight:600;color:var(--ink);position:relative;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;transition:background .18s,color .18s;
}
.cal-day.empty{cursor:default;}
.cal-day.muted{color:rgba(28,37,48,.28);cursor:default;}
.cal-day.has:hover{background:var(--peach);}
.cal-day .dot{width:5px;height:5px;border-radius:50%;background:var(--blue-dark);position:absolute;bottom:7px;}
.cal-day.muted .dot{display:none;}
.cal-day.selected{background:var(--azulejo);color:#fff;}
.cal-day.selected .dot{background:#fff;}
.cal-legend{display:flex;align-items:center;gap:8px;margin-top:auto;padding-top:22px;font-size:13px;color:var(--body-soft);}
.cal-legend .dot{width:6px;height:6px;border-radius:50%;background:var(--blue-dark);}
.cal-right{padding:42px 40px 40px;background:var(--blue-soft);display:flex;flex-direction:column;overflow:hidden;}
.cal-right .sel-date{font-family:var(--serif);font-size:24px;color:var(--ink);line-height:1.15;margin-bottom:4px;}
.cal-right .sel-sub{font-size:14px;color:var(--body-soft);margin-bottom:24px;}
.cal-tours{display:flex;flex-direction:column;gap:14px;overflow-y:auto;padding-right:4px;flex:1;}
.cal-tour{
  display:flex;gap:16px;align-items:center;background:#fff;border-radius:12px;padding:14px;
  box-shadow:0 6px 18px rgba(30,40,60,.08);transition:transform .25s ease,box-shadow .25s ease;
}
.cal-tour:hover{transform:translateX(3px);box-shadow:0 10px 24px rgba(30,40,60,.16);}
.cal-tour .swatch{flex:none;width:62px;height:62px;border-radius:9px;}
.cal-tour .body{flex:1;min-width:0;}
.cal-tour .t-time{font-size:12px;font-weight:700;letter-spacing:.08em;color:var(--blue-dark);text-transform:uppercase;margin-bottom:3px;}
.cal-tour .t-ttl{font-family:var(--serif);font-size:18px;color:var(--ink);line-height:1.12;margin-bottom:4px;}
.cal-tour .t-meta{font-size:13px;color:var(--body-soft);}
.cal-tour .pick{
  flex:none;align-self:stretch;display:flex;align-items:center;background:var(--salmon);color:var(--ink);
  border:none;border-radius:8px;padding:0 16px;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:background .2s;white-space:nowrap;
}
.cal-tour .pick:hover{background:var(--blue);color:#fff;}
.cal-empty-msg{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;flex:1;color:var(--body-soft);gap:14px;padding:20px;}
.cal-empty-msg svg{width:46px;height:46px;color:var(--blue-dark);opacity:.7;}
.cal-empty-msg p{font-size:16px;line-height:1.5;max-width:240px;}
.cal-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;flex:1;color:var(--body-soft);gap:16px;}
.cal-placeholder svg{width:54px;height:54px;color:var(--blue-dark);opacity:.6;}
.cal-placeholder p{font-size:16px;line-height:1.5;max-width:260px;}

/* ============ scroll rise animation ============ */
.rise{
  opacity:0;
  transform:translateY(44px);
  transition:opacity .7s cubic-bezier(.4,0,.2,1), transform .7s cubic-bezier(.4,0,.2,1);
}
.rise.in-view{opacity:1;transform:none;}
.rise-delay-1{transition-delay:.1s;}
.rise-delay-2{transition-delay:.2s;}
.rise-delay-3{transition-delay:.3s;}
.rise-delay-4{transition-delay:.4s;}
@media(prefers-reduced-motion:reduce){
  .rise{opacity:1;transform:none;transition:none;}
}

/* ============ responsive ============ */
@media(max-width:760px){
  .cal-modal{grid-template-columns:1fr;max-height:92vh;overflow-y:auto;}
  .cal-left{border-right:none;border-bottom:1px solid var(--line);}
  .cal-tours{max-height:none;}
}
@media(max-width:900px){
  .wrap{padding:0 22px;}
  nav.main,.header-left{gap:24px;}
  nav.main{display:none;}
  .consult{padding:0 28px;}
  .hero h1{font-size:48px;}
  .hero-img{height:auto;min-height:420px;}
  .hero-content{padding:40px 26px;}
  .intro h2{font-size:30px;}
  .feat-grid{grid-template-columns:1fr;}
  .feat{border-right:none !important;border-top:none !important;padding:20px 0;}
  .feat.border-top{border-top:none !important;}
  .rooftop-grid,.about-grid,.tour-grid,.contact-grid,.footer-top{grid-template-columns:1fr;gap:40px;}
  .about h3{font-size:28px;}
  .contact h3{font-size:32px;}
  .footer-top h3{font-size:28px;}
  .footer-bottom{flex-direction:column;gap:14px;}
  .hero h1 br{display:none;}
}
