
/* ==========================================================
   V62 APP STYLE — Prostyi Sad
   Єдиний мобільний/app-style вигляд для сайту
   ========================================================== */
:root{
  --ps-green:#16a34a;
  --ps-green-dark:#166534;
  --ps-green-soft:#ecfdf3;
  --ps-mint:#f3fbf4;
  --ps-cream:#fffaf0;
  --ps-ink:#0f172a;
  --ps-muted:#64748b;
  --ps-line:#dcebdd;
  --ps-card:#ffffff;
  --ps-shadow:0 16px 42px rgba(15,23,42,.08);
  --ps-radius:24px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:
    radial-gradient(circle at 50% -80px, rgba(34,197,94,.16), transparent 410px),
    linear-gradient(180deg,#f7fbf4 0%,#fff8ed 100%) !important;
  color:var(--ps-ink);
  -webkit-font-smoothing:antialiased;
}
body:not(.ps-no-app-nav){padding-bottom:calc(92px + env(safe-area-inset-bottom));}
body a{transition:background .18s ease,border-color .18s ease,transform .18s ease,box-shadow .18s ease}
body a:hover{transform:translateY(-1px)}
.container,.wrap,.shell{
  width:min(1180px, calc(100vw - 28px)) !important;
  max-width:1180px !important;
  margin-left:auto !important;
  margin-right:auto !important;
}
.topbar{
  border:1px solid rgba(22,101,52,.10);
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(14px);
  border-radius:22px;
  padding:10px 12px;
  box-shadow:0 10px 30px rgba(15,23,42,.055);
}
.logo,.brand-dot{
  background:linear-gradient(135deg,#16a34a,#22c55e) !important;
  color:#fff !important;
  box-shadow:0 8px 20px rgba(22,163,74,.20);
}
.hero,.card,.section-card,.hero-card,.feature-card,.quick-card,.product-card,.paycard,.panel-card,.month-card,.tool-card{
  border-radius:var(--ps-radius) !important;
  border:1px solid rgba(22,101,52,.11) !important;
  box-shadow:var(--ps-shadow) !important;
}
.card,.section-card,.hero-card,.feature-card,.product-card,.panel-card,.month-card,.tool-card{
  background:rgba(255,255,255,.94) !important;
}
.hero{
  background:
    radial-gradient(circle at 92% 8%, rgba(34,197,94,.13), transparent 230px),
    rgba(255,255,255,.92) !important;
}
.h-title,.title,.section-title,h1,h2{
  letter-spacing:-.02em;
}
.h-sub,.sub,.section-sub,.subtitle,.small-note{
  color:var(--ps-muted) !important;
  line-height:1.48 !important;
}
.btn,button.btn,.tab,.pill,.back,.club-link,.quick-card,.club-quicklink{
  border-radius:18px !important;
}
.btn,button.btn{
  min-height:48px;
  font-weight:900 !important;
  box-shadow:0 10px 24px rgba(22,163,74,.14);
}
.btn:not(.secondary){
  background:linear-gradient(135deg,#16a34a,#22c55e) !important;
  color:#fff !important;
  border:0 !important;
}
.btn.secondary,.pill,.back{
  background:#fff !important;
  border:1px solid rgba(22,101,52,.16) !important;
  color:var(--ps-green-dark) !important;
}
input,select,textarea{
  border-radius:16px !important;
  border:1px solid rgba(22,101,52,.18) !important;
  background:#fff !important;
  min-height:46px;
}
input:focus,select:focus,textarea:focus{
  outline:none !important;
  border-color:rgba(22,163,74,.75) !important;
  box-shadow:0 0 0 4px rgba(22,163,74,.13) !important;
}
.badge,.history-badge{
  border-radius:999px !important;
  background:var(--ps-green-soft) !important;
  border:1px solid #bbf7d0 !important;
  color:var(--ps-green-dark) !important;
  font-weight:900 !important;
}

/* App launch card */
.ps-app-launch{
  margin:14px 0 12px;
  padding:16px;
  border-radius:24px;
  background:linear-gradient(135deg,#ecfdf3,#fff);
  border:1px solid #bbf7d0;
  box-shadow:0 14px 34px rgba(22,163,74,.10);
}
.ps-app-launch__title{font-weight:1000;font-size:18px;margin-bottom:4px;color:#14532d}
.ps-app-launch__text{color:#48614b;font-size:14px;line-height:1.45;margin-bottom:12px}
.ps-app-launch__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}

/* Homepage: more app-like */
.home .hero-grid{gap:18px}
.home-quick-grid{
  display:grid !important;
  grid-template-columns:repeat(5,minmax(0,1fr)) !important;
  gap:12px !important;
}
.quick-card{
  min-height:116px;
  background:#fff !important;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  padding:16px !important;
}
.quick-card__icon{font-size:26px}
.quick-card__title{font-weight:1000}
.quick-card__sub{color:var(--ps-muted);font-size:13px}

/* Diagnosis layout */
body.page-diagnostyka main{
  width:min(1420px, calc(100vw - 28px)) !important;
  max-width:1420px !important;
  margin-left:auto !important;
  margin-right:auto !important;
}
body.page-diagnostyka .diag-grid{
  width:100% !important;
  display:grid !important;
  grid-template-columns:minmax(0,1.25fr) minmax(360px,.9fr) !important;
  gap:22px !important;
  align-items:start !important;
}
body.page-diagnostyka #photo-ai,
body.page-diagnostyka #explain-ai{
  width:100% !important;
  max-width:none !important;
}
body.page-diagnostyka .club-card{
  border-radius:24px !important;
}
.diag-section{
  border-radius:22px !important;
  background:linear-gradient(180deg,#ffffff,#fbfff9) !important;
}
.ai-pro-collapsible{
  border-radius:22px !important;
}
#explain-ai{
  max-height:none;
}

/* Shop/catalog */
.wrap .card img,.product-card img,.plant-card img{
  border-radius:18px !important;
}
.tabs.is-visible,.tabs{
  gap:10px !important;
  overflow-x:auto;
  padding:4px 0;
}
.tab{
  white-space:nowrap;
  min-width:120px;
}
.card .price,.price,.paycard-price{
  color:#14532d !important;
  font-weight:1000 !important;
}

/* Calendar/care/history */
.calendar-grid,.months-grid,.grid{
  gap:12px !important;
}
.month-card,.section-card{
  overflow:hidden;
}

/* Bottom app navigation */
.ps-app-bottom-nav{
  position:fixed;
  left:50%;
  bottom:calc(10px + env(safe-area-inset-bottom));
  transform:translateX(-50%);
  z-index:9999;
  width:min(560px, calc(100vw - 20px));
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:6px;
  padding:8px;
  border-radius:24px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(22,101,52,.16);
  box-shadow:0 18px 50px rgba(15,23,42,.18);
  backdrop-filter:blur(18px);
}
.ps-app-bottom-nav a{
  text-decoration:none;
  color:#49614b;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:3px;
  min-height:54px;
  border-radius:18px;
  font-size:11px;
  font-weight:900;
}
.ps-app-bottom-nav a span:first-child{font-size:19px;line-height:1}
.ps-app-bottom-nav a.is-active{
  background:linear-gradient(135deg,#16a34a,#22c55e);
  color:#fff;
  box-shadow:0 10px 22px rgba(22,163,74,.25);
}

/* App hub page */
.ps-app-shell{
  width:min(560px, calc(100vw - 24px));
  margin:0 auto;
  padding:16px 0 110px;
}
.ps-app-hero{
  padding:22px;
  border-radius:30px;
  background:linear-gradient(135deg,#ecfdf3,#ffffff);
  border:1px solid #bbf7d0;
  box-shadow:var(--ps-shadow);
}
.ps-app-hero h1{margin:8px 0 6px;font-size:30px}
.ps-app-hero p{margin:0;color:var(--ps-muted);line-height:1.45}
.ps-app-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:14px;
}
.ps-app-tile{
  min-height:140px;
  padding:16px;
  border-radius:26px;
  border:1px solid rgba(22,101,52,.12);
  background:#fff;
  box-shadow:0 12px 32px rgba(15,23,42,.07);
  text-decoration:none;
  color:var(--ps-ink);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.ps-app-tile__icon{font-size:30px}
.ps-app-tile__title{font-weight:1000;font-size:17px}
.ps-app-tile__sub{font-size:13px;color:var(--ps-muted);line-height:1.35}

/* Desktop */
@media (min-width:980px){
  .ps-app-bottom-nav{bottom:18px}
}
/* Tablet/mobile */
@media (max-width:1100px){
  .home-quick-grid{grid-template-columns:repeat(3,minmax(0,1fr)) !important}
}
@media (max-width:980px){
  body.page-diagnostyka .diag-grid{grid-template-columns:1fr !important}
  #explain-ai{position:static !important}
}
@media (max-width:760px){
  .container,.wrap,.shell{
    width:calc(100vw - 18px) !important;
  }
  .topbar{
    position:sticky;
    top:8px;
    z-index:20;
    margin-top:8px;
  }
  .home-quick-grid{grid-template-columns:1fr 1fr !important}
  .quick-card{min-height:108px;padding:14px !important}
  .ps-app-launch__grid{grid-template-columns:1fr}
  .ps-app-grid{grid-template-columns:1fr 1fr}
  .ps-app-tile{min-height:126px;padding:14px}
  .ps-app-hero h1{font-size:26px}
  .hero,.card,.section-card,.hero-card{border-radius:24px !important}
  .diag-steps{grid-template-columns:1fr !important}
  .photo-two{grid-template-columns:1fr !important}
}
@media (max-width:430px){
  .ps-app-grid{grid-template-columns:1fr}
  .ps-app-bottom-nav a{font-size:10px}
}

/* ===== V62.1 FIX: diagnosis submit button above app bottom navigation ===== */
@media (max-width:760px){
  body.page-diagnostyka{
    padding-bottom:calc(210px + env(safe-area-inset-bottom)) !important;
  }
  body.page-diagnostyka .sticky-submit{
    position:fixed !important;
    left:16px !important;
    right:16px !important;
    bottom:calc(92px + env(safe-area-inset-bottom)) !important;
    z-index:10050 !important;
    width:auto !important;
    max-width:none !important;
    min-height:56px !important;
    border-radius:18px !important;
    font-size:17px !important;
    box-shadow:0 16px 38px rgba(22,163,74,.32) !important;
  }
  body.page-diagnostyka.sticky-submit-hidden .sticky-submit{
    opacity:0 !important;
    transform:translateY(18px) !important;
    pointer-events:none !important;
  }
}


/* ===== V62.2 ADD TO HOME SCREEN ===== */
button.ps-install-btn{cursor:pointer;font-family:inherit}
.ps-install-modal{
  position:fixed;
  inset:0;
  z-index:20000;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:18px;
  background:rgba(15,23,42,.42);
  backdrop-filter:blur(8px);
}
.ps-install-sheet{
  width:min(520px,100%);
  border-radius:28px;
  background:#fff;
  border:1px solid rgba(22,101,52,.14);
  box-shadow:0 24px 80px rgba(15,23,42,.28);
  padding:18px;
}
.ps-install-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.ps-install-title{font-size:21px;font-weight:1000;color:#0f172a;line-height:1.15}
.ps-install-sub{color:#64748b;font-size:14px;line-height:1.45;margin-top:5px}
.ps-install-close{width:42px;height:42px;border-radius:999px;border:1px solid #dcebdd;background:#f8fafc;font-size:22px;line-height:1;cursor:pointer}
.ps-install-steps{display:grid;gap:10px;margin-top:12px}
.ps-install-step{padding:13px 14px;border-radius:18px;background:#f6fff6;border:1px solid #d9f2dc;color:#244b1e;line-height:1.4;font-weight:800}
.ps-install-step small{display:block;color:#64748b;font-weight:600;margin-top:3px}
.ps-install-ok{margin-top:14px;width:100%}
@media (min-width:760px){.ps-install-modal{align-items:center}.ps-install-sheet{padding:20px}}
