:root{--color-ocean-deep: #0a4d5c;--color-ocean: #167d8f;--color-ocean-light: #5bb8c9;--color-ocean-mist: #c8e6ec;--color-sand: #e8d5b7;--color-sand-light: #f5ede1;--color-sand-pale: #fdf8f2;--color-coral: #e67a5e;--color-coral-light: #f0a08a;--color-coral-dark: #c96a4f;--color-sunset: #d4a843;--color-sky: #87ceeb;--color-white: #ffffff;--color-dark: #1a2a3a;--color-text: #3d3d3d;--color-text-light: #6b7280;--color-seafoam: #7ec8b8;--color-shell: #fce4d6;--font-heading: "Georgia", "Times New Roman", serif;--font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--shadow-lg: 0 8px 30px rgba(0,0,0,.12);--shadow-xl: 0 15px 50px rgba(0,0,0,.2);--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--max-width: 1200px;--header-height: 75px}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-body);color:var(--color-text);background:var(--color-white);line-height:1.7;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--color-dark);line-height:1.3}h1{font-size:2.8rem}h2{font-size:2.2rem}h3{font-size:1.6rem}h4{font-size:1.2rem}a{color:var(--color-ocean);text-decoration:none;transition:color .2s}a:hover{color:var(--color-ocean-deep)}img{max-width:100%;height:auto}.container{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}.section{padding:5rem 0}.section-alt{background:var(--color-sand-pale)}.section-ocean{background:linear-gradient(135deg,var(--color-ocean-deep),var(--color-ocean));color:var(--color-white)}.section-ocean h2,.section-ocean h3{color:var(--color-white)}.btn{display:inline-block;padding:.85rem 2rem;border-radius:50px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s ease;border:none;text-align:center;letter-spacing:.3px}.btn-primary{background:var(--color-ocean);color:var(--color-white)}.btn-primary:hover{background:var(--color-ocean-deep);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-accent{background:var(--color-coral);color:var(--color-white)}.btn-accent:hover{background:var(--color-coral-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-outline{background:transparent;border:2px solid var(--color-ocean);color:var(--color-ocean)}.btn-outline:hover{background:var(--color-ocean);color:var(--color-white);transform:translateY(-2px)}.btn-outline-light{background:transparent;border:2px solid var(--color-white);color:var(--color-white)}.btn-outline-light:hover{background:var(--color-white);color:var(--color-ocean-deep);transform:translateY(-2px)}.wave-divider{position:relative;height:60px;background:transparent;overflow:hidden;margin-top:-2px}.wave-divider svg{position:absolute;bottom:0;width:100%;height:60px}.site-header{position:sticky;top:0;z-index:100;background:#fffffff7;backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,.06);height:var(--header-height)}.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%;max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}.site-logo{font-family:var(--font-heading);font-size:1.35rem;color:var(--color-ocean-deep);font-weight:700;line-height:1.2}.site-logo .logo-sub{display:block;font-size:.65rem;font-family:var(--font-body);color:var(--color-text-light);font-weight:400;letter-spacing:1.5px;text-transform:uppercase}.nav-links{display:flex;gap:.25rem;list-style:none}.nav-links a{padding:.5rem 1rem;color:var(--color-text);font-size:.9rem;font-weight:500;border-radius:var(--radius-sm);transition:all .2s}.nav-links a:hover,.nav-links a.active{background:var(--color-sand-pale);color:var(--color-ocean)}.nav-links .btn-nav-book{background:var(--color-coral);color:#fff!important;padding:.5rem 1.2rem}.nav-links .btn-nav-book:hover{background:var(--color-coral-dark)}.mobile-menu-btn{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-dark);padding:.5rem}.hero{position:relative;height:90vh;min-height:550px;max-height:850px;display:flex;align-items:center;justify-content:center;overflow:hidden}.hero-image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#0a4d5cb3,#0003 40%,#0a4d5c80)}.hero-content{position:relative;text-align:center;color:var(--color-white);max-width:850px;padding:0 1.5rem;z-index:1}.hero-content h1{font-size:3.8rem;color:var(--color-white);margin-bottom:.75rem;text-shadow:0 2px 30px rgba(0,0,0,.4);letter-spacing:1px}.hero-content .hero-tagline{font-size:1.2rem;margin-bottom:.5rem;opacity:.95;font-weight:300;letter-spacing:2px;text-transform:uppercase}.hero-content .hero-desc{font-size:1.15rem;margin-bottom:2rem;opacity:.85;font-weight:300;max-width:600px;margin-left:auto;margin-right:auto}.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.hero-buttons .btn{font-size:1.05rem;padding:1rem 2.5rem}.section-banner{position:relative;height:400px;display:flex;align-items:center;justify-content:center;overflow:hidden}.section-banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.section-banner .banner-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#0a4d5cbf,#00000059)}.section-banner .banner-content{position:relative;z-index:1;text-align:center;color:#fff;padding:2rem}.section-banner .banner-content h2{font-size:2.5rem;color:#fff;margin-bottom:.5rem;text-shadow:0 2px 20px rgba(0,0,0,.3)}.section-banner .banner-content p{font-size:1.1rem;opacity:.9;max-width:600px;margin:0 auto}.page-header{position:relative;min-height:350px;display:flex;align-items:center;justify-content:center;overflow:hidden}.page-header-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.page-header .header-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#0a4d5cbf,#0000004d 60%,#0a4d5c66)}.page-header .header-content{position:relative;z-index:1;text-align:center;color:#fff;padding:0 1.5rem;max-width:700px}.page-header .header-content h1{color:#fff;font-size:3rem;margin-bottom:.5rem;text-shadow:0 2px 20px rgba(0,0,0,.3)}.page-header .header-content p{opacity:.9;font-size:1.15rem;font-weight:300}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}.card{background:var(--color-white);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);transition:all .3s}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-6px)}.card-img{width:100%;height:240px;object-fit:cover}.card-body{padding:1.5rem}.card-body h3{margin-bottom:.5rem}.card-body p{color:var(--color-text-light);font-size:.95rem}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.gallery-item{position:relative;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;aspect-ratio:4/3}.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}.gallery-item:hover img{transform:scale(1.1)}.gallery-item:after{content:"🔍";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);font-size:2rem;opacity:0;transition:all .3s}.gallery-item:hover:after{opacity:1;transform:translate(-50%,-50%) scale(1)}.feature-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem;margin:2rem 0}.feature-item{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:var(--color-sand-pale);border-radius:var(--radius-md);transition:all .3s;border:1px solid rgba(0,0,0,.04)}.feature-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);border-color:var(--color-ocean-mist)}.feature-icon{font-size:1.6rem;flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-white);border-radius:50%}.feature-item strong{display:block;margin-bottom:.2rem}.booking-section{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;margin:2rem 0}@media(max-width:900px){.booking-section{grid-template-columns:1fr}.hero-content h1{font-size:2.2rem}.hero{height:75vh;min-height:450px}.page-header{min-height:250px}.page-header .header-content h1,h1{font-size:2rem}h2{font-size:1.7rem}h3{font-size:1.3rem}.nav-links{display:none}.nav-links.open{display:flex;flex-direction:column;position:absolute;top:var(--header-height);left:0;right:0;background:var(--color-white);padding:1rem;box-shadow:var(--shadow-lg);border-bottom:1px solid #eee;z-index:99}.mobile-menu-btn{display:block}.section-banner{height:250px}.section-banner .banner-content h2{font-size:1.8rem}}.calendar-widget{background:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:1.75rem;border:1px solid rgba(0,0,0,.06)}.calendar-widget h3{margin-bottom:1rem;color:var(--color-ocean-deep)}.calendar-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.calendar-nav button{background:var(--color-sand-pale);border:none;padding:.45rem .9rem;border-radius:var(--radius-sm);cursor:pointer;font-size:1.1rem;color:var(--color-dark);transition:background .2s}.calendar-nav button:hover{background:var(--color-sand)}.calendar-nav .month-label{font-weight:600;font-size:1.1rem;color:var(--color-ocean-deep);font-family:var(--font-heading)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;text-align:center}.calendar-grid .day-header{font-size:.75rem;font-weight:600;color:var(--color-text-light);padding:.6rem 0;text-transform:uppercase;letter-spacing:.5px}.calendar-grid .day{padding:.5rem;border-radius:var(--radius-sm);font-size:.9rem;cursor:pointer;transition:all .2s;min-height:38px;display:flex;align-items:center;justify-content:center}.calendar-grid .day:hover:not(.disabled):not(.booked){background:var(--color-ocean-light);color:var(--color-white);transform:scale(1.05)}.calendar-grid .day.available{background:var(--color-sand-pale)}.calendar-grid .day.booked{background:#fde8e8;color:#c0392b;cursor:not-allowed;text-decoration:line-through;position:relative}.calendar-grid .day.selected{background:var(--color-ocean);color:var(--color-white);font-weight:600;transform:scale(1.05)}.calendar-grid .day.in-range{background:var(--color-ocean-light);color:var(--color-white)}.calendar-grid .day.disabled{color:#ccc;cursor:default}.calendar-legend{display:flex;gap:1.5rem;margin-top:1rem;font-size:.8rem;color:var(--color-text-light);flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.4rem}.legend-dot{width:14px;height:14px;border-radius:3px;flex-shrink:0}.legend-dot.available{background:var(--color-sand-pale);border:1px solid #ddd}.legend-dot.booked{background:#fde8e8;border:1px solid #e8b4b4}.legend-dot.selected{background:var(--color-ocean)}.booking-form{background:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:2rem;border:1px solid rgba(0,0,0,.06)}.booking-form h3{margin-bottom:.5rem;color:var(--color-ocean-deep)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-weight:600;font-size:.88rem;margin-bottom:.35rem;color:var(--color-dark)}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem 1rem;border:1px solid #ddd;border-radius:var(--radius-sm);font-size:.95rem;font-family:var(--font-body);transition:border-color .2s,box-shadow .2s;background:var(--color-white)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-ocean);box-shadow:0 0 0 3px #167d8f1f}.form-group textarea{min-height:100px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-success{text-align:center;padding:3rem}.form-success .check-icon{font-size:3.5rem;margin-bottom:1rem}.review-card{background:var(--color-white);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-sm);margin-bottom:1.5rem;border:1px solid rgba(0,0,0,.05);transition:box-shadow .3s}.review-card:hover{box-shadow:var(--shadow-md)}.review-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.review-stars{color:var(--color-sunset);font-size:1.2rem;letter-spacing:2px}.review-date{color:var(--color-text-light);font-size:.85rem}.review-title{font-weight:600;font-size:1.15rem;margin-bottom:.75rem;color:var(--color-ocean-deep)}.review-text{color:var(--color-text);line-height:1.8;font-size:.95rem}.review-author{margin-top:.75rem;font-weight:600;color:var(--color-ocean);font-size:.9rem}.review-summary{text-align:center;margin-bottom:3rem;padding:2rem;background:var(--color-sand-pale);border-radius:var(--radius-lg)}.review-summary .big-rating{font-size:4rem;font-weight:700;color:var(--color-ocean-deep);font-family:var(--font-heading)}.review-summary .stars{font-size:1.8rem;color:var(--color-sunset);margin:.5rem 0}.policy-section{margin:2.5rem 0;padding:1.5rem;background:var(--color-sand-pale);border-radius:var(--radius-md);border-left:4px solid var(--color-ocean)}.policy-section h3{color:var(--color-ocean-deep);padding-bottom:.5rem;border-bottom:2px solid var(--color-ocean-mist);margin-bottom:1.25rem}.policy-section h4{color:var(--color-ocean);margin:1.25rem 0 .5rem;font-size:1.1rem}.policy-section h4:first-of-type{margin-top:0}.policy-section p{margin-bottom:.75rem;line-height:1.8;color:var(--color-text)}.policy-section ul{list-style:none;padding:0}.policy-section li{padding:.35rem 0 .35rem 1.5rem;position:relative}.policy-section li:before{content:"•";color:var(--color-ocean);position:absolute;left:0;font-weight:700}.rate-card{background:linear-gradient(135deg,var(--color-sand-pale),var(--color-white));border-radius:var(--radius-lg);padding:2rem;margin:1rem 0;border:1px solid rgba(0,0,0,.06);transition:transform .3s,box-shadow .3s}.rate-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.rate-card h4{color:var(--color-ocean-deep);margin-bottom:.5rem}.rate-card .season-label{font-size:.9rem;color:var(--color-text-light);margin-bottom:.75rem}.rate-card .price{font-size:2.2rem;font-weight:700;color:var(--color-coral)}.rate-card .price span{font-size:1rem;color:var(--color-text-light);font-weight:400}.activity-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1rem}.activity-card{background:var(--color-white);border-radius:var(--radius-md);padding:1.25rem 1.5rem;margin-bottom:.75rem;box-shadow:var(--shadow-sm);border-left:4px solid var(--color-ocean);transition:transform .2s,box-shadow .2s}.activity-card:hover{transform:translate(5px);box-shadow:var(--shadow-md)}.activity-card h4{margin-bottom:.25rem;color:var(--color-dark)}.activity-card .activity-desc{font-size:.9rem;color:var(--color-text-light)}.activity-card a{color:var(--color-coral);font-weight:500;font-size:.9rem}.category-section{margin-bottom:2.5rem}.category-section h3{color:var(--color-ocean-deep);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-ocean-mist)}.webcam-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin-bottom:2rem}.site-footer{position:relative;overflow:hidden}.footer-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.25) saturate(.8)}.footer-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,#1a2a3ad9,#0a1e2df2)}.footer-content{position:relative;z-index:1;padding:4rem 0 0}.footer-inner{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2.5rem;color:#ffffffd9}.footer-grid h4{color:var(--color-white);margin-bottom:1rem;font-size:1.1rem;position:relative;padding-bottom:.5rem}.footer-grid h4:after{content:"";position:absolute;bottom:0;left:0;width:30px;height:2px;background:var(--color-coral)}.footer-grid p{font-size:.9rem;line-height:1.7;color:#ffffffb3}.footer-grid ul{list-style:none}.footer-grid li{margin-bottom:.5rem}.footer-grid a{color:#ffffffb3;font-size:.9rem;transition:color .2s}.footer-grid a:hover{color:var(--color-coral-light)}.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.5rem 0;margin-top:2.5rem;text-align:center;font-size:.85rem;color:#fff6}.footer-bottom a{color:#ffffff80}.footer-bottom a:hover{color:var(--color-coral-light)}.lightbox{display:none;position:fixed;inset:0;z-index:999;background:#000000eb;justify-content:center;align-items:center;cursor:pointer}.lightbox.open{display:flex}.lightbox img{max-width:90%;max-height:90%;object-fit:contain;border-radius:4px}.lightbox-close{position:absolute;top:1.5rem;right:2rem;color:#fff;font-size:2rem;cursor:pointer;background:#0000004d;border:none;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}.lightbox-close:hover{background:#fff3}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:2.5rem;cursor:pointer;background:#0000004d;border:none;padding:.8rem 1.2rem;border-radius:50%;transition:background .2s}.lightbox-nav:hover{background:#fff3}.lightbox-nav.prev{left:1rem}.lightbox-nav.next{right:1rem}.spinner{display:inline-block;width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.text-center{text-align:center}.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}.mb-2{margin-bottom:2rem}.mb-3{margin-bottom:3rem}.gap-2{gap:2rem}.divider{width:60px;height:3px;background:var(--color-coral);margin:1.5rem auto;border-radius:2px}.floating-book-btn{display:none;position:fixed;bottom:1.5rem;right:1.5rem;z-index:50;background:var(--color-coral);color:#fff;border:none;border-radius:50px;padding:.8rem 1.5rem;font-weight:600;box-shadow:var(--shadow-xl);cursor:pointer;font-size:.95rem;transition:transform .2s,box-shadow .2s}.floating-book-btn:hover{transform:translateY(-2px);box-shadow:0 20px 60px #0000004d}@media(max-width:768px){.floating-book-btn{display:block}}
