/*
Theme Name: Paradise Coast
Theme URI: https://floridasparadisevilla.com/
Author: Paradise Coast
Description: A bright, photo-forward WordPress theme for vacation rental and villa websites, with a hero booking layout, amenities grid, gallery, and rates table.
Version: 1.4.2
Requires at least: 6.2
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: paradise-coast
*/

:root{
  --coral:#ff7a59; --coral-dk:#f2603c; --ocean:#11707f; --ocean-dk:#0c4f5a;
  --sun:#ffc24b; --ink:#1d2b30; --slate:#5a6b72; --cloud:#f4f8f9;
  --sand:#fff7f1; --line:#e7eef0; --white:#fff;
  --shadow:0 18px 40px -18px rgba(17,60,68,.30);
  --shadow-sm:0 8px 22px -12px rgba(17,60,68,.28);
  --rad:18px; --rad-sm:12px;
  --hbody:'Poppins',system-ui,sans-serif; --hbody-2:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--hbody-2);color:var(--ink);background:var(--white);
  line-height:1.7;font-size:17px;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--ocean);text-decoration:none}
a:hover{color:var(--coral-dk)}
h1,h2,h3,h4{font-family:var(--hbody);line-height:1.15;color:var(--ink);margin:0 0 .5em;font-weight:700;letter-spacing:-.01em}
h1{font-size:clamp(2.1rem,5vw,3.2rem);font-weight:800}
h2{font-size:clamp(1.6rem,3.3vw,2.3rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em}
.shell{max-width:1140px;margin:0 auto;padding:0 22px}
.eyebrow{display:inline-block;font-family:var(--hbody);font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--coral-dk);margin-bottom:14px}
.eyebrow.light{color:var(--sun)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;background:var(--coral);color:#fff;
  padding:14px 30px;border-radius:999px;font-family:var(--hbody);font-weight:600;font-size:1rem;
  border:none;cursor:pointer;box-shadow:0 10px 22px -10px rgba(255,122,89,.85);
  transition:transform .16s ease,box-shadow .16s ease,background .16s ease}
