/* FerryOS Mobile App Experience + PageSpeed Responsive Pack — 2026-05-30 */
:root{
  --mob-safe-top:env(safe-area-inset-top,0px);
  --mob-safe-right:env(safe-area-inset-right,0px);
  --mob-safe-bottom:env(safe-area-inset-bottom,0px);
  --mob-safe-left:env(safe-area-inset-left,0px);
  --mob-header-h:64px;
  --mob-bottom-nav-h:72px;
  --mob-radius:18px;
  --mob-tap:46px;
  --mob-shadow:0 16px 42px rgba(15,23,42,.14);
  --mob-border:rgba(15,23,42,.09);
  --mob-bg:#f7f9fc;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{touch-action:manipulation;-webkit-tap-highlight-color:transparent;background:var(--mob-bg)}
img,picture,video,canvas,svg{max-width:100%;height:auto}iframe{max-width:100%;border:0}
button,a,input,select,textarea{touch-action:manipulation}input,select,textarea{font-size:16px;max-width:100%}
button,.btn,.btn-sm,.btn-primary,.btn-outline,.nav-btn,.btn-search,.mobile-toggle,[role=button],input[type=submit]{min-height:44px;min-width:44px}
.container{width:min(100% - 32px,1240px)}
main{min-height:calc(100vh - 160px)}
.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}.skip-link:focus{position:fixed;left:12px;top:12px;width:auto;height:auto;z-index:99999;background:#fff;color:#0f172a;padding:10px 14px;border-radius:12px;box-shadow:var(--mob-shadow)}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}
@media (max-width:1024px){
  .container{width:min(100% - 28px,960px);padding-left:0;padding-right:0}
  .sec,.wsec{padding:42px 0}.hero{padding:36px 0 46px}.hero-title{font-size:clamp(2rem,7vw,2.6rem);line-height:1.08}.hero-sub{font-size:1rem;margin-bottom:24px}
  .tg,.eg,.rg,.wg,.home-dest-grid,.blog-grid,.dest-grid,.cards-grid,.packages-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:14px!important}
}
@media (max-width:768px){
  body{padding-bottom:calc(var(--mob-bottom-nav-h) + var(--mob-safe-bottom) + 10px)}
  .site-header{position:sticky;top:0;z-index:2000;padding-top:var(--mob-safe-top);backdrop-filter:saturate(160%) blur(16px);box-shadow:0 8px 28px rgba(2,8,23,.18)}
  .header-inner{min-height:var(--mob-header-h);padding:10px max(14px,var(--mob-safe-right)) 10px max(14px,var(--mob-safe-left));gap:10px}
  .logo{font-size:1.2rem;min-width:0;max-width:calc(100vw - 86px);overflow:hidden;text-overflow:ellipsis}.logo img{max-height:34px}.logo-slogan{display:none!important}
  .mobile-toggle{display:flex!important;align-items:center;justify-content:center;width:46px;height:46px;border-radius:14px;background:rgba(255,255,255,.12)!important;border:1px solid rgba(255,255,255,.18)!important;font-size:1.35rem;line-height:1;z-index:2102}
  .nav-links{position:fixed;inset:calc(var(--mob-safe-top) + 76px) max(12px,var(--mob-safe-right)) auto max(12px,var(--mob-safe-left));display:grid!important;grid-template-columns:1fr 1fr;gap:10px;max-height:calc(100dvh - 96px - var(--mob-safe-bottom));overflow:auto;background:rgba(255,255,255,.96);backdrop-filter:blur(18px);border:1px solid rgba(148,163,184,.22);border-radius:24px;box-shadow:var(--mob-shadow);padding:14px;opacity:0;transform:translateY(-12px) scale(.98);pointer-events:none;transition:opacity .18s ease,transform .18s ease;z-index:2101}
  .nav-links.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
  .nav-links a{display:flex!important;align-items:center;justify-content:center;min-height:50px;padding:12px 10px!important;color:#0f172a!important;background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;text-align:center;font-size:.94rem;font-weight:750;box-shadow:0 1px 0 rgba(255,255,255,.9) inset}
  .nav-links a.active{background:#e0f2fe!important;color:#0369a1!important;border-color:#7dd3fc}.nav-links .nav-btn{grid-column:1/-1;background:linear-gradient(135deg,#0284c7,#0369a1)!important;color:#fff!important;border:0!important}
  .hdr-selectors{grid-column:1/-1;display:grid!important;grid-template-columns:1fr 1fr;margin-top:0!important}.hdr-sel,.hdr-sel-flag-wrap{width:100%}.hdr-sel{background-color:#0f172a!important;border-color:#1e293b!important;color:#fff!important;border-radius:14px!important;min-height:48px!important}
  .hero{border-radius:0 0 28px 28px}.sbox,.page-search,.checkout-card,.panel-card,.card,.tc,.ec,.rc,.wc,.booking-card,.result-card,.filter-card{border-radius:var(--mob-radius)!important;box-shadow:0 10px 28px rgba(15,23,42,.08)!important}
  .sbox{padding:18px!important;margin:0 auto;width:100%}.stabs{overflow:auto;scroll-snap-type:x mandatory;padding:5px}.stab{min-width:max-content;scroll-snap-align:start;white-space:nowrap}.trip-type{display:grid;grid-template-columns:1fr 1fr;gap:8px}.trip-r{min-height:44px;border:1px solid #e2e8f0;border-radius:14px;padding:10px 12px;background:#fff}
  .srow,.popts,.form-row,.checkout-row,.filter-row{display:grid!important;grid-template-columns:1fr!important;gap:12px!important}.sf,.pf,.form-group,.field{min-width:0!important;width:100%!important;flex:unset!important}.swap-btn{width:46px;height:46px;margin:0 auto!important;align-self:center;transform:rotate(90deg)}
  .sec-h{display:block;margin-bottom:18px}.sec-h h2{font-size:1.35rem;line-height:1.2}.sec-h a{display:inline-flex;margin-top:8px;min-height:40px;align-items:center}
  .tg,.eg,.rg,.wg,.home-dest-grid,.blog-grid,.dest-grid,.cards-grid,.packages-grid{grid-template-columns:1fr!important;gap:14px!important}.tc,.ec,.rc{transform:none!important}.rc{align-items:flex-start;flex-direction:column}.rprice{text-align:left}.timg{height:166px}.ec{min-height:auto}.epr,.tfoot{align-items:center}
  table{width:100%;border-collapse:collapse}.table-responsive,.responsive-table,.orders-table-wrap,.data-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:16px;border:1px solid #e5edf6}table th,table td{white-space:nowrap;padding:12px 10px}
  .sfooter{margin-top:24px;padding-bottom:calc(22px + var(--mob-safe-bottom))}.fgrid{grid-template-columns:1fr!important;gap:16px!important}.fcol a{min-height:36px;display:flex;align-items:center}.fbot{display:grid!important;gap:10px;text-align:center}.fcur{justify-content:center;flex-wrap:wrap}
  .mobile-app-dock{display:grid!important}
}
@media (max-width:420px){
  .container{width:min(100% - 22px,390px)}.header-inner{padding-left:10px;padding-right:10px}.hero-title{font-size:1.8rem}.hero-sub{font-size:.95rem}.sbox{padding:14px!important}.nav-links{grid-template-columns:1fr}.hdr-selectors{grid-template-columns:1fr}.mobile-app-dock{grid-template-columns:repeat(5,1fr)!important}.mobile-app-dock a{font-size:10px}.mobile-app-dock .dock-icon{font-size:18px}.hide-xs{display:none!important}
}
.mobile-app-dock{display:none;position:fixed;left:max(10px,var(--mob-safe-left));right:max(10px,var(--mob-safe-right));bottom:max(8px,var(--mob-safe-bottom));grid-template-columns:repeat(6,1fr);gap:4px;z-index:1990;background:rgba(255,255,255,.93);backdrop-filter:blur(18px);border:1px solid rgba(148,163,184,.28);border-radius:22px;padding:8px;box-shadow:0 18px 50px rgba(15,23,42,.18)}
.mobile-app-dock a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:54px;border-radius:16px;color:#475569;font-size:11px;font-weight:800;letter-spacing:-.01em}.mobile-app-dock a.active,.mobile-app-dock a:focus-visible{background:#e0f2fe;color:#0369a1;outline:0}.mobile-app-dock .dock-icon{font-size:20px;line-height:1}.mobile-app-dock a:active{transform:scale(.97)}
.mobile-scroll-top{position:fixed;right:max(16px,var(--mob-safe-right));bottom:calc(var(--mob-bottom-nav-h) + var(--mob-safe-bottom) + 20px);width:46px;height:46px;border-radius:50%;border:0;background:#0f172a;color:#fff;box-shadow:var(--mob-shadow);z-index:1980;display:none;align-items:center;justify-content:center}.mobile-scroll-top.is-visible{display:flex}
@media (min-width:769px){.mobile-app-dock,.mobile-scroll-top{display:none!important}}
@supports (content-visibility:auto){.sec,.wsec,.sfooter,.tc,.ec,.rc,.wc{content-visibility:auto;contain-intrinsic-size:1px 420px}}


/* FerryOS Public Frontend Mobile Polish — tours, cruise and hero search — 2026-05-30b */
@media (max-width:768px){
  .hero .sbox{padding:14px!important;border-radius:22px!important}
  #tab-ferry .home-route-row{display:grid!important;grid-template-columns:minmax(0,1fr) minmax(0,1fr) 48px!important;gap:8px!important;align-items:end!important;margin-top:12px!important}
  #tab-ferry .home-route-row .route-from{order:1!important}
  #tab-ferry .home-route-row .route-to{order:2!important}
  #tab-ferry .home-route-row .swap-btn{order:3!important;width:48px!important;height:48px!important;margin:0!important;align-self:end!important;justify-self:end!important;transform:none!important;border-radius:16px!important;font-size:1.05rem!important;background:#fff!important;border:1px solid #dbe7f3!important;box-shadow:0 8px 22px rgba(15,23,42,.08)!important}
  #tab-ferry .home-route-row .sf label{font-size:.72rem!important;letter-spacing:.04em;margin-bottom:6px!important;white-space:nowrap!important}
  #tab-ferry .home-route-row select{height:48px!important;min-height:48px!important;padding:0 30px 0 11px!important;border-radius:14px!important;font-size:.91rem!important;text-overflow:ellipsis!important}
  #tab-ferry .home-route-row .sf{min-width:0!important}
  #tab-ferry .home-route-row .sf.is-loading::after{right:34px!important;top:calc(50% + 12px)!important}
  .trip-type{grid-template-columns:1fr 1fr!important;gap:8px!important;margin-bottom:8px!important}
  .trip-r{font-size:.92rem!important;min-height:48px!important;display:flex!important;align-items:center!important;gap:8px!important;justify-content:flex-start!important}
  #tab-ferry .srow:not(.home-route-row),#tab-ferry .popts,#tab-tour .srow,#tab-esim .srow{gap:10px!important}
  .btn-search{width:100%!important;min-height:52px!important;border-radius:16px!important;font-weight:900!important}

  /* Tour detail pages */
  .td-hero{height:280px!important}
  .td-grid{grid-template-columns:1fr!important;gap:16px!important;margin-top:16px!important}
  .td-card{border-radius:16px!important;padding:16px!important}
  .td-hl,.td-info,.td-inc-exc-grid,.td-review-summary{grid-template-columns:1fr!important}
  .td-list li{align-items:flex-start!important;line-height:1.55!important;word-break:normal!important;overflow-wrap:anywhere!important}
  .td-gallery{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .td-gallery img{height:92px!important}

  /* Cruise detail pages with inline-style overrides */
  .cruise-detail-page{padding:18px 0!important}
  .cruise-detail-page .container{width:min(100% - 22px,430px)!important;padding-left:0!important;padding-right:0!important}
  .cruise-detail-page h1{font-size:1.45rem!important;line-height:1.22!important}
  .cruise-detail-page h2{font-size:1.25rem!important;line-height:1.25!important}
  .cruise-detail-page h3{font-size:1.05rem!important;line-height:1.3!important}
  .cruise-detail-grid{display:grid!important;grid-template-columns:1fr!important;gap:18px!important;padding:18px!important}
  .cruise-inc-exc-grid{grid-template-columns:1fr!important;gap:14px!important}
  .cruise-sticky-aside{order:-1!important}
  .cruise-booking-box{position:static!important;top:auto!important;border-radius:18px!important}
  .cruise-detail-page ul{padding-left:20px!important;line-height:1.7!important}
  .cruise-detail-page img{max-width:100%!important;height:auto!important}
  .cruise-detail-page table{display:block!important;overflow-x:auto!important;white-space:nowrap!important}
}
@media (max-width:380px){
  #tab-ferry .home-route-row{grid-template-columns:minmax(0,1fr) minmax(0,1fr) 44px!important;gap:6px!important}
  #tab-ferry .home-route-row .swap-btn{width:44px!important;height:46px!important;border-radius:14px!important}
  #tab-ferry .home-route-row select{font-size:.86rem!important;padding-left:9px!important;padding-right:26px!important}
  #tab-ferry .home-route-row .sf label{font-size:.68rem!important}
}
