/* ============================================
   SUI TAXI - Page Common Styles
   Shared styles for hotel/course/airport/charter pages
   Extracted from inline $pageStyles blocks
   ============================================ */

/* PAGE HERO */
.page-hero{position:relative;height:70vh;min-height:420px;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.page-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,0.3) 0%,rgba(0,0,0,0.65) 100%);}
.page-hero-content{position:relative;z-index:2;text-align:center;padding:0 24px;}
.page-hero-content h1{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,5vw,3.6rem);color:#fff;margin-bottom:16px;line-height:1.2;}
.page-hero-content h1 em{color:#c9a84c;font-style:italic;}
.page-hero-content p{color:rgba(255,255,255,0.85);font-size:1rem;letter-spacing:0.12em;font-family:'Noto Sans JP',sans-serif;}

/* BREADCRUMB */
.breadcrumb{padding:12px 24px;background:rgba(0,0,0,0.8);border-bottom:1px solid rgba(201,168,76,0.15);}
.breadcrumb a,.breadcrumb span{font-size:12px;color:rgba(201,168,76,0.7);text-decoration:none;letter-spacing:0.06em;font-family:'Noto Sans JP',sans-serif;}
.breadcrumb a:hover{color:#c9a84c;}
.breadcrumb span{color:rgba(255,255,255,0.4);margin:0 8px;}

/* CONTENT SECTION */
.content-section{max-width:900px;margin:0 auto;padding:64px 24px;}
.content-section h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.6rem,4vw,2.4rem);color:#c9a84c;margin-bottom:24px;line-height:1.3;}
.content-section h2 em{font-style:italic;}
.content-section h3{font-family:'Cinzel',serif;font-size:1rem;color:#c9a84c;letter-spacing:0.12em;margin:40px 0 12px;}
.content-section p{font-family:'Noto Sans JP',sans-serif;color:rgba(255,255,255,0.78);font-size:15px;line-height:2;margin-bottom:16px;}
.content-section strong{color:#c9a84c;}

/* FARE TABLE */
.fare-table{width:100%;border-collapse:collapse;font-family:'Noto Sans JP',sans-serif;font-size:14px;margin:24px 0;}
.fare-table thead th{background:rgba(201,168,76,0.12);color:#c9a84c;padding:12px 16px;text-align:left;font-weight:500;letter-spacing:0.06em;border-bottom:1px solid rgba(201,168,76,0.2);}
.fare-table tbody tr{border-bottom:1px solid rgba(255,255,255,0.06);}
.fare-table tbody tr:hover{background:rgba(201,168,76,0.04);}
.fare-table tbody td{padding:12px 16px;color:rgba(255,255,255,0.78);vertical-align:middle;}
.fare-table .price{color:#c9a84c;font-weight:500;font-size:16px;}
.fare-table .note{font-size:12px;color:rgba(255,255,255,0.45);margin-top:4px;}
.fare-wrap{background:rgba(201,168,76,0.05);border:1px solid rgba(201,168,76,0.15);border-radius:4px;padding:24px;margin:32px 0;}
.access-table{background:rgba(201,168,76,0.05);border:1px solid rgba(201,168,76,0.15);border-radius:4px;padding:24px;margin:24px 0;}
.access-table table{width:100%;border-collapse:collapse;font-family:'Noto Sans JP',sans-serif;font-size:14px;}
.access-table td{padding:10px 0;color:rgba(255,255,255,0.75);border-bottom:1px solid rgba(201,168,76,0.1);}
.access-table td:first-child{color:rgba(201,168,76,0.7);width:130px;}
.access-table tr:last-child td{border-bottom:none;}

/* TIP BOX */
.tip-box{background:rgba(201,168,76,0.08);border-left:3px solid #c9a84c;padding:20px 24px;margin:32px 0;border-radius:0 4px 4px 0;}
.tip-box p{margin:0;font-size:14px;}

/* INFO GRID / CARDS */
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin:32px 0;}
.info-card{background:rgba(201,168,76,0.05);border:1px solid rgba(201,168,76,0.15);border-radius:4px;padding:24px;}
.info-card h3{font-family:'Cinzel',serif;color:#c9a84c;font-size:14px;letter-spacing:0.1em;margin-bottom:12px;}
.info-card p{font-size:13px;color:rgba(255,255,255,0.65);line-height:1.8;margin:0;}
.info-card h4{font-family:'Cinzel',serif;color:#c9a84c;font-size:13px;letter-spacing:0.1em;margin-bottom:8px;}
.info-card .icon{font-size:2em;margin-bottom:12px;}

/* SPOTS / RELATED */
.spots-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin:24px 0;}
.spot-item,.spot-card{background:rgba(201,168,76,0.05);border:1px solid rgba(201,168,76,0.15);border-radius:4px;padding:20px;}
.spot-item h3,.spot-item h4,.spot-card h3,.spot-card h4{font-family:'Noto Sans JP',sans-serif;color:#c9a84c;font-size:14px;margin-bottom:8px;}
.spot-item p,.spot-card p{font-size:13px;color:rgba(255,255,255,0.6);margin:0;line-height:1.7;}
.related-spots{background:rgba(255,255,255,0.03);border-top:1px solid rgba(201,168,76,0.12);padding:48px 24px;margin:48px 0 0;}
.related-spots .inner{max-width:900px;margin:0 auto;}
.related-spots h3{font-family:'Cinzel',serif;color:#c9a84c;font-size:14px;letter-spacing:0.12em;margin-bottom:24px;}
.spot-card{display:block;text-decoration:none;border:1px solid rgba(201,168,76,0.18);border-radius:4px;overflow:hidden;transition:border-color 0.3s;}
.spot-card:hover{border-color:#c9a84c;}
.spot-card img{width:100%;height:140px;object-fit:cover;display:block;}
.spot-card-body{padding:14px 16px;}
.spot-card-body h3,.spot-card-body h4{font-family:'Noto Sans JP',sans-serif;color:#c9a84c;font-size:13px;margin-bottom:4px;letter-spacing:normal;}
.spot-card-body p{font-size:12px;color:rgba(255,255,255,0.5);margin:0;line-height:1.6;}

/* PHOTOS */
.photo-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin:32px 0;}
.photo-row img{width:100%;height:240px;object-fit:cover;border-radius:4px;}
.photo-single{margin:32px 0;}
.photo-single img{width:100%;height:auto;border-radius:4px;}
.photo-caption{font-size:12px;color:rgba(255,255,255,0.5);text-align:center;margin-top:8px;font-family:'Noto Sans JP',sans-serif;}

/* MAP */
.map-wrap{margin:40px 0;border:1px solid rgba(201,168,76,0.15);border-radius:4px;overflow:hidden;}
.map-wrap iframe{width:100%;height:380px;border:0;display:block;}

/* CTA */
.cta-center{text-align:center;margin:48px 0 0;}

/* RESPONSIVE */
@media(max-width:600px){
  .fare-table thead th,.fare-table tbody td{padding:10px 12px;}
  .page-hero{height:60vh;min-height:360px;}
  .content-section{padding:48px 20px;}
}