.btn:hover{background:var(--coral-dk);color:#fff;transform:translateY(-2px);box-shadow:0 16px 28px -12px rgba(242,96,60,.9)}
.btn.alt{background:var(--ocean);box-shadow:0 10px 22px -10px rgba(17,112,127,.8)}
.btn.alt:hover{background:var(--ocean-dk)}
.btn.ghost{background:rgba(255,255,255,.14);border:2px solid rgba(255,255,255,.7);box-shadow:none;backdrop-filter:blur(2px)}
.btn.ghost:hover{background:rgba(255,255,255,.26);transform:translateY(-2px)}
.btn.lg{padding:16px 38px;font-size:1.08rem}

/* masthead */
.masthead{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);backdrop-filter:saturate(150%) blur(10px);border-bottom:1px solid var(--line)}
.masthead .bar{max-width:1180px;margin:0 auto;padding:12px 22px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink)}
.brand:hover{color:var(--ink)}
.mark{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:13px;background:linear-gradient(135deg,var(--coral),var(--sun));color:#fff;font-family:var(--hbody);font-weight:800;font-size:1.05rem;box-shadow:0 8px 16px -8px rgba(255,122,89,.9)}
.brand-txt{display:flex;flex-direction:column;font-family:var(--hbody);font-weight:700;font-size:1.18rem;line-height:1.1}
.brand-txt small{font-family:var(--hbody-2);font-weight:500;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--slate)}
.mainnav{display:flex;align-items:center;gap:4px}
.mainnav a{font-family:var(--hbody);font-weight:600;font-size:.95rem;color:var(--ink);padding:9px 13px;border-radius:10px}
.mainnav a:hover{background:var(--sand);color:var(--coral-dk)}
.mainnav a.current{color:var(--coral-dk)}
.mainnav .navcta{background:var(--ocean);color:#fff;margin-left:8px;padding:10px 20px;border-radius:999px}
.mainnav .navcta:hover{background:var(--ocean-dk);color:#fff}
.navtoggle,.burger{display:none}

/* hero */
.hero{position:relative;color:#fff;padding:118px 22px 104px;text-align:center;overflow:hidden;
  background:linear-gradient(180deg,rgba(12,55,63,.30),rgba(12,55,63,.62)),var(--hero) center/cover no-repeat}
.hero .inner{position:relative;max-width:880px;margin:0 auto}
.hero h1{color:#fff;text-shadow:0 3px 24px rgba(0,0,0,.32);margin-bottom:.28em}
.hero .sub{font-size:clamp(1.05rem,2vw,1.3rem);max-width:680px;margin:0 auto 1.7em;color:#f3fbfc;text-shadow:0 2px 12px rgba(0,0,0,.32)}
.hero .cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.statbar{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin-top:42px}
.statbar .chip{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);backdrop-filter:blur(4px);
  border-radius:14px;padding:14px 22px;min-width:104px;text-align:center}
.statbar .chip b{display:block;font-family:var(--hbody);font-weight:800;font-size:1.5rem;line-height:1}
.statbar .chip span{font-size:.82rem;letter-spacing:.04em;color:#e8f6f7}

/* sections */
.sec{padding:84px 0}
.sec.tight{padding:60px 0}
.sec.cloud{background:var(--cloud)}
.sec.sand{background:var(--sand)}
.sec.ocean{background:linear-gradient(135deg,var(--ocean),var(--ocean-dk));color:#fff}
.sec.ocean h1,.sec.ocean h2{color:#fff}
.sec-head{max-width:720px;margin:0 auto 14px}
.sec-head.center{text-align:center}
.lead{font-size:1.18rem;color:var(--slate);max-width:760px}
.sec.ocean .lead{color:#e3f4f5}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* split feature */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:52px;align-items:center}
.split.flip .ph{order:2}
.split .ph{position:relative}
.split .ph img{border-radius:var(--rad);box-shadow:var(--shadow);width:100%;aspect-ratio:4/3;object-fit:cover}
.split .ph:before{content:"";position:absolute;inset:auto -16px -16px auto;width:62%;height:62%;border-radius:var(--rad);background:linear-gradient(135deg,var(--sun),var(--coral));z-index:-1;opacity:.5}
.split .bd h2{margin-bottom:.4em}

/* amenities grid */
.amen{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:34px}
.amen .item{background:#fff;border:1px solid var(--line);border-radius:var(--rad);padding:24px 22px;box-shadow:var(--shadow-sm);transition:transform .16s ease,box-shadow .16s ease}
.amen .item:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.amen .ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;background:var(--sand);font-size:1.4rem;margin-bottom:12px}
.amen .item h3{font-size:1.08rem;margin-bottom:.3em}
.amen .item p{margin:0;color:var(--slate);font-size:.96rem}

/* tick list */
.ticks{list-style:none;padding:0;margin:26px 0 0;display:grid;grid-template-columns:repeat(2,1fr);gap:12px 26px}
.ticks li{position:relative;padding-left:30px;color:var(--ink)}
.ticks li:before{content:"";position:absolute;left:0;top:.35em;width:18px;height:18px;border-radius:50%;
  background:var(--ocean) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/12px no-repeat}

/* cards (attractions) */
.cardgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:34px}
.tcard{background:#fff;border:1px solid var(--line);border-radius:var(--rad);padding:26px 24px;box-shadow:var(--shadow-sm);transition:transform .16s ease,box-shadow .16s ease}
.tcard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.tcard h3{display:flex;align-items:center;gap:10px;font-size:1.12rem}
.tcard h3 .dot{width:11px;height:11px;border-radius:50%;background:var(--coral);flex:0 0 auto}
.tcard p{margin:0;color:var(--slate);font-size:.97rem}

/* gallery */
.galgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:30px}
.galgrid a{display:block;border-radius:var(--rad-sm);overflow:hidden;box-shadow:var(--shadow-sm)}
.galgrid img{aspect-ratio:4/3;object-fit:cover;width:100%;transition:transform .4s ease}
.galgrid a:hover img{transform:scale(1.06)}

/* rates table */
.tablecard{background:#fff;border-radius:var(--rad);box-shadow:var(--shadow);overflow:hidden;border:1px solid var(--line);margin-top:24px}
table.rate{width:100%;border-collapse:collapse}
table.rate th,table.rate td{padding:15px 20px;text-align:left;border-bottom:1px solid var(--line)}
table.rate thead th{background:linear-gradient(135deg,var(--ocean),var(--ocean-dk));color:#fff;font-family:var(--hbody);font-weight:600;letter-spacing:.01em}
table.rate tbody tr:last-child td{border-bottom:none}
table.rate tbody tr:nth-child(even) td{background:var(--cloud)}
table.rate td:last-child{font-family:var(--hbody);font-weight:700;color:var(--ocean-dk);white-space:nowrap}
.pricepill{display:inline-block;background:var(--sand);color:var(--coral-dk);font-family:var(--hbody);font-weight:700;border-radius:999px;padding:3px 14px}

/* location list */
.distbar{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:26px}
.distbar .d{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--line);border-radius:var(--rad);padding:18px 22px;box-shadow:var(--shadow-sm)}
.distbar .d .pin{width:44px;height:44px;border-radius:12px;background:var(--sand);display:grid;place-items:center;font-size:1.3rem;flex:0 0 auto}
.distbar .d b{display:block;font-family:var(--hbody);font-size:1.15rem;color:var(--ocean-dk)}
.distbar .d span{color:var(--slate);font-size:.95rem}

/* CTA banner */
.ctaband{position:relative;border-radius:24px;padding:56px 40px;text-align:center;color:#fff;overflow:hidden;margin-top:8px;
  background:linear-gradient(135deg,var(--coral),var(--coral-dk))}
.ctaband:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% -20%,rgba(255,255,255,.28),transparent 60%)}
.ctaband > *{position:relative}
.ctaband h2{color:#fff;margin-bottom:.3em}
.ctaband p{max-width:560px;margin:0 auto 1.4em;color:#fff4ef}

/* note + errors */
.note{background:#e9f6f8;border:1px solid #bfe3e7;color:var(--ocean-dk);padding:16px 20px;border-radius:var(--rad-sm)}
.muted{color:var(--slate);font-size:.96rem}
.errors{background:#fdeee9;border:1px solid #f6c8b9;color:#b34326;padding:14px 18px;border-radius:var(--rad-sm)}

/* booking form */
.bookwrap{display:grid;grid-template-columns:1fr 360px;gap:40px;align-items:start;margin-top:10px}
form.book{display:grid;gap:16px;background:#fff;padding:30px;border-radius:var(--rad);box-shadow:var(--shadow);border:1px solid var(--line)}
form.book .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
label{font-family:var(--hbody);font-weight:600;font-size:.9rem;display:block;margin-bottom:6px;color:var(--ink)}
input,select,textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:11px;font:inherit;background:#fdfefe;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--ocean);box-shadow:0 0 0 3px rgba(17,112,127,.14)}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.aside-card{background:linear-gradient(160deg,var(--ocean),var(--ocean-dk));color:#fff;border-radius:var(--rad);padding:28px;box-shadow:var(--shadow)}
.aside-card h3{color:#fff}
.aside-card ul{list-style:none;padding:0;margin:14px 0 0}
.aside-card li{padding:9px 0;border-bottom:1px solid rgba(255,255,255,.16);display:flex;justify-content:space-between;gap:12px;font-size:.96rem}
.aside-card li:last-child{border-bottom:none}
.aside-card li b{font-family:var(--hbody)}

/* footer */
.site-footer{background:var(--ink);color:#b9cace;padding:62px 0 26px;font-size:.96rem}
.foot-inner{max-width:1140px;margin:0 auto;padding:0 22px}
.foot-cols{display:grid;grid-template-columns:1.8fr 1fr 1fr;gap:36px}
.foot-about .mark{margin-bottom:14px}
.site-footer h4{color:#fff;font-family:var(--hbody);font-size:1.02rem;margin:0 0 14px}
.foot-links{list-style:none;padding:0;margin:0}
.foot-links li{margin-bottom:9px}
.foot-links a{color:#b9cace}
.foot-links a:hover{color:var(--sun)}
.foot-base{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:20px;color:#8499a0;font-size:.86rem}
.totop{color:#8499a0}
.totop:hover{color:var(--sun)}

/* responsive */
@media(max-width:900px){
  .split,.bookwrap{grid-template-columns:1fr;gap:30px}
  .split.flip .ph{order:0}
  .amen,.cardgrid,.galgrid{grid-template-columns:repeat(2,1fr)}
  .foot-cols{grid-template-columns:1fr 1fr}
  .distbar{grid-template-columns:1fr}
}
@media(max-width:720px){
  .mainnav{position:fixed;inset:64px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;
    background:#fff;border-bottom:1px solid var(--line);padding:8px 16px 16px;box-shadow:var(--shadow);
    transform:translateY(-130%);transition:transform .25s ease;visibility:hidden}
  .navtoggle:checked ~ .mainnav{transform:translateY(0);visibility:visible}
  .mainnav a{padding:13px 10px;border-radius:10px}
  .mainnav .navcta{margin:8px 0 0;text-align:center}
  .burger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:40px;cursor:pointer}
  .burger span{height:3px;border-radius:3px;background:var(--ink);transition:.25s}
  .navtoggle:checked ~ .burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .navtoggle:checked ~ .burger span:nth-child(2){opacity:0}
  .navtoggle:checked ~ .burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .ticks,.amen,.cardgrid,.galgrid{grid-template-columns:1fr}
  .foot-cols{grid-template-columns:1fr}
  form.book .row{grid-template-columns:1fr}
  .hero{padding:88px 20px 76px}
  .sec{padding:60px 0}
  .ctaband{padding:42px 24px}
}
