/*
Theme Name: Nicky Phuket Thailand
Theme URI: http://localhost/thailand
Author: Nicky Phuket
Description: Конверсионна тема за туристически екскурзии в Пукет — WooCommerce, тъмен тропически дизайн със злато и тюркоаз. Изградена по дизайна на NICKY PHUKET THAILAND.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 7.4
License: GNU GPL v2 or later
Text Domain: nicky-phuket
WC requires at least: 7.0
WC tested up to: 10.7
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root{
  --np-bg:        #0b211f;   /* deep teal-charcoal page bg */
  --np-bg-2:      #081a18;   /* darker band */
  --np-bg-3:      #0f2b28;   /* lighter band */
  --np-surface:   #12302c;   /* cards */
  --np-surface-2: #16403a;   /* card hover / elevated */
  --np-gold:      #e6c587;   /* gold accent */
  --np-gold-2:    #cda968;   /* gold deep */
  --np-teal:      #18b9a9;   /* turquoise primary */
  --np-teal-2:    #11978b;   /* turquoise deep */
  --np-green:     #25d366;   /* whatsapp green */
  --np-green-2:   #1fae53;   /* whatsapp deep */
  --np-text:      #eaf4f1;   /* near-white text */
  --np-heading:   #f6efe0;   /* warm white headings */
  --np-muted:     #9fbcb6;   /* muted teal-grey */
  --np-line:      rgba(255,255,255,.08);
  --np-line-2:    rgba(255,255,255,.14);

  --np-font:   'Montserrat', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --np-script: 'Pacifico', 'Brush Script MT', cursive;

  --np-container: 1240px;
  --np-radius:    16px;
  --np-radius-sm: 10px;
  --np-shadow:    0 18px 50px rgba(0,0,0,.45);
  --np-shadow-sm: 0 8px 24px rgba(0,0,0,.30);
  --np-header-h:  84px;
}

/* ============================================================
   BASE
   ============================================================ */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--np-font);
  font-size:16px;
  line-height:1.65;
  color:var(--np-text);
  background:var(--np-bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; transition:color .2s ease, opacity .2s ease; }
h1,h2,h3,h4{ margin:0; color:var(--np-heading); font-weight:800; line-height:1.12; }
p{ margin:0 0 1em; }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family:inherit; }

.np-container{
  width:100%;
  max-width:var(--np-container);
  margin:0 auto;
  padding:0 24px;
}

/* Script + section eyebrow helpers */
.np-script{
  font-family:var(--np-script);
  color:var(--np-gold);
  font-weight:400;
}
.np-eyebrow{
  font-family:var(--np-script);
  color:var(--np-gold);
  font-size:1.7rem;
  line-height:1;
  display:block;
  margin-bottom:6px;
}
.np-section{ padding:84px 0; position:relative; }
.np-section--alt{ background:var(--np-bg-2); }
.np-section-head{ text-align:center; margin-bottom:48px; }
.np-section-head h2{
  font-size:clamp(1.8rem, 4vw, 2.7rem);
  letter-spacing:.06em;
  text-transform:uppercase;
}
.np-section-head .np-eyebrow{ font-size:2rem; text-transform:none; letter-spacing:0; }

/* ============================================================
   BUTTONS
   ============================================================ */
.np-btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:15px 28px;
  border-radius:999px;
  font-weight:700;
  font-size:.98rem;
  letter-spacing:.01em;
  cursor:pointer;
  border:1px solid transparent;
  transition:transform .18s ease, box-shadow .18s ease, background .2s ease, color .2s ease;
  white-space:nowrap;
}
.np-btn svg{ width:20px; height:20px; flex:0 0 auto; }
.np-btn:hover{ transform:translateY(-2px); }

