:root{
  --cream:#faf6f0;
  --cream-2:#f3ece2;
  --ink:#2b2630;
  --ink-soft:#6b6470;
  --peri:#8b8cd9;          /* periwinkle */
  --peri-deep:#6566c4;
  --blush:#f4c7d4;
  --slate:#52546b;
  --line:#e6ddd1;
  --ok:#5bb38a;
  --warn:#e0925a;
  --shadow:0 18px 40px -18px rgba(80,70,110,.35);
  --radius:22px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Nunito',system-ui,sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
}
h1,h2,h3,.brand-text{font-family:'Unbounded',sans-serif;font-weight:700;line-height:1.1;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* floating background orbs */
.bg-orbs{position:fixed;inset:0;z-index:-1;pointer-events:none;filter:blur(8px)}
.orb{position:absolute;border-radius:50%;opacity:.4;animation:float 18s ease-in-out infinite}
.orb-1{width:340px;height:340px;top:-80px;left:-60px;background:radial-gradient(circle,#cfd0f5,transparent 70%)}
.orb-2{width:420px;height:420px;top:40%;right:-120px;background:radial-gradient(circle,#f6d6e0,transparent 70%);animation-delay:-6s}
.orb-3{width:300px;height:300px;bottom:-60px;left:20%;background:radial-gradient(circle,#d8e9df,transparent 70%);animation-delay:-12s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-30px)}}

/* header */
.site-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px clamp(20px,5vw,56px);position:sticky;top:0;z-index:50;
  background:rgba(250,246,240,.78);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{font-size:1.4rem;color:var(--peri)}
.brand-text{font-size:1.15rem;display:flex;flex-direction:column;line-height:1}
.brand-text small{font-family:'Nunito';font-weight:500;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-top:3px}
.site-nav{display:flex;gap:26px;align-items:center;font-weight:600;font-size:.95rem}
.site-nav a{color:var(--slate);transition:color .2s}
.site-nav a:hover{color:var(--peri-deep)}
.nav-admin{background:var(--cream-2);padding:8px 16px;border-radius:30px;border:1px solid var(--line)}

/* flash */
.flash-wrap{max-width:760px;margin:18px auto 0;padding:0 20px;display:flex;flex-direction:column;gap:8px}
.flash{padding:12px 18px;border-radius:14px;font-weight:600;font-size:.92rem}
.flash-error{background:#fde8e8;color:#b14242;border:1px solid #f3c6c6}
.flash-success{background:#e4f5ec;color:#357a59;border:1px solid #c2e8d4}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:'Nunito';font-weight:700;font-size:1rem;padding:14px 26px;border-radius:40px;
  cursor:pointer;border:none;transition:transform .15s,box-shadow .2s,background .2s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:linear-gradient(135deg,var(--peri),var(--peri-deep));color:#fff;box-shadow:0 12px 24px -10px rgba(101,102,196,.7)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 30px -12px rgba(101,102,196,.8)}
.btn-ghost{background:transparent;color:var(--peri-deep);border:1.5px solid var(--peri)}
.btn-ghost:hover{background:var(--peri);color:#fff}
.btn-disabled{background:var(--cream-2);color:var(--ink-soft);cursor:default;border:1px solid var(--line)}
.btn-sm{padding:10px 20px;font-size:.92rem}
.btn-xs{padding:7px 12px;font-size:.95rem;border-radius:12px}
.btn-block{width:100%}

/* hero */
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;
  max-width:1180px;margin:0 auto;padding:clamp(40px,7vw,90px) clamp(20px,5vw,56px)}
.eyebrow{display:inline-block;font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--peri-deep);background:#eceaf9;padding:7px 16px;border-radius:30px;margin-bottom:22px}
.hero-text h1{font-size:clamp(2.2rem,5vw,3.6rem);margin-bottom:20px}
.lede{font-size:1.12rem;color:var(--ink-soft);max-width:46ch;margin-bottom:30px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:32px;margin-top:40px}
.hero-stats div{display:flex;flex-direction:column}
.hero-stats b{font-family:'Unbounded';font-size:1.8rem;color:var(--peri-deep)}
.hero-stats span{font-size:.85rem;color:var(--ink-soft)}
.hero-art{position:relative}
.hero-card{position:relative;border-radius:30px;overflow:hidden;box-shadow:var(--shadow);transform:rotate(2deg);
  animation:cardIn .9s cubic-bezier(.2,.8,.2,1)}
.hero-card img{width:100%;height:520px;object-fit:cover}
@keyframes cardIn{from{opacity:0;transform:rotate(2deg) translateY(30px)}to{opacity:1;transform:rotate(2deg) translateY(0)}}
.hero-badge{position:absolute;bottom:18px;left:18px;right:18px;background:rgba(255,255,255,.92);
  backdrop-filter:blur(6px);padding:12px 18px;border-radius:16px;font-weight:600;font-size:.9rem;text-align:center}

/* sections */
.section-head{max-width:1180px;margin:0 auto 36px;padding:0 clamp(20px,5vw,56px)}
.section-head.center{text-align:center}
.section-head h2{font-size:clamp(1.7rem,3.5vw,2.5rem)}
.section-head h2 span{color:var(--peri);font-weight:400}
.section-head p{color:var(--ink-soft);max-width:54ch;margin-top:8px}
.section-head.center p{margin-left:auto;margin-right:auto}

.catalog{padding:clamp(40px,6vw,72px) 0}
.catalog-alt{background:linear-gradient(180deg,transparent,var(--cream-2) 12%,var(--cream-2) 88%,transparent)}
.grid{max-width:1180px;margin:0 auto;padding:0 clamp(20px,5vw,56px);
  display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:26px}

/* card */
.card{background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);
  box-shadow:0 10px 30px -22px rgba(80,70,110,.4);transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card-media{position:relative;aspect-ratio:4/3;overflow:hidden}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.card:hover .card-media img{transform:scale(1.06)}
.card-sold .card-media img,.card-reserved .card-media img{filter:saturate(.6) brightness(.97)}
.status-pill{position:absolute;top:12px;left:12px;font-size:.74rem;font-weight:700;padding:5px 12px;border-radius:30px;backdrop-filter:blur(4px)}
.status-available{background:rgba(91,179,138,.92);color:#fff}
.status-reserved{background:rgba(224,146,90,.92);color:#fff}
.status-sold{background:rgba(120,116,130,.9);color:#fff}
.card-body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:8px;flex:1}
.card-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.card-top h3{font-size:1.25rem}
.price{font-family:'Unbounded';font-weight:600;color:var(--peri-deep);font-size:1rem;white-space:nowrap}
.price.big{font-size:1.6rem;display:block;margin:6px 0}
.card-color{font-size:.85rem;color:var(--peri-deep);font-weight:600}
.card-desc{font-size:.92rem;color:var(--ink-soft);flex:1}
.card-body .btn{margin-top:6px}

/* care */
.care{padding:clamp(48px,7vw,88px) 0}
.care-grid{max-width:1180px;margin:0 auto;padding:0 clamp(20px,5vw,56px);
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px}
.care-grid article{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;text-align:center;transition:transform .2s}
.care-grid article:hover{transform:translateY(-4px)}
.care-emoji{font-size:2.2rem;display:block;margin-bottom:12px}
.care-grid h3{font-size:1.1rem;margin-bottom:8px}
.care-grid p{font-size:.9rem;color:var(--ink-soft)}

/* booking */
.book{max-width:1000px;margin:0 auto;padding:clamp(28px,5vw,56px) clamp(20px,5vw,40px)}
.back-link{color:var(--peri-deep);font-weight:700;display:inline-block;margin-bottom:24px}
.book-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:40px;align-items:start}
.book-pet{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:0 12px 30px -22px rgba(80,70,110,.4)}
.book-pet img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:16px;margin-bottom:16px}
.book-pet h2{font-size:1.5rem}
.book-form-wrap h1{font-size:clamp(1.8rem,4vw,2.4rem);margin-bottom:10px}
.book-form{display:flex;flex-direction:column;gap:16px;margin-top:24px}
.book-form label{display:flex;flex-direction:column;gap:6px;font-weight:700;font-size:.92rem;color:var(--slate)}
.book-form input,.book-form textarea{font-family:'Nunito';font-size:1rem;padding:13px 16px;border:1.5px solid var(--line);
  border-radius:14px;background:#fff;transition:border .2s,box-shadow .2s;font-weight:500;color:var(--ink)}
.book-form input:focus,.book-form textarea:focus{outline:none;border-color:var(--peri);box-shadow:0 0 0 4px rgba(139,140,217,.15)}
.book-form textarea{resize:vertical}
.form-note{font-size:.85rem;color:var(--ink-soft);text-align:center}

/* thanks + login */
.thanks,.admin-login{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:40px 20px}
.thanks-card,.login-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:48px 40px;text-align:center;max-width:480px;box-shadow:var(--shadow)}
.thanks-emoji{font-size:3rem;display:block;margin-bottom:16px}
.thanks-card h1{font-size:1.7rem;margin-bottom:14px}
.login-card{display:flex;flex-direction:column;gap:14px;align-items:center}
.login-card h1{font-size:1.5rem}
.login-card input{width:100%;font-family:'Nunito';font-size:1rem;padding:13px 16px;border:1.5px solid var(--line);border-radius:14px}
.login-card input:focus{outline:none;border-color:var(--peri)}

/* admin */
.admin{max-width:1180px;margin:0 auto;padding:clamp(28px,5vw,56px) clamp(20px,5vw,40px)}
.admin-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;margin-bottom:28px}
.admin-head h1{font-size:clamp(1.6rem,3.5vw,2.2rem)}
.admin-stats{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.chip{font-size:.82rem;font-weight:700;padding:7px 14px;border-radius:30px;background:var(--cream-2);border:1px solid var(--line)}
.chip-new{background:#fdeede;color:#b3702f;border-color:#f3d9bc}
.chip-ok{background:#e4f5ec;color:#357a59;border-color:#c2e8d4}
.chip-off{background:#f0eef2;color:#8a8693}
.empty{background:#fff;border:1px dashed var(--line);border-radius:var(--radius);padding:48px;text-align:center;color:var(--ink-soft)}
.table-wrap{overflow-x:auto;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 12px 30px -24px rgba(80,70,110,.4)}
.admin-table{width:100%;border-collapse:collapse;min-width:760px}
.admin-table th{text-align:left;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);
  padding:16px 18px;border-bottom:2px solid var(--line);font-weight:700}
.admin-table td{padding:14px 18px;border-bottom:1px solid var(--line);font-size:.92rem;vertical-align:middle}
.row-cancelled{opacity:.5}
.cell-pet{display:flex;align-items:center;gap:10px;font-weight:700}
.cell-pet img{width:42px;height:42px;border-radius:10px;object-fit:cover}
.cell-contacts a{color:var(--peri-deep);font-weight:600}
.cell-msg{max-width:220px;color:var(--ink-soft)}
.cell-date{white-space:nowrap;color:var(--ink-soft);font-size:.85rem}
.cell-actions{display:flex;gap:6px}
.cell-actions form{margin:0}

/* footer */
.site-footer{background:var(--ink);color:#e8e3ee;margin-top:60px;padding:40px clamp(20px,5vw,56px) 30px}
.foot-inner{max-width:1180px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
.foot-inner .brand-mark{color:var(--blush)}
.foot-meta{display:flex;gap:22px;flex-wrap:wrap;font-size:.9rem;align-items:center}
.foot-meta a{color:var(--peri);font-weight:700}
.foot-fine{max-width:1180px;margin:22px auto 0;font-size:.82rem;color:#9b95a8;border-top:1px solid #413c4a;padding-top:18px}

/* responsive */
@media(max-width:860px){
  .hero{grid-template-columns:1fr;gap:36px}
  .hero-art{order:-1}
  .hero-card img{height:340px}
  .book-grid{grid-template-columns:1fr}
  .site-nav{gap:14px;font-size:.85rem}
  .site-nav a:not(.nav-admin){display:none}
}