.np-btn--wa{ background:linear-gradient(135deg,var(--np-green),var(--np-green-2)); color:#fff; box-shadow:0 10px 26px rgba(37,211,102,.35); }
.np-btn--wa:hover{ box-shadow:0 16px 34px rgba(37,211,102,.45); }

.np-btn--primary{ background:linear-gradient(135deg,var(--np-teal),var(--np-teal-2)); color:#06201d; box-shadow:0 10px 26px rgba(24,185,169,.35); }
.np-btn--primary:hover{ box-shadow:0 16px 34px rgba(24,185,169,.45); }

.np-btn--dark{ background:rgba(8,26,24,.72); color:var(--np-heading); border-color:var(--np-line-2); backdrop-filter:blur(6px); }
.np-btn--dark:hover{ background:rgba(8,26,24,.92); border-color:var(--np-gold); }

.np-btn--ghost{ background:transparent; color:var(--np-teal); border-color:var(--np-teal); }
.np-btn--ghost:hover{ background:var(--np-teal); color:#06201d; }

/* ============================================================
   HEADER
   ============================================================ */
.np-header{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  height:var(--np-header-h);
  display:flex; align-items:center;
  transition:background .3s ease, box-shadow .3s ease, height .3s ease;
}
.np-header .np-container{ display:flex; align-items:center; gap:28px; }
.np-header.is-stuck{
  background:rgba(8,26,24,.92);
  backdrop-filter:blur(12px);
  box-shadow:0 6px 26px rgba(0,0,0,.35);
  border-bottom:1px solid var(--np-line);
}

.np-logo{ display:flex; align-items:center; gap:12px; margin-right:auto; }
.np-logo svg{ width:42px; height:42px; flex:0 0 auto; }
.np-logo-img{ height:54px; width:auto; display:block; }
.np-logo-text{ display:flex; flex-direction:column; line-height:1; }
.np-logo-text .np-logo-name{
  font-size:1.55rem; font-weight:800; letter-spacing:.14em;
  color:var(--np-gold); text-transform:uppercase;
}
.np-logo-text .np-logo-sub{
  font-size:.6rem; font-weight:600; letter-spacing:.42em;
  color:var(--np-text); text-transform:uppercase; margin-top:3px;
}

.np-nav{ display:flex; align-items:center; gap:26px; }
.np-nav a{
  font-size:.92rem; font-weight:600; color:var(--np-text);
  position:relative; padding:6px 0; letter-spacing:.01em;
}
.np-nav a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0;
  background:var(--np-teal); transition:width .25s ease;
}
.np-nav a:hover, .np-nav a:hover::after,
.np-nav .current-menu-item > a{ color:var(--np-gold); }
.np-nav a:hover::after,
.np-nav .current-menu-item > a::after{ width:100%; background:var(--np-gold); }

.np-header-actions{ display:flex; align-items:center; gap:16px; }
.np-lang{
  display:flex; align-items:center; gap:6px; cursor:pointer;
  color:var(--np-text); font-size:.85rem; font-weight:600;
}
.np-lang .np-flag{ width:26px; height:18px; border-radius:3px; overflow:hidden; box-shadow:0 0 0 1px var(--np-line-2); }
.np-lang svg.np-chev{ width:14px; height:14px; opacity:.8; }

.np-cart-link{ position:relative; display:flex; align-items:center; color:var(--np-text); }
.np-cart-link svg{ width:24px; height:24px; }
.np-cart-count{
  position:absolute; top:-8px; right:-10px; min-width:18px; height:18px;
  background:var(--np-gold); color:#06201d; font-size:.68rem; font-weight:800;
  border-radius:999px; display:flex; align-items:center; justify-content:center; padding:0 5px;
}

/* burger */
.np-burger{ display:none; background:none; border:0; cursor:pointer; padding:6px; }
.np-burger span{ display:block; width:26px; height:2px; background:var(--np-heading); margin:5px 0; transition:.3s; }

/* ============================================================
   HERO
   ============================================================ */
.np-hero{
  position:relative;
  min-height:42vh;
  display:flex; align-items:center;
  padding-top:var(--np-header-h);
  color:#fff;
  background:
    linear-gradient(115deg, rgba(6,24,22,.92) 0%, rgba(6,24,22,.55) 42%, rgba(6,24,22,.18) 70%),
    radial-gradient(120% 130% at 82% 18%, #f3c061 0%, #e0934a 16%, #1f6f69 52%, #0b211f 100%);
  background-size:cover;
  background-position:center;
}
/* If a hero photo is dropped at /wp-content/uploads/hero.jpg the inline style in header overrides this. */
.np-hero::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:160px;
  background:linear-gradient(180deg, transparent, var(--np-bg));
  pointer-events:none;
}
.np-hero-inner{ position:relative; z-index:2; max-width:640px; padding:8px 0; }
.np-hero .np-eyebrow{ font-size:1.4rem; }
.np-hero h1{
  font-size:clamp(1.8rem, 4vw, 2.9rem);
  letter-spacing:.04em; text-transform:uppercase; margin:2px 0; line-height:1.04;
  text-shadow:0 4px 30px rgba(0,0,0,.45);
}
.np-hero h1 .np-hero-sub{ white-space:nowrap; }
.np-hero h1 .np-hero-name{ display:block; color:#fff; }
.np-hero h1 .np-hero-sub{ display:block; color:#fff; font-weight:700; }
.np-hero-tag{
  font-size:1.12rem; font-weight:700; color:var(--np-gold);
  margin:10px 0 12px; letter-spacing:.01em;
}
.np-hero-lead{
  font-size:1rem; color:#dcebe8; color:rgba(255,255,255,.9);
  max-width:520px; margin-bottom:18px;
}
.np-hero-cta{ display:flex; flex-wrap:wrap; gap:16px; }

.np-hero-scroll{
  position:absolute; left:50%; bottom:34px; transform:translateX(-50%);
  z-index:2; color:rgba(255,255,255,.7); animation:npBounce 2s infinite;
}
.np-hero-scroll svg{ width:30px; height:30px; }
@keyframes npBounce{ 0%,100%{ transform:translate(-50%,0);} 50%{ transform:translate(-50%,10px);} }

/* ============================================================
   FEATURES BAR
   ============================================================ */
.np-features{
  background:var(--np-bg-2);
  border-top:1px solid var(--np-line);
  border-bottom:1px solid var(--np-line);
  position:relative; z-index:3;
}
.np-features .np-container{
  display:grid; grid-template-columns:repeat(5,1fr); gap:24px;
  padding-top:30px; padding-bottom:30px;
}
.np-feature{ display:flex; align-items:center; gap:14px; }
.np-feature-ic{
  flex:0 0 auto; width:46px; height:46px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(24,185,169,.12); color:var(--np-gold);
}
.np-feature-ic svg{ width:24px; height:24px; }
.np-feature-txt b{ display:block; font-size:.95rem; color:var(--np-heading); font-weight:700; }
.np-feature-txt span{ display:block; font-size:.8rem; color:var(--np-muted); }

/* ============================================================
   EXCURSIONS
   ============================================================ */
.np-exc-grid{
  display:grid; grid-template-columns:repeat(6,1fr); gap:20px;
}
.np-exc-card{
  background:var(--np-surface);
  border:1px solid var(--np-line);
  border-radius:var(--np-radius);
  overflow:hidden;
  display:flex; flex-direction:column;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.np-exc-card:hover{ transform:translateY(-6px); box-shadow:var(--np-shadow); border-color:rgba(230,197,135,.4); }
.np-exc-media{ position:relative; aspect-ratio:4/3; overflow:hidden; }
.np-exc-media img{ width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.np-exc-card:hover .np-exc-media img{ transform:scale(1.06); }
.np-exc-body{ padding:16px 16px 18px; display:flex; flex-direction:column; gap:10px; flex:1; }
.np-exc-body h3{ font-size:1.02rem; letter-spacing:.04em; text-transform:uppercase; color:var(--np-heading); }
.np-exc-meta{ display:flex; flex-wrap:wrap; gap:14px; color:var(--np-muted); font-size:.8rem; margin-top:auto; }
.np-exc-meta span{ display:inline-flex; align-items:center; gap:5px; }
.np-exc-meta svg{ width:15px; height:15px; opacity:.85; }
.np-exc-price{ font-size:1.02rem; font-weight:700; color:var(--np-gold); }
.np-exc-price small{ font-size:.72rem; font-weight:600; color:var(--np-muted); margin-right:4px; }
.np-exc-card a.np-exc-hit{ position:absolute; inset:0; z-index:1; }

.np-exc-foot{ text-align:center; margin-top:42px; }

/* ============================================================
   ABOUT NICKY
   ============================================================ */
.np-about{ background:var(--np-bg-2); padding:0; overflow:hidden; }
.np-about .np-about-grid{
  display:grid; grid-template-columns:1fr 1.15fr; align-items:stretch; gap:0;
}
.np-about-media{ position:relative; min-height:460px; background:linear-gradient(160deg,#16403a,#0b211f); }
.np-about-media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center top; }
.np-about-media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, transparent 60%, var(--np-bg-2) 100%),
             linear-gradient(0deg, rgba(8,26,24,.35), transparent 40%);
}
.np-about-watermark{
  position:absolute; left:26px; bottom:18px; z-index:2;
  font-family:var(--np-font); font-weight:800; letter-spacing:.1em;
  font-size:clamp(2.6rem,7vw,5rem); line-height:1; text-transform:uppercase;
  color:rgba(255,255,255,.14); pointer-events:none;
}
.np-about-body{ padding:72px 56px; display:flex; flex-direction:column; }
.np-about-body h2{ font-size:clamp(1.6rem,3.2vw,2.3rem); margin:2px 0 16px; }
.np-about-body p{ color:var(--np-text); opacity:.92; max-width:560px; }
.np-about-sign{ font-family:'Caveat', cursive; font-weight:700; color:var(--np-gold); font-size:2.6rem; line-height:1; margin-top:8px; }
.np-about-points{
  display:grid; grid-template-columns:1fr 1fr; gap:16px 26px; margin-top:30px;
}
.np-point{ display:flex; align-items:center; gap:12px; font-weight:600; font-size:.95rem; }
.np-point svg{ width:22px; height:22px; color:var(--np-teal); flex:0 0 auto; }

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.np-wa-float{
  position:fixed; right:22px; bottom:22px; z-index:980;
  display:flex; align-items:center; gap:10px;
  background:linear-gradient(135deg,var(--np-green),var(--np-green-2));
  color:#fff; font-weight:700; font-size:.92rem;
  padding:12px 18px 12px 14px; border-radius:999px;
  box-shadow:0 12px 30px rgba(37,211,102,.45);
  transition:transform .2s ease, box-shadow .2s ease;
}
.np-wa-float:hover{ transform:translateY(-3px) scale(1.02); box-shadow:0 18px 40px rgba(37,211,102,.55); }
.np-wa-float .np-wa-ic{
  width:34px; height:34px; border-radius:999px; background:rgba(255,255,255,.18);
  display:flex; align-items:center; justify-content:center;
}
.np-wa-float svg{ width:22px; height:22px; }
.np-wa-float .np-wa-pulse{
  position:absolute; left:14px; top:50%; transform:translateY(-50%);
  width:34px; height:34px; border-radius:999px; background:var(--np-green);
  animation:npPulse 2.2s infinite; z-index:-1;
}
@keyframes npPulse{ 0%{ box-shadow:0 0 0 0 rgba(37,211,102,.5);} 70%{ box-shadow:0 0 0 16px rgba(37,211,102,0);} 100%{ box-shadow:0 0 0 0 rgba(37,211,102,0);} }

/* ============================================================
   FOOTER
   ============================================================ */
.np-footer{ background:var(--np-bg-2); border-top:1px solid var(--np-line); padding:64px 0 28px; }
.np-footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px; }
.np-footer h4{ font-size:1rem; letter-spacing:.06em; text-transform:uppercase; color:var(--np-gold); margin-bottom:18px; }
.np-footer p, .np-footer li{ color:var(--np-muted); font-size:.92rem; }
.np-footer li{ margin-bottom:10px; }
.np-footer a:hover{ color:var(--np-gold); }
.np-footer .np-logo{ margin:0 0 16px; }
.np-foot-contact li{ display:flex; align-items:center; gap:10px; }
.np-foot-contact svg{ width:18px; height:18px; color:var(--np-teal); flex:0 0 auto; }
.np-footer-bottom{
  margin-top:48px; padding-top:22px; border-top:1px solid var(--np-line);
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; align-items:center;
  color:var(--np-muted); font-size:.85rem;
}
.np-footer-legal{ display:flex; gap:18px; flex-wrap:wrap; }
.np-footer-legal a{ color:var(--np-muted); }
.np-footer-legal a:hover{ color:var(--np-gold); }

/* ============================================================
   PAGE / GENERIC CONTENT
   ============================================================ */
.np-page-hero{
  padding:calc(var(--np-header-h) + 60px) 0 56px;
  text-align:center;
  background:linear-gradient(160deg,#0f2b28,var(--np-bg));
  border-bottom:1px solid var(--np-line);
}
.np-page-hero h1{ font-size:clamp(2rem,4.5vw,3rem); letter-spacing:.04em; text-transform:uppercase; }
.np-page-body{ padding:64px 0; }
.np-page-body .np-container{ max-width:880px; }
.np-page-body h2{ margin:1.4em 0 .6em; }
.np-page-body a:not(.np-btn){ color:var(--np-teal); }
.np-page-body a:not(.np-btn):hover{ color:var(--np-gold); }
/* Buttons must always keep their own readable text colour, even inside content. */
.np-page-body .np-btn--wa{ color:#fff; }
.np-page-body .np-btn--primary{ color:#06201d; }
.np-page-hero .np-page-sub{ max-width:640px; margin:14px auto 0; color:var(--np-muted); font-size:1.05rem; }

/* ---- Inner-page components (Хотели / VIP / Отзиви / За мен / Контакти) ---- */
.np-lead-center{ max-width:760px; margin:0 auto; text-align:center; color:var(--np-text); font-size:1.06rem; }
.np-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:44px; }
.np-card{ background:var(--np-surface); border:1px solid var(--np-line); border-radius:var(--np-radius); padding:30px 26px; transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease; }
.np-card:hover{ transform:translateY(-6px); border-color:rgba(230,197,135,.4); box-shadow:var(--np-shadow); }
.np-card-ic{ width:54px; height:54px; border-radius:14px; display:flex; align-items:center; justify-content:center; background:rgba(24,185,169,.12); color:var(--np-gold); margin-bottom:18px; }
.np-card-ic svg{ width:28px; height:28px; }
.np-card h3{ font-size:1.14rem; margin-bottom:10px; letter-spacing:.02em; }
.np-card p{ color:var(--np-muted); font-size:.95rem; margin:0; }

.np-steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; margin-top:44px; }
.np-step{ text-align:center; }
.np-step-n{ width:50px; height:50px; border-radius:999px; margin:0 auto 14px; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:1.2rem; color:#06201d; background:linear-gradient(135deg,var(--np-gold),var(--np-gold-2)); }
.np-step h4{ margin-bottom:8px; font-size:1.05rem; }
.np-step p{ color:var(--np-muted); font-size:.92rem; }

.np-testi{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:10px; }
.np-testi-card{ background:var(--np-surface); border:1px solid var(--np-line); border-radius:var(--np-radius); padding:28px 26px; }
.np-stars{ color:var(--np-gold); display:flex; gap:3px; margin-bottom:14px; }
.np-stars svg{ width:18px; height:18px; fill:currentColor; stroke:none; }
.np-testi-card p{ color:var(--np-text); font-style:italic; margin:0; }
.np-testi-who{ display:flex; align-items:center; gap:12px; margin-top:18px; }
.np-testi-avatar{ width:44px; height:44px; border-radius:999px; background:linear-gradient(135deg,var(--np-teal),var(--np-teal-2)); display:flex; align-items:center; justify-content:center; font-weight:800; color:#06201d; }
.np-testi-who b{ color:var(--np-heading); display:block; }
.np-testi-who span{ color:var(--np-muted); font-size:.85rem; }

.np-contact-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.np-contact-card{ background:var(--np-surface); border:1px solid var(--np-line); border-radius:var(--np-radius); padding:32px 26px; text-align:center; }
.np-contact-card .np-card-ic{ margin:0 auto 16px; }
.np-contact-card h3{ font-size:1.05rem; margin-bottom:8px; }
.np-contact-card a, .np-contact-card p{ color:var(--np-gold); font-weight:600; margin:0; }

.np-cta-band{ text-align:center; padding:60px 0; background:linear-gradient(160deg,#0f2b28,var(--np-bg)); border-top:1px solid var(--np-line); }
.np-cta-band h2{ font-size:clamp(1.5rem,3vw,2.1rem); margin-bottom:10px; }
.np-cta-band p{ color:var(--np-muted); max-width:560px; margin:0 auto 24px; }

@media (max-width:900px){ .np-cards,.np-steps,.np-testi,.np-contact-cards{ grid-template-columns:1fr 1fr; } }
@media (max-width:600px){ .np-cards,.np-steps,.np-testi,.np-contact-cards{ grid-template-columns:1fr; } }

/* ============================================================
   WOOCOMMERCE
   ============================================================ */
.np-shop-wrap{ padding:calc(var(--np-header-h) + 50px) 0 80px; }
.np-shop-wrap .np-container{ max-width:var(--np-container); }
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering{ color:var(--np-muted); }
.woocommerce ul.products li.product .price{ color:var(--np-gold)!important; font-weight:700; }
.woocommerce ul.products li.product .woocommerce-loop-product__title{ color:var(--np-heading); }
.woocommerce span.onsale{ background:var(--np-gold); color:#06201d; }
.woocommerce #respond input#submit,
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce a.button.alt, .woocommerce button.button.alt{
  background:linear-gradient(135deg,var(--np-teal),var(--np-teal-2))!important;
  color:#06201d!important; border-radius:999px!important; font-weight:700!important;
  border:0!important; padding:.7em 1.6em!important;
}
.woocommerce a.button:hover, .woocommerce button.button:hover{ filter:brightness(1.06); }
.woocommerce div.product p.price, .woocommerce div.product span.price{ color:var(--np-gold); }
.woocommerce-message, .woocommerce-info, .woocommerce-error{
  border-top-color:var(--np-teal); background:var(--np-surface); color:var(--np-text);
}
.woocommerce-message::before, .woocommerce-info::before{ color:var(--np-teal); }

/* ---- Excursion booking form (single product) ---- */
.np-per{ font-size:.72rem; color:var(--np-muted); font-weight:600; }
.np-field-label{ display:block; font-size:.85rem; font-weight:600; color:var(--np-muted); margin-bottom:6px; }
.np-included{ display:flex; flex-direction:column; gap:9px; margin:18px 0 22px; padding:0; }
.np-included li{ display:flex; align-items:center; gap:10px; color:var(--np-text); font-weight:500; }
.np-included svg{ width:20px; height:20px; color:var(--np-teal); flex:0 0 auto; }
.np-booking{ display:grid; grid-template-columns:1fr 1fr; gap:16px; margin:6px 0 20px; }
.np-booking-field{ display:block; }
.np-booking input[type="date"], .np-booking input[type="text"], .np-booking input[type="number"]{
  width:100%; padding:13px 14px; border-radius:10px; border:1px solid var(--np-line-2);
  background:var(--np-bg-2); color:var(--np-text); font-family:inherit; font-size:.95rem;
  color-scheme:dark;
}
.np-booking input:focus{ outline:none; border-color:var(--np-teal); box-shadow:0 0 0 3px rgba(24,185,169,.18); }
.np-field-label small{ color:var(--np-gold); font-weight:700; margin-left:4px; }
.np-booking-total{ font-size:1.02rem; color:var(--np-text); margin:0 0 2px; }
.np-booking-total .np-total-val{ color:var(--np-gold); font-size:1.4rem; font-weight:800; margin-left:6px; }
.woocommerce div.product form.cart{ display:flex; flex-wrap:wrap; align-items:center; gap:14px; margin-bottom:1.6em; }
.woocommerce div.product form.cart .np-booking{ flex:1 1 100%; }
.woocommerce div.product form.cart .np-booking-total{ flex:1 1 100%; }
.woocommerce div.product form.cart button.single_add_to_cart_button{ flex:1 1 auto; min-width:220px; }
.np-wa-book{ flex:1 1 100%; justify-content:center; margin-top:4px; }
@media (max-width:560px){ .np-booking{ grid-template-columns:1fr; } }

/* ---- Ratings + trust badges ---- */
.np-rating{ display:inline-flex; align-items:center; gap:5px; font-size:.86rem; color:var(--np-muted); }
.np-rating svg{ width:16px; height:16px; fill:var(--np-gold); stroke:none; }
.np-rating b{ color:var(--np-heading); font-weight:700; }
.np-exc-body .np-rating{ margin:-2px 0 0; }

.np-trust{ display:grid; grid-template-columns:1fr 1fr; gap:12px 18px; margin:6px 0 0; padding:20px 0 0; border-top:1px solid var(--np-line); }
.np-trust li{ display:flex; align-items:center; gap:10px; color:var(--np-text); font-size:.9rem; font-weight:500; }
.np-trust svg{ width:20px; height:20px; color:var(--np-teal); flex:0 0 auto; }

/* WooCommerce native star rating -> gold */
.woocommerce .star-rating{ color:var(--np-gold); }
.woocommerce .star-rating::before{ color:rgba(230,197,135,.32); }
.woocommerce .woocommerce-product-rating{ margin-bottom:14px; }
.woocommerce .woocommerce-product-rating .woocommerce-review-link{ color:var(--np-muted); }
.woocommerce ul.products li.product .star-rating{ margin:0 auto 8px 0; }
.woocommerce #reviews .commentlist{ color:var(--np-text); }
.woocommerce #reviews .comment-text{ background:var(--np-surface); border:1px solid var(--np-line); border-radius:12px; padding:18px 20px; }

/* ---- Rich excursion details ---- */
.np-details{ margin-top:8px; clear:both; }
.np-details-inner{ max-width:920px; }
.np-detail-block{ padding:26px 0; border-top:1px solid var(--np-line); }
.np-detail-block:first-child{ border-top:0; padding-top:6px; }
.np-detail-block h2{ font-size:1.4rem; margin-bottom:16px; letter-spacing:.01em; }
.np-detail-desc{ color:var(--np-text); }
.np-incl-list{ display:flex; flex-direction:column; gap:10px; }
.np-incl-list li{ display:flex; align-items:flex-start; gap:10px; color:var(--np-text); }
.np-incl-list svg{ width:20px; height:20px; flex:0 0 auto; margin-top:2px; }
.np-incl-yes svg{ color:var(--np-teal); }
.np-incl-no svg{ color:#d98a8a; }
.np-incl-no li{ color:var(--np-muted); }
.np-incl-grid{ display:grid; grid-template-columns:1fr 1fr; gap:30px; }
.np-incl-h{ font-size:1.05rem; margin-bottom:14px; color:var(--np-gold); }
.np-know{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.np-know-item{ display:flex; align-items:flex-start; gap:14px; }
.np-know-item .np-card-ic{ width:44px; height:44px; margin:0; flex:0 0 auto; }
.np-know-item .np-card-ic svg{ width:22px; height:22px; }
.np-know-item b{ display:block; color:var(--np-heading); }
.np-know-item span{ color:var(--np-muted); font-size:.92rem; }
.np-faq{ display:flex; flex-direction:column; gap:10px; }
.np-faq-item{ background:var(--np-surface); border:1px solid var(--np-line); border-radius:12px; overflow:hidden; }
.np-faq-item summary{ list-style:none; cursor:pointer; padding:16px 18px; display:flex; align-items:center; justify-content:space-between; gap:12px; font-weight:600; color:var(--np-heading); }
.np-faq-item summary::-webkit-details-marker{ display:none; }
.np-faq-item summary svg{ width:20px; height:20px; transition:transform .25s ease; color:var(--np-muted); flex:0 0 auto; }
.np-faq-item[open] summary svg{ transform:rotate(180deg); }
.np-faq-a{ padding:0 18px 16px; color:var(--np-muted); }
.np-cancel{ display:flex; align-items:center; gap:14px; }
.np-cancel .np-card-ic{ margin:0; flex:0 0 auto; }
.np-cancel b{ display:block; color:var(--np-heading); }
.np-cancel span{ color:var(--np-muted); font-size:.92rem; }
@media (max-width:680px){ .np-incl-grid, .np-know{ grid-template-columns:1fr; } }

/* ---- Discovery: collections + shop toolbar + header search ---- */
.np-search-link{ display:flex; align-items:center; color:var(--np-text); }
.np-search-link svg{ width:22px; height:22px; }
.np-search-link:hover{ color:var(--np-gold); }
.np-collections{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.np-collection{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:6px; padding:30px 18px; background:var(--np-surface); border:1px solid var(--np-line); border-radius:var(--np-radius); transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease; }
.np-collection:hover{ transform:translateY(-6px); border-color:rgba(230,197,135,.4); box-shadow:var(--np-shadow); }
.np-collection-ic{ width:58px; height:58px; border-radius:16px; display:flex; align-items:center; justify-content:center; background:rgba(24,185,169,.12); color:var(--np-gold); margin-bottom:6px; }
.np-collection-ic svg{ width:30px; height:30px; }
.np-collection b{ color:var(--np-heading); font-size:1.05rem; }
.np-collection small{ color:var(--np-muted); font-size:.82rem; }
.np-shop-toolbar{ display:flex; flex-wrap:wrap; align-items:center; gap:16px; margin-bottom:28px; }
.np-shop-search{ position:relative; flex:1 1 260px; max-width:360px; display:flex; align-items:center; }
.np-shop-search svg{ position:absolute; left:14px; width:18px; height:18px; color:var(--np-muted); pointer-events:none; }
.np-shop-search input{ width:100%; padding:12px 14px 12px 42px; border-radius:999px; border:1px solid var(--np-line-2); background:var(--np-bg-2); color:var(--np-text); font-family:inherit; font-size:.92rem; }
.np-shop-search input:focus{ outline:none; border-color:var(--np-teal); }
.np-pills{ display:flex; flex-wrap:wrap; gap:8px; }
.np-pill{ display:inline-flex; align-items:center; gap:6px; padding:9px 16px; border-radius:999px; border:1px solid var(--np-line-2); color:var(--np-text); font-size:.86rem; font-weight:600; background:var(--np-surface); transition:border-color .2s ease, color .2s ease, background .2s ease; }
.np-pill svg{ width:16px; height:16px; }
.np-pill:hover{ border-color:var(--np-gold); color:var(--np-gold); }
.np-pill.is-active{ background:linear-gradient(135deg,var(--np-teal),var(--np-teal-2)); color:#06201d; border-color:transparent; }
@media (max-width:900px){ .np-collections{ grid-template-columns:1fr 1fr; } .np-search-link{ display:none; } }

/* ---- Breadcrumbs ---- */
.np-breadcrumb{ color:var(--np-muted); font-size:.86rem; margin-bottom:22px; }
.np-breadcrumb a{ color:var(--np-muted); }
.np-breadcrumb a:hover{ color:var(--np-gold); }
.np-bc-sep{ margin:0 8px; opacity:.5; }

/* ---- Sticky mobile booking bar ---- */
.np-sticky-book{ display:none; }
@media (max-width:900px){
  .np-sticky-book{
    display:flex; position:fixed; left:0; right:0; bottom:0; z-index:990;
    align-items:center; gap:14px; padding:11px 16px;
    background:rgba(8,26,24,.97); backdrop-filter:blur(10px); border-top:1px solid var(--np-line-2);
  }
  .np-sticky-price{ flex:1; font-size:1.05rem; font-weight:800; color:var(--np-gold); line-height:1.1; }
  .np-sticky-price small{ font-size:.68rem; color:var(--np-muted); font-weight:600; margin-right:4px; }
  .np-sticky-price .np-per{ display:none; }
  .np-sticky-btn{ flex:0 0 auto; }
  .single-product{ padding-bottom:72px; }
}

/* ============================================================
   MOBILE OPTIMIZATION
   ============================================================ */
@media (max-width:900px){
  :root{ --np-header-h:70px; }
  /* Header was overflowing: hide the WhatsApp button (floating one covers it),
     shrink the logo so the burger always fits. */
  .np-header .np-btn--wa{ display:none; }
  .np-header-actions{ gap:10px; }
  .np-logo{ gap:9px; }
  .np-logo svg{ width:34px; height:34px; }
  .np-logo-img{ height:40px; }
  .np-logo-text .np-logo-name{ font-size:1.15rem; letter-spacing:.08em; }
  .np-logo-text .np-logo-sub{ font-size:.5rem; letter-spacing:.26em; }
  .np-cart-link svg{ width:22px; height:22px; }
  /* On the product page the sticky bar is the CTA — drop the floating WA to avoid overlap. */
  .single-product .np-wa-float{ display:none; }
  /* Comfortable tap targets in the mobile menu. */
  .np-nav.is-open a{ font-size:1rem; }
}
@media (max-width:600px){
  .np-container{ padding:0 20px; }
  .np-hero-cta .np-btn{ width:100%; justify-content:center; }
  .np-section{ padding:54px 0; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px){
  .np-exc-grid{ grid-template-columns:repeat(3,1fr); }
  .np-features .np-container{ grid-template-columns:repeat(3,1fr); row-gap:26px; }
}
@media (max-width:900px){
  .np-nav, .np-lang{ display:none; }
  .np-burger{ display:block; }
  .np-about .np-about-grid{ grid-template-columns:1fr; }
  .np-about-media{ min-height:300px; }
  .np-about-body{ padding:48px 24px; }
  .np-footer-grid{ grid-template-columns:1fr 1fr; gap:32px; }
  /* mobile nav drawer */
  .np-nav.is-open{
    display:flex; position:fixed; top:var(--np-header-h); left:0; right:0;
    flex-direction:column; align-items:flex-start; gap:0;
    background:rgba(8,26,24,.98); padding:14px 24px 24px;
  }
  .np-nav.is-open a{ width:100%; padding:12px 0; } .np-nav.is-open a::after{ display:none !important; }
}
@media (max-width:640px){
  .np-exc-grid{ grid-template-columns:repeat(2,1fr); }
  .np-features .np-container{ grid-template-columns:1fr 1fr; }
  .np-about-points{ grid-template-columns:1fr; }
  .np-footer-grid{ grid-template-columns:1fr; }
  .np-section{ padding:60px 0; }
  .np-hero-cta .np-btn{ flex:1 1 100%; justify-content:center; }
  .np-wa-float span{ display:none; }
  .np-wa-float{ padding:14px; }
}

/* Контактни CTA бутони (Viber/Telegram/WhatsApp) вместо booking */
.np-contact-cta { margin:1.5rem 0; }
.np-contact-cta__title { font-weight:600; margin:0 0 0.8rem; font-size:1.05rem; }
.np-contact-cta__btns { display:flex; flex-direction:column; gap:0.7rem; }
.np-btn { display:flex; align-items:center; justify-content:center; gap:0.6rem; padding:0.95rem 1.4rem; border-radius:0.7rem; font-weight:700; font-size:1.05rem; text-decoration:none; color:#fff; transition:transform .15s ease, box-shadow .15s ease; }
.np-btn:hover { transform:translateY(-2px); box-shadow:0 8px 22px rgba(0,0,0,0.25); color:#fff; }
.np-btn svg { width:24px; height:24px; flex-shrink:0; }
.np-btn--viber { background:#7360f2; }
.np-btn--telegram { background:#229ED9; }
.np-btn--wa { background:#25D366; }
@media (min-width:600px){ .np-contact-cta__btns { flex-direction:row; } .np-btn { flex:1; } }

/* Social icons (footer + contacts) */
.np-foot-social { display:flex; gap:12px; margin-top:14px; }
.np-foot-social--center { justify-content:center; }
.np-foot-social a { display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; border-radius:50%; background:rgba(255,255,255,0.1); color:#fff; transition:transform .15s ease, background .15s ease; }
.np-foot-social a:hover { transform:translateY(-2px); }
.np-foot-social a svg { width:22px; height:22px; }
.np-foot-social a[aria-label="Facebook"]:hover { background:#1877F2; }
.np-foot-social a[aria-label="Instagram"]:hover { background:#E1306C; }
.np-foot-social a[aria-label="Viber"]:hover { background:#7360f2; }
.np-foot-social a[aria-label="WhatsApp"]:hover { background:#25D366; }

/* TikTok + hero viber/telegram buttons */
.np-foot-social a[aria-label="TikTok"]:hover { background:#000; }
.np-btn--viber { background:#7360f2; color:#fff; }
.np-btn--telegram { background:#229ED9; color:#fff; }
.np-btn--viber:hover, .np-btn--telegram:hover { filter:brightness(1.08); }

/* ===== Floating contact FAB (multi-option) ===== */
.np-fab{ position:fixed; right:22px; bottom:22px; z-index:980; display:flex; flex-direction:column; align-items:flex-end; gap:12px; }
.np-fab-trigger{ position:relative; display:flex; align-items:center; gap:10px; border:0; cursor:pointer;
  background:linear-gradient(135deg,var(--np-green),var(--np-green-2)); color:#fff; font-weight:700; font-size:.92rem;
  padding:12px 18px 12px 14px; border-radius:999px; box-shadow:0 12px 30px rgba(37,211,102,.45); transition:transform .2s ease; font-family:inherit; }
.np-fab-trigger:hover{ transform:translateY(-3px) scale(1.02); }
.np-fab-trigger-ic{ width:34px; height:34px; border-radius:999px; background:rgba(255,255,255,.18); display:flex; align-items:center; justify-content:center; }
.np-fab-trigger-ic svg{ width:22px; height:22px; }
.np-fab-trigger-x{ display:none; font-size:26px; line-height:1; width:34px; text-align:center; }
.np-fab.is-open .np-fab-trigger-ic, .np-fab.is-open .np-wa-pulse{ display:none; }
.np-fab.is-open .np-fab-trigger-x{ display:block; }
.np-fab.is-open .np-fab-trigger-text{ display:none; }
.np-fab .np-wa-pulse{ position:absolute; left:14px; top:50%; transform:translateY(-50%); width:34px; height:34px; border-radius:999px; background:var(--np-green); animation:npPulse 2.2s infinite; z-index:-1; }
.np-fab-menu{ display:flex; flex-direction:column; align-items:flex-end; gap:10px; opacity:0; pointer-events:none; transform:translateY(10px); transition:opacity .2s ease, transform .2s ease; }
.np-fab.is-open .np-fab-menu{ opacity:1; pointer-events:auto; transform:translateY(0); }
.np-fab-item{ display:flex; align-items:center; gap:10px; padding:9px 16px 9px 12px; border-radius:999px; color:#fff; font-weight:600; font-size:.9rem; text-decoration:none; box-shadow:0 8px 20px rgba(0,0,0,.25); transition:transform .15s ease; white-space:nowrap; }
.np-fab-item:hover{ transform:translateX(-3px); color:#fff; }
.np-fab-ic{ width:30px; height:30px; border-radius:999px; background:rgba(255,255,255,.2); display:flex; align-items:center; justify-content:center; }
.np-fab-ic svg{ width:18px; height:18px; }
.np-fab-item--wa{ background:#25D366; }
.np-fab-item--viber{ background:#7360f2; }
.np-fab-item--tg{ background:#229ED9; }
.np-fab-item--tel{ background:#0e3a36; }

/* CTA band — multiple contact buttons inline */
.np-cta-band .np-btn{ display:inline-flex; vertical-align:middle; margin:6px; }
.np-cta-band .np-btn--viber{ background:#7360f2; color:#fff; }
.np-cta-band .np-btn--telegram{ background:#229ED9; color:#fff; }

/* Contacts page portrait */
.np-contact-photo{ max-width:420px; margin:0 auto; border-radius:18px; overflow:hidden; box-shadow:0 18px 50px rgba(0,0,0,.35); }
.np-contact-photo img{ display:block; width:100%; height:auto; }

/* Header contact dropdown */
.np-hcontact{ position:relative; }
.np-hcontact-trigger{ display:inline-flex; align-items:center; gap:8px; border:0; cursor:pointer; font-family:inherit; }
.np-hcontact-trigger svg:last-child{ width:16px; height:16px; transition:transform .2s ease; }
.np-hcontact.is-open .np-hcontact-trigger svg:last-child{ transform:rotate(180deg); }
.np-hcontact-menu{ position:absolute; top:calc(100% + 10px); right:0; min-width:230px; background:#0e3a36; border:1px solid var(--np-line); border-radius:14px; box-shadow:0 18px 44px rgba(0,0,0,.4); padding:8px; display:flex; flex-direction:column; gap:4px; opacity:0; pointer-events:none; transform:translateY(8px); transition:opacity .2s ease, transform .2s ease; z-index:1001; }
.np-hcontact:hover .np-hcontact-menu, .np-hcontact.is-open .np-hcontact-menu{ opacity:1; pointer-events:auto; transform:translateY(0); }
.np-hc-item{ display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:9px; color:#fff; font-weight:600; font-size:.9rem; text-decoration:none; white-space:nowrap; transition:background .15s ease; }
.np-hc-item svg{ width:18px; height:18px; }
.np-hc-item--wa:hover{ background:#25D366; }
.np-hc-item--viber:hover{ background:#7360f2; }
.np-hc-item--tg:hover{ background:#229ED9; }
.np-hc-item--tel:hover{ background:rgba(255,255,255,.12); }


/* NP brand social colors v2.4.2 */
.np-footer .np-foot-social a, .np-foot-social--center a { color:#fff; }
.np-footer .np-foot-social a[aria-label="Facebook"], .np-foot-social--center a[aria-label="Facebook"]{ background:#1877F2; }
.np-footer .np-foot-social a[aria-label="Instagram"], .np-foot-social--center a[aria-label="Instagram"]{ background:radial-gradient(circle at 30% 107%,#fdf497 0%,#fdf497 5%,#fd5949 45%,#d6249f 60%,#285AEB 90%); }
.np-footer .np-foot-social a[aria-label="TikTok"], .np-foot-social--center a[aria-label="TikTok"]{ background:#010101; box-shadow:inset 0 0 0 1px rgba(255,255,255,.18); }
.np-footer .np-foot-social a[aria-label="Viber"], .np-foot-social--center a[aria-label="Viber"]{ background:#7360F2; }
.np-footer .np-foot-social a[aria-label="Telegram"], .np-foot-social--center a[aria-label="Telegram"]{ background:#29A9EB; }
.np-footer .np-foot-social a[aria-label="WhatsApp"], .np-foot-social--center a[aria-label="WhatsApp"]{ background:#25D366; }
.np-footer .np-foot-social a:hover, .np-foot-social--center a:hover{ transform:translateY(-2px); filter:brightness(1.1); }


/* NP header dropdown colored icons v2.4.4 */
.np-hc-item--wa svg{ color:#25D366; }
.np-hc-item--viber svg{ color:#7360F2; }
.np-hc-item--tg svg{ color:#29A9EB; }
.np-hc-item--tel svg{ color:#18B9A9; }
.np-hc-item:hover svg{ color:#fff; }


/* NP contacts cards 3x2 v2.4.5 */
.np-contact-cards{ grid-template-rows:repeat(2,auto); grid-auto-flow:column; }
.np-contact-cards .np-contact-card{ display:flex; flex-direction:column; justify-content:center; }
@media (max-width:900px){ .np-contact-cards{ grid-auto-flow:row; grid-template-rows:auto; } }


/* NP YouTube brand color v2.4.7 */
.np-footer .np-foot-social a[aria-label="YouTube"], .np-foot-social--center a[aria-label="YouTube"]{ background:#FF0000; }


/* TikTok icon size match v2.4.9 */
.np-foot-social a[aria-label="TikTok"] svg{ width:32px; height:32px; }
