/* ============================================================
   POP / GEN-Z design language — print-split profiles
   Self-contained. Does NOT depend on landing.css / community.css.
   Prefix: pp-  (pop-profile)
   ============================================================ */

:root{
  /* surfaces */
  --bg:#FFFDF7;          /* warm almost-white page */
  --bg2:#F6F2EA;         /* section / track */
  --card:#FFFFFF;        /* cards */
  /* ink */
  --ink:#141414;
  --ink2:#5B5B66;
  --line:rgba(20,20,20,.08);
  --line2:rgba(20,20,20,.14);
  /* pop colors */
  --coral:#FF5E7E;
  --violet:#7C5CFF;
  --blue:#2E6BFF;
  --lime:#C6F24E;
  --sun:#FFC53D;
  /* gradients */
  --grad-hero:linear-gradient(135deg,#FF5E7E 0%,#7C5CFF 100%);
  --grad-2:linear-gradient(120deg,#2E6BFF,#7C5CFF);
  /* status */
  --ok:#1FBF75;
  --warn:#FF9F1C;
  --err:#FF4D5E;
  /* radii */
  --r:22px;
  --r-lg:32px;
  --pill:999px;
  /* shadows */
  --shadow:0 8px 30px rgba(20,20,20,.06);
  --shadow-lg:0 20px 50px -20px rgba(124,92,255,.35);
  /* fonts */
  --font-display:'Unbounded',system-ui,sans-serif;
  --font:'Inter',system-ui,-apple-system,sans-serif;
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  /* КАНОН витрины (lp-body): тёплый холст + мягкие candy-подсветки коралл/фиолет */
  background:
    radial-gradient(1100px 520px at 12% -8%, rgba(124,92,255,.10), transparent 60%),
    radial-gradient(900px 480px at 96% 4%, rgba(255,94,126,.10), transparent 55%),
    var(--bg);
  background-attachment:fixed;
  color:var(--ink);
  font-family:var(--font);
  font-size:15px;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
button{ font-family:inherit; }
a{ color:inherit; }

/* ---------- carrying column ---------- */
.pp-col{ max-width:560px; margin:0 auto; padding:0 16px; }

/* decorative blobs */
.pp-blob{
  position:absolute; border-radius:50%;
  filter:blur(40px); pointer-events:none; z-index:0;
}

/* ---------- card ---------- */
.pp-card{
  position:relative;
  background:var(--card);
  border-radius:var(--r);
  box-shadow:var(--shadow);
  padding:18px;
  margin-bottom:16px;
}
.pp-card-title{
  font:800 17px var(--font-display);
  letter-spacing:-.01em;
  margin:0 0 12px;
}
.pp-card-sub{ color:var(--ink2); font:500 12px var(--font); margin:-8px 0 12px; }

/* spring hover */
.pp-spring{ transition:transform .18s cubic-bezier(.34,1.56,.64,1), box-shadow .18s; }
.pp-spring:hover{ transform:translateY(-2px); box-shadow:var(--shadow-lg); }

/* =====================================================
   STICKY NAV
   ===================================================== */
.pp-nav{
  position:sticky; top:0; z-index:50; height:56px;
  display:flex; align-items:center; justify-content:space-between;
  background:rgba(255,253,247,.8); backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line); padding:0 16px;
}
.pp-brand{ display:flex; align-items:center; gap:9px; text-decoration:none; }
/* КАНОН бренда = логотип витрины (lp-brand): градиент-чип коралл→фиолет + белый кролик */
.pp-logo{ width:34px; height:34px; border-radius:11px; flex:none; background:var(--grad-hero);
  display:grid; place-items:center; box-shadow:0 6px 16px -6px rgba(124,92,255,.6); }
.pp-logo svg{ width:23px; height:23px; display:block; }
.pp-logo-dot{ width:12px; height:12px; border-radius:var(--pill); background:var(--grad-hero); flex:none; } /* legacy */
.pp-wordmark{ font:800 20px var(--font-display); letter-spacing:-.03em; color:var(--ink); }
.pp-dot{ color:var(--coral); }
.pp-nav-links{ display:flex; align-items:center; gap:18px; }
.pp-nav-links a{ font:600 14px var(--font); color:var(--ink2); text-decoration:none; }
.pp-nav-links a:hover{ color:var(--ink); }
.pp-nav-cta{ display:flex; align-items:center; gap:8px; }
/* «Войти» — чистая ссылка БЕЗ обводки (канон витрины lp-nav-links), а не плашка */
.pp-nav-login{
  font:600 14px var(--font); color:var(--ink2); text-decoration:none;
  border:none; border-radius:var(--pill); padding:8px 12px; transition:background .15s,color .15s;
}
.pp-nav-login:hover{ color:var(--ink); background:rgba(124,92,255,.08); }
/* «Регистрация» — градиент-пилюля с неоновой подсветкой (канон lp-nav-cta) */
.pp-nav-join{
  font:700 14px var(--font); color:#fff; text-decoration:none;
  background:var(--grad-hero); border-radius:var(--pill); padding:10px 18px;
  box-shadow:0 8px 20px -8px rgba(124,92,255,.7);
  transition:transform .18s cubic-bezier(.34,1.56,.64,1), box-shadow .18s;
}
.pp-nav-join:hover{ transform:translateY(-2px); box-shadow:0 12px 26px -8px rgba(124,92,255,.85); }
.pp-nav-join.is-icon{ display:none; }
@media(max-width:560px){
  .pp-nav-links{ display:none; }
  .pp-nav-login{ display:none; }
  .pp-nav-join.is-text{ display:none; }
  .pp-nav-join.is-icon{ display:grid; place-items:center; width:40px; height:40px; padding:0; font-size:20px; }
}

/* =====================================================
   HERO + AVATAR + REEL
   ===================================================== */
.pp-cover{
  height:200px; background:var(--grad-hero);
  border-radius:0 0 var(--r-lg) var(--r-lg);
  position:relative; overflow:hidden; margin-top:8px;
}
.pp-cover img{ width:100%; height:100%; object-fit:cover; }
.pp-cover::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(to bottom,transparent 55%,rgba(0,0,0,.18));
}
/* photo cover: collage of printed parts dimmed so the avatar/name pop */
.pp-cover.has-photo::after{
  background:linear-gradient(135deg,rgba(124,92,255,.28),rgba(255,94,126,.18) 60%,transparent),
    linear-gradient(to bottom,transparent 40%,rgba(0,0,0,.32));
}
.pp-avatar-wrap{ width:124px; height:124px; margin:-56px auto 0; position:relative; z-index:2; }
.pp-avatar-wrap.is-customer{ width:104px; height:104px; margin-top:-52px; }
.pp-reel{
  position:absolute; inset:0; border-radius:var(--pill);
  background:conic-gradient(var(--coral), var(--violet) var(--reel,86%), var(--line2) 0);
  padding:6px;
}
.pp-avatar{
  width:100%; height:100%; border-radius:var(--pill);
  border:4px solid #fff; object-fit:cover; background:var(--bg2);
}
.pp-ava-init{
  width:100%; height:100%; border-radius:var(--pill); border:4px solid #fff;
  background:var(--grad-2); color:#fff; display:grid; place-items:center;
  font:800 40px var(--font-display);
}
.pp-points{
  position:absolute; left:50%; bottom:-10px; transform:translateX(-50%);
  background:#fff; box-shadow:var(--shadow); border-radius:var(--pill);
  font:800 12px var(--font-display); padding:3px 10px; white-space:nowrap; z-index:3;
}
.pp-online{
  position:absolute; right:8px; bottom:14px; width:14px; height:14px;
  border-radius:var(--pill); background:var(--ok); border:3px solid #fff; z-index:3;
}
.is-customer .pp-online{ right:6px; bottom:8px; }

/* identity */
.pp-name{ font:800 28px var(--font-display); letter-spacing:-.02em; text-align:center; margin:20px 0 2px; }
.pp-handle{ text-align:center; color:var(--ink2); font:600 14px var(--font); }
.pp-tag{ text-align:center; color:var(--ink2); font:400 15px var(--font); margin:6px 0 12px; }
.pp-chips{ display:flex; flex-wrap:wrap; gap:6px; justify-content:center; }
.pp-chip{
  border:1px solid var(--line2); border-radius:var(--pill); padding:4px 10px;
  font:600 12px var(--font); color:var(--ink2);
}
.pp-stickers{ display:flex; flex-wrap:wrap; gap:8px 6px; justify-content:center; margin-top:12px; }
.pp-ctx{
  text-align:center; color:var(--ink2); font:600 12px var(--font);
  text-transform:uppercase; letter-spacing:.08em; margin-top:14px;
}

/* =====================================================
   STICKERS (фирменные наклейки)
   ===================================================== */
.sticker{
  display:inline-flex; align-items:center; gap:5px; font:800 12px var(--font-display);
  padding:5px 11px; border-radius:var(--pill);
  box-shadow:0 0 0 2px #fff inset, 0 4px 12px rgba(0,0,0,.15);
  transition:transform .18s cubic-bezier(.34,1.56,.64,1); white-space:nowrap;
  border:none; cursor:default;
}
.sticker:hover{ transform:rotate(0) scale(1.06) !important; }
.s-violet{ background:var(--violet); color:#fff; }
.s-blue  { background:var(--blue);   color:#fff; }
.s-sun   { background:var(--sun);    color:var(--ink); }
.s-lime  { background:var(--lime);   color:var(--ink); }
.s-coral { background:var(--coral);  color:#fff; }
.s-ok    { background:var(--ok);     color:#fff; }
.s-mini  { font-size:10px; padding:3px 8px; box-shadow:0 0 0 1.5px #fff inset, 0 2px 6px rgba(0,0,0,.12); }
.sticker.is-guarantee{ font-size:13px; padding:6px 13px; }

/* =====================================================
   TIER + CTA
   ===================================================== */
.pp-tier-row{ display:flex; align-items:center; gap:12px; }
.pp-medal{
  width:44px; height:44px; border-radius:var(--pill); display:grid; place-items:center;
  font-size:22px; flex:none;
}
.pp-medal.tier-new{ background:var(--line2); }
.pp-medal.tier-l1{ background:var(--sun); }
.pp-medal.tier-l2{ background:var(--blue); }
.pp-medal.tier-top{ background:linear-gradient(135deg,#FFC53D,#FF9F1C); }
.pp-medal.tier-pro{ background:var(--grad-hero); box-shadow:0 0 14px rgba(124,92,255,.5); }
.pp-tier-info{ flex:1; min-width:0; }
.pp-tier-label{ font:800 16px var(--font-display); }
.pp-tier-hint{ color:var(--ink2); font:500 12px var(--font); margin-top:2px; }
.pp-tier-mini{ height:6px; border-radius:var(--pill); background:var(--bg2); overflow:hidden; margin-top:6px; }
.pp-tier-mini i{ display:block; height:100%; background:var(--grad-hero); }

.pp-btn{
  min-height:52px; border-radius:var(--pill); font:700 16px var(--font); border:none;
  cursor:pointer; width:100%; display:inline-flex; align-items:center; justify-content:center; gap:8px;
}
.pp-btn-primary{ background:var(--grad-hero); color:#fff; box-shadow:0 12px 28px -10px rgba(124,92,255,.7);
  transition:transform .18s cubic-bezier(.34,1.56,.64,1), box-shadow .18s; }
.pp-btn-primary:hover{ transform:translateY(-2px); box-shadow:0 18px 36px -10px rgba(124,92,255,.85); }
.pp-btn-secondary{ background:#fff; color:var(--ink); border:1.5px solid var(--line2); }
.pp-cta{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:14px; }
@media(max-width:420px){ .pp-cta{ grid-template-columns:1fr; } }
/* stacked CTA: primary order button on top, secondaries below */
.pp-cta.is-stack{ display:flex; flex-direction:column; gap:10px; }
.pp-cta.is-stack .pp-cta{ margin-top:0; }

/* =====================================================
   STATS
   ===================================================== */
.pp-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.pp-num{ font:800 24px var(--font-display); font-variant-numeric:tabular-nums; line-height:1.1; }
.pp-num small{ display:block; font:500 11px var(--font); color:var(--ink2); margin-top:2px; }
/* textual stat (e.g. «до 1ч») reads smaller, in Inter, not a 24px display number */
.pp-num.is-text{ font:700 18px var(--font); letter-spacing:-.01em; }
@media(max-width:400px){
  .pp-stats{ grid-template-columns:1fr 1fr; }
}

/* =====================================================
   RATING BARS
   ===================================================== */
.pp-rate-row{ display:grid; grid-template-columns:1fr 120px auto; align-items:center; gap:10px; margin:8px 0; }
.pp-rate-row span:first-child{ font:600 13px var(--font); }
.pp-rate-row .pp-rate-val{ font:800 14px var(--font-display); font-variant-numeric:tabular-nums; }
.pp-bar{ height:10px; border-radius:var(--pill); background:var(--bg2); overflow:hidden; }
.pp-bar i{ display:block; height:100%; width:0; background:var(--grad-2);
  transition:width .9s cubic-bezier(.34,1.56,.64,1); }
@media(max-width:420px){
  .pp-rate-row{ grid-template-columns:1fr 84px auto; gap:8px; }
}

/* =====================================================
   PRINTERS
   ===================================================== */
.pp-printer{
  display:flex; align-items:center; gap:10px; padding:12px; border:1px solid var(--line);
  border-radius:var(--r); margin-bottom:10px;
}
.pp-printer-name{ font:700 15px var(--font); }
.pp-printer-bed{ font:500 12px var(--font); color:var(--ink2); margin-top:2px; }
.pp-tech{ padding:2px 8px; border-radius:var(--pill); color:#fff; font:700 11px var(--font); }
.pp-tech.fdm{ background:var(--blue); }
.pp-tech.sla{ background:var(--violet); }
.pp-qty{
  margin-left:auto; width:26px; height:26px; border-radius:var(--pill);
  background:var(--bg2); display:grid; place-items:center; font:700 13px var(--font); flex:none;
}

/* =====================================================
   MATERIALS
   ===================================================== */
.pp-mat-row{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin:8px 0; }
.pp-mat-type{
  border-radius:var(--pill); padding:3px 11px; font:700 12px var(--font);
  border:1.5px solid var(--line2); color:var(--ink2); background:#fff;
}
.pp-mat-type.pla { border-color:var(--violet); color:var(--violet); }
.pp-mat-type.petg{ border-color:var(--blue);   color:var(--blue); }
.pp-mat-type.abs { border-color:var(--coral);  color:var(--coral); }
.pp-mat-type.resin{ border-color:var(--ink2);  color:var(--ink2); }
.pp-swatch{ width:20px; height:20px; border-radius:var(--pill); border:1px solid var(--line2); flex:none; }

/* =====================================================
   PORTFOLIO / DIFFERENTIATOR
   ===================================================== */
.pp-filter{ display:flex; flex-wrap:wrap; gap:8px; margin:0 0 14px; }
.pp-filter-chip{
  border:1.5px solid var(--line2); background:#fff; border-radius:var(--pill);
  padding:7px 14px; font:600 13px var(--font); color:var(--ink2); cursor:pointer;
  transition:all .15s;
}
.pp-filter-chip.is-active{ background:var(--ink); color:#fff; border-color:var(--ink); }

.pp-work{ position:relative; margin-bottom:18px; }
.pp-work model-viewer{
  width:100%; height:320px; border-radius:var(--r); background:var(--bg2); display:block;
  --poster-color:transparent;
}
.pp-work.is-exploded model-viewer{ background:linear-gradient(160deg,var(--bg2),#fff); }
.pp-work-mv{ position:relative; }
/* moat badge — ALWAYS visible over the viewer (main differentiator) */
.pp-moat-badge{
  position:absolute; left:12px; top:12px; z-index:3;
  display:inline-flex; align-items:center; gap:5px;
  background:var(--lime); color:var(--ink);
  font:800 12px var(--font-display); letter-spacing:-.01em;
  padding:6px 12px; border-radius:var(--pill); white-space:nowrap;
  box-shadow:0 0 0 2px #fff inset, 0 4px 12px rgba(0,0,0,.16);
}
.pp-moat-badge.is-draft{ background:#fff; color:var(--ink2); box-shadow:0 0 0 1.5px var(--line2) inset, 0 4px 12px rgba(0,0,0,.1); }
.pp-cut-overlay{
  position:absolute; left:12px; bottom:12px; background:rgba(20,20,20,.7);
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  color:#fff; border-radius:var(--pill); padding:8px 14px;
  font:700 13px var(--font); border:none; cursor:pointer; z-index:2;
  transition:transform .18s cubic-bezier(.34,1.56,.64,1);
}
.pp-cut-overlay:hover{ transform:scale(1.05); }
.pp-work-title{ font:800 17px var(--font-display); margin:12px 0 6px; letter-spacing:-.01em; }
.pp-work-chips{ display:flex; flex-wrap:wrap; gap:6px; }
.pp-cut-btn{
  width:100%; margin-top:12px; border:1.5px solid var(--violet); color:var(--violet);
  background:#fff; border-radius:var(--pill); min-height:48px; font:700 15px var(--font); cursor:pointer;
  transition:all .15s;
}
.pp-cut-btn:hover{ background:rgba(124,92,255,.06); }
.pp-work.is-exploded .pp-cut-btn{ border-color:var(--line2); color:var(--ink2); }
.pp-cut-reveal{
  max-height:0; overflow:hidden; opacity:0;
  transition:max-height .4s ease, opacity .3s ease, margin .3s ease;
}
.pp-work.is-exploded .pp-cut-reveal{ max-height:260px; opacity:1; margin-top:12px; }
.pp-fact{ margin-top:8px; font:600 13px var(--font); color:var(--ink2); }
.pp-makes{ display:flex; gap:8px; margin-top:8px; }
.pp-makes img{ width:56px; height:56px; border-radius:14px; object-fit:cover; }
.pp-draft-chip{
  display:inline-flex; align-items:center; gap:5px; font:700 12px var(--font);
  color:var(--ink2); background:var(--bg2); border-radius:var(--pill); padding:5px 11px;
}

/* =====================================================
   FEED
   ===================================================== */
.pp-feed-item{ position:relative; padding:14px; border:1px solid var(--line); border-radius:var(--r); margin-bottom:10px; overflow:hidden; }
.pp-feed-item.is-milestone{ background:linear-gradient(120deg,rgba(255,197,61,.1),transparent); border-color:rgba(255,197,61,.3); }
.pp-feed-text{ font:600 14px var(--font); }
.pp-feed-photo{ width:100%; border-radius:var(--r); margin-top:10px; }
.pp-feed-date{ float:right; color:var(--ink2); font:500 12px var(--font); }
.pp-feed-meta{ margin-top:10px; color:var(--ink2); font:600 12px var(--font); display:flex; gap:14px; }

/* =====================================================
   REVIEWS
   ===================================================== */
.pp-review{ border:1px solid var(--line); border-radius:var(--r); padding:14px; margin-bottom:10px; }
.pp-review-head{ display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.pp-ava-mini{
  width:36px; height:36px; border-radius:var(--pill); background:var(--grad-2);
  color:#fff; display:grid; place-items:center; font:700 15px var(--font); flex:none;
}
.pp-review-author{ font:700 14px var(--font); }
.pp-review-date{ color:var(--ink2); font:500 12px var(--font); }
.pp-stars{ color:var(--sun); font-size:13px; letter-spacing:1px; }
.pp-review-cats{ display:flex; flex-wrap:wrap; gap:6px; margin:6px 0 8px; }
.pp-review-cat{ font:600 11px var(--font); color:var(--ink2); background:var(--bg2); border-radius:var(--pill); padding:3px 9px; }
.pp-review-text{ font:400 14px var(--font); color:var(--ink); }
.pp-rate-hero{ display:flex; align-items:baseline; gap:8px; margin-bottom:14px; }
.pp-rate-hero b{ font:800 34px var(--font-display); font-variant-numeric:tabular-nums; }
.pp-rate-hero span{ color:var(--ink2); font:500 13px var(--font); }

/* =====================================================
   ABOUT / PHOTOS / VERIFY
   ===================================================== */
.pp-about{ font:400 15px var(--font); color:var(--ink); white-space:pre-line; margin:0 0 12px; }
.pp-photos{
  display:flex; gap:10px; overflow-x:auto; scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch; padding-bottom:4px; margin:0 -2px;
}
.pp-photos img{
  width:160px; height:120px; object-fit:cover; border-radius:var(--r);
  scroll-snap-align:start; flex:none;
}
.pp-verify{ display:flex; flex-wrap:wrap; gap:8px; margin-top:12px; }
.pp-verify-item{
  display:inline-flex; align-items:center; gap:6px; font:600 12px var(--font);
  border:1px solid var(--line2); border-radius:var(--pill); padding:5px 11px;
}
.pp-verify-item.is-on{ color:var(--ok); border-color:rgba(31,191,117,.4); background:rgba(31,191,117,.06); }
.pp-verify-item.is-off{ color:var(--ink2); }

/* =====================================================
   LEAD / СРОКИ
   ===================================================== */
.pp-lead{ display:flex; flex-direction:column; gap:2px; }
.pp-lead-row{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:9px 0; border-bottom:1px solid var(--line);
}
.pp-lead-row:last-child{ border-bottom:none; }
.pp-lead-key{ font:600 13px var(--font); color:var(--ink2); flex:none; }
.pp-lead-val{ font:700 14px var(--font); color:var(--ink); text-align:right; }

/* =====================================================
   PRICE
   ===================================================== */
.pp-price{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.pp-price-cell{ background:var(--bg2); border-radius:var(--r); padding:14px; text-align:center; }
.pp-price-cell b{ font:800 22px var(--font-display); display:block; }
.pp-price-cell span{ font:500 12px var(--font); color:var(--ink2); }

/* =====================================================
   TRUST (customer)
   ===================================================== */
.pp-trust{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.pp-trust-cell{ background:var(--bg2); border-radius:var(--r); padding:16px; text-align:center; }
.pp-trust .pp-num.is-hero{ font-size:34px; color:var(--ok); }

/* tags (customer) */
.pp-tags{ display:flex; flex-wrap:wrap; gap:8px; }
.pp-tag-chip{ border-radius:var(--pill); padding:6px 12px; font:600 13px var(--font); border:1.5px solid; background:#fff; }
.pp-tag-chip.t-violet{ border-color:var(--violet); color:var(--violet); }
.pp-tag-chip.t-blue  { border-color:var(--blue);   color:var(--blue); }
.pp-tag-chip.t-coral { border-color:var(--coral);  color:var(--coral); }

/* private (locked) */
.pp-locked-card{ background:var(--bg2); }
.pp-locked-row{ display:flex; justify-content:space-between; gap:10px; padding:8px 0; border-bottom:1px solid var(--line); }
.pp-locked-row:last-child{ border-bottom:none; }
.pp-locked-key{ font:600 13px var(--font); color:var(--ink2); flex:none; }
.pp-locked{ filter:blur(5px); user-select:none; pointer-events:none; color:var(--ink2); font:600 13px var(--font); }
.pp-lock-note{ display:flex; align-items:center; gap:8px; color:var(--ink2); font:500 12px var(--font); margin-top:8px; }

/* =====================================================
   STICKY CTA
   ===================================================== */
.pp-sticky-cta{
  position:sticky; bottom:0; z-index:30; width:100%;
  background:rgba(255,253,247,.9); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  padding:12px 0 calc(12px + env(safe-area-inset-bottom));
  display:flex; gap:10px; border-top:1px solid var(--line);
}
.pp-sticky-inner{ max-width:560px; margin:0 auto; width:100%; display:flex; gap:10px; padding:0 16px; }
.pp-sticky-cta .pp-btn{ min-height:52px; }
.pp-share{ flex:none; width:52px; }

/* =====================================================
   PREVIEW SWITCHER
   ===================================================== */
.pp-switch{
  position:fixed; right:16px; bottom:86px; z-index:60; display:flex; gap:4px; align-items:center;
  background:rgba(255,255,255,.92); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--line); border-radius:var(--pill); padding:4px; box-shadow:var(--shadow);
}
.pp-switch a{
  font:700 12px var(--font); color:var(--ink2); text-decoration:none;
  padding:7px 12px; border-radius:var(--pill);
}
.pp-switch a.is-active{ background:var(--grad-hero); color:#fff; }
.pp-switch-tag{ font:700 10px var(--font); color:var(--ink2); padding:0 6px 0 4px; text-transform:uppercase; letter-spacing:.05em; }
@media(min-width:768px){ .pp-switch{ bottom:16px; } }

/* =====================================================
   FORM (edit)
   ===================================================== */
.pp-input, textarea.pp-input{
  width:100%; background:#fff; border:1.5px solid var(--line); border-radius:var(--r);
  padding:12px 14px; font:500 15px var(--font); color:var(--ink); resize:vertical;
}
.pp-input:focus{ outline:none; border-color:var(--violet); box-shadow:0 0 0 3px rgba(124,92,255,.15); }
.pp-label{ display:block; font:600 12px var(--font); color:var(--ink2); margin:0 0 6px; }
.pp-field{ margin-bottom:14px; }
.pp-row2{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media(max-width:420px){ .pp-row2{ grid-template-columns:1fr; } }

/* onboarding */
.pp-onb{
  position:sticky; top:56px; z-index:40; background:var(--card); border-radius:var(--r);
  box-shadow:var(--shadow); padding:16px; margin:12px 0;
}
/* on phones a sticky onboarding block eats half the screen — let it scroll away */
@media(max-width:560px){
  .pp-onb{ position:static; }
}
.pp-onb-head{ display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:10px; }
.pp-onb-pct{ font:800 32px var(--font-display); font-variant-numeric:tabular-nums; line-height:1; }
.pp-onb-pct small{ font:800 16px var(--font-display); }
.pp-onb-motiv{ font:700 13px var(--font); color:var(--violet); text-align:right; max-width:160px; }
.pp-progress{ height:14px; border-radius:var(--pill); background:var(--bg2); overflow:hidden; }
.pp-progress i{ display:block; height:100%; background:var(--grad-hero); transition:width .5s cubic-bezier(.34,1.56,.64,1); }
.pp-tiers{ display:flex; gap:6px; margin-top:10px; }
.pp-tier{ flex:1; text-align:center; font:600 11px var(--font); color:var(--ink2); padding:6px 0; border-radius:var(--pill); background:var(--bg2); }
.pp-tier.is-active{ background:var(--grad-hero); color:#fff; font-weight:700; }
.pp-checks{ margin-top:12px; border-top:1px solid var(--line); padding-top:8px; }
.pp-check{ display:flex; align-items:center; gap:8px; padding:8px 0; cursor:pointer; font:500 14px var(--font); }
.pp-check.is-done{ color:var(--ink2); }
.pp-check.is-todo{ color:var(--ink); font-weight:600; }
.pp-check-box{ width:20px; height:20px; border-radius:7px; flex:none; display:grid; place-items:center; font-size:12px; border:1.5px solid var(--line2); }
.pp-check.is-done .pp-check-box{ background:var(--ok); border-color:var(--ok); color:#fff; }

/* repeatable rows (printers) */
.pp-rep{ display:grid; grid-template-columns:1.4fr .7fr .7fr .5fr auto; gap:8px; margin-bottom:10px; align-items:center; }
.pp-rep-del{ border:none; background:var(--bg2); color:var(--err); width:38px; height:38px; border-radius:12px; cursor:pointer; font-size:18px; flex:none; }
.pp-rep-del .pp-rep-del-txt{ display:none; }
/* phone: model full-width on top, then [tech][bed], then [qty][delete] full-width row */
@media(max-width:480px){
  .pp-rep{
    grid-template-columns:1fr 1fr;
    grid-template-areas:"model model" "tech bed" "qty qty" "del del";
    gap:8px 8px;
    padding:12px; border:1px solid var(--line); border-radius:var(--r);
  }
  .pp-rep > [data-pk="model"]{ grid-area:model; }
  .pp-rep > [data-pk="tech"]{ grid-area:tech; }
  .pp-rep > [data-pk="bed"]{ grid-area:bed; }
  .pp-rep > [data-pk="qty"]{ grid-area:qty; }
  .pp-rep-del{
    grid-area:del; width:100%; height:auto; min-height:40px; border-radius:var(--r);
    display:flex; align-items:center; justify-content:center; gap:6px;
    font:700 14px var(--font);
  }
  .pp-rep-del .pp-rep-del-txt{ display:inline; }
}
.pp-add-btn{
  width:100%; border:1.5px dashed var(--line2); background:#fff; border-radius:var(--r);
  padding:12px; font:700 14px var(--font); color:var(--violet); cursor:pointer; margin-top:4px;
}
.pp-add-btn:hover{ background:rgba(124,92,255,.04); border-color:var(--violet); }

/* material toggles */
.pp-mat-toggle{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:12px; }
.pp-toggle{
  border:1.5px solid var(--line2); background:#fff; border-radius:var(--pill); padding:8px 14px;
  font:600 13px var(--font); color:var(--ink2); cursor:pointer; user-select:none;
}
.pp-toggle.is-on{ background:var(--violet); color:#fff; border-color:var(--violet); }

/* color pickers */
.pp-colorpick{ display:flex; flex-wrap:wrap; gap:6px; }
.pp-colorpick label{ cursor:pointer; }
.pp-colorpick input{ display:none; }
.pp-color-dot{ width:24px; height:24px; border-radius:var(--pill); border:2px solid var(--line2); display:block; }
.pp-colorpick input:checked + .pp-color-dot{ border-color:var(--ink); box-shadow:0 0 0 2px #fff,0 0 0 4px var(--ink); }

/* anti-bypass hint */
.pp-hint{
  background:rgba(255,159,28,.1); border:1px solid rgba(255,159,28,.3);
  border-radius:var(--r); padding:10px 12px; font:500 13px var(--font); color:#9a6500; margin-top:8px;
}
.pp-flag{ background:rgba(255,159,28,.25); border-radius:4px; padding:0 2px; }

/* upload zones */
.pp-drop{
  border:1.5px dashed var(--line2); border-radius:var(--r); background:var(--bg2);
  padding:20px; text-align:center; color:var(--ink2); font:600 13px var(--font); cursor:pointer;
}
.pp-drop:hover{ border-color:var(--violet); color:var(--violet); }
.pp-drop-row{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media(max-width:420px){ .pp-drop-row{ grid-template-columns:1fr; } }

/* role switch (edit) */
.pp-roleswitch{ display:flex; gap:8px; background:var(--bg2); border-radius:var(--pill); padding:4px; margin-bottom:12px; }
.pp-roleswitch button{
  flex:1; border:none; background:transparent; border-radius:var(--pill); padding:10px;
  font:700 14px var(--font); color:var(--ink2); cursor:pointer;
}
.pp-roleswitch button.is-active{ background:#fff; color:var(--ink); box-shadow:var(--shadow); }

/* portfolio gallery edit thumbs */
.pp-port-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-top:10px; }
.pp-port-grid img{ aspect-ratio:1; object-fit:cover; border-radius:14px; }

/* =====================================================
   TOAST
   ===================================================== */
.pp-toast{
  position:fixed; left:50%; bottom:110px; transform:translateX(-50%) translateY(20px);
  background:var(--ink); color:#fff; font:700 14px var(--font); padding:12px 20px;
  border-radius:var(--pill); box-shadow:var(--shadow-lg); z-index:100; opacity:0;
  transition:opacity .25s, transform .25s cubic-bezier(.34,1.56,.64,1); pointer-events:none;
  max-width:90vw; text-align:center;
}
.pp-toast.is-show{ opacity:1; transform:translateX(-50%) translateY(0); }

/* spacer above sticky cta so content not hidden */
.pp-bottom-pad{ height:8px; }

/* section spacing helper */
.pp-mt0{ margin-top:0; }
.pp-divider{ height:1px; background:var(--line); margin:14px 0; }

/* desktop polish */
@media(min-width:768px){
  body{ font-size:15.5px; }
  .pp-name{ font-size:30px; }
}

/* =====================================================
   KLIKKO MASCOT — brand companion (Duolingo-moment)
   White rabbit w/ teal ears, transparent PNG → soft drop-shadow.
   ===================================================== */

/* pop-scale used when a pose swaps in */
@keyframes pp-klikko-pop{
  0%  { transform:scale(.6) rotate(-6deg); opacity:0; }
  60% { transform:scale(1.08) rotate(2deg); }
  100%{ transform:scale(1) rotate(0); opacity:1; }
}
@keyframes pp-klikko-float{
  0%,100%{ transform:translateY(0); }
  50%    { transform:translateY(-4px); }
}

/* --- onboarding companion: Klikko + speech bubble next to the bar --- */
.pp-klikko{
  display:flex; align-items:flex-end; gap:12px; margin-bottom:14px;
}
.pp-klikko-img{
  width:110px; height:110px; flex:none; object-fit:contain;
  filter:drop-shadow(0 10px 16px rgba(124,92,255,.22));
  animation:pp-klikko-pop .5s cubic-bezier(.34,1.56,.64,1) both;
}
/* retrigger on pose change */
.pp-klikko-img.is-pop{ animation:pp-klikko-pop .5s cubic-bezier(.34,1.56,.64,1) both; }
.pp-klikko-bubble{
  position:relative; flex:1; min-width:0;
  background:#fff; border:1.5px solid var(--line); border-radius:var(--r);
  box-shadow:var(--shadow); padding:12px 14px;
  font:600 14px var(--font); color:var(--ink); line-height:1.35;
  animation:pp-klikko-pop .4s cubic-bezier(.34,1.56,.64,1) both;
}
/* speech-bubble tail pointing at Klikko */
.pp-klikko-bubble::before{
  content:""; position:absolute; left:-9px; bottom:18px;
  width:16px; height:16px; background:#fff;
  border-left:1.5px solid var(--line); border-bottom:1.5px solid var(--line);
  transform:rotate(45deg); border-bottom-left-radius:3px;
}
@media(max-width:560px){
  .pp-klikko{ gap:10px; align-items:center; }
  .pp-klikko-img{ width:80px; height:80px; }
  .pp-klikko-bubble{ font-size:13px; padding:10px 12px; }
  .pp-klikko-bubble::before{ bottom:14px; }
}

/* --- showcase accent: Klikko peeking at a section title --- */
.pp-title-klikko{ position:relative; padding-right:52px; }
.pp-klikko-peek{
  position:absolute; right:-2px; top:50%; width:46px; height:46px;
  transform:translateY(-58%) rotate(6deg); object-fit:contain;
  filter:drop-shadow(0 6px 10px rgba(124,92,255,.2));
  animation:pp-klikko-float 4s ease-in-out infinite; pointer-events:none;
}

/* --- empty / loading / error states with Klikko --- */
.pp-empty{
  display:flex; flex-direction:column; align-items:center; text-align:center;
  gap:6px; padding:24px 12px 12px;
}
.pp-empty-img{
  width:96px; height:96px; object-fit:contain;
  filter:drop-shadow(0 10px 16px rgba(124,92,255,.18));
  animation:pp-klikko-pop .5s cubic-bezier(.34,1.56,.64,1) both;
}
.pp-empty-img.is-loading{ animation:pp-klikko-float 1.4s ease-in-out infinite; }
.pp-empty-title{ font:800 15px var(--font-display); letter-spacing:-.01em; color:var(--ink); }
.pp-empty-sub{ font:500 13px var(--font); color:var(--ink2); max-width:280px; }

/* =====================================================
   DESKTOP 2-COLUMN (master only, ≥960px)
   On phones .pp-head/.pp-side/.pp-main are display:contents —
   layout-transparent — so the mobile single column is untouched.
   ===================================================== */
.pp-head, .pp-side, .pp-main{ display:contents; }
@media(min-width:960px){
  .pp-col-master{
    max-width:1040px;
    display:grid;
    grid-template-columns:340px 1fr;
    grid-template-areas:"head head" "side main";
    column-gap:28px; align-items:start;
  }
  .pp-col-master .pp-head{ display:block; grid-area:head; }
  .pp-col-master .pp-side{
    display:block; grid-area:side;
    position:sticky; top:72px;
  }
  .pp-col-master .pp-main{ display:block; grid-area:main; min-width:0; }
  /* head stays centered like mobile; cover full bleed of the wide container */
  .pp-col-master .pp-head .pp-stickers{ max-width:680px; margin-left:auto; margin-right:auto; }
}

/* =====================================================
   AUTH (вход / регистрация) — страница /account.html (P1)
   ===================================================== */
.pp-auth-wrap{
  min-height:calc(100vh - 64px);
  display:grid; place-items:center; padding:24px 16px 64px;
}
.pp-auth-card{
  width:100%; max-width:420px; background:var(--card);
  border-radius:var(--r); box-shadow:var(--shadow);
  border:1px solid var(--line2); padding:28px 24px;
}
.pp-auth-klikko{ display:block; width:84px; height:auto; margin:0 auto 10px; }
.pp-auth-title{ font:800 24px var(--font-display); letter-spacing:-.02em; color:var(--ink); text-align:center; margin:0 0 4px; }
.pp-auth-sub{ font:500 14px var(--font); color:var(--ink2); text-align:center; margin:0 0 20px; }
.pp-auth-tabs{ display:flex; gap:6px; background:var(--bg2); border-radius:var(--pill); padding:4px; margin-bottom:20px; }
.pp-auth-tabs button{
  flex:1; border:none; background:none; cursor:pointer; padding:9px 10px;
  border-radius:var(--pill); font:700 14px var(--font); color:var(--ink2);
}
.pp-auth-tabs button.is-active{ background:#fff; color:var(--ink); box-shadow:var(--shadow); }
.pp-auth-err{
  background:rgba(255,77,94,.10); color:#d23048; border:1px solid rgba(255,77,94,.30);
  border-radius:14px; padding:10px 12px; font:600 13px var(--font); margin-bottom:14px;
}
.pp-auth-card .pp-btn{ width:100%; margin-top:6px; }
.pp-auth-alt{ text-align:center; font:500 13px var(--font); color:var(--ink2); margin-top:16px; }
.pp-auth-alt a{ color:var(--violet); font-weight:700; text-decoration:none; cursor:pointer; }

/* «это вы» бейдж на собственном публичном профиле */
.pp-you-badge{
  display:inline-flex; align-items:center; gap:6px; padding:5px 12px;
  border-radius:var(--pill); background:var(--bg2); color:var(--ink2);
  font:700 12px var(--font); margin:10px auto 0;
}
.pp-you-badge a{ color:var(--violet); text-decoration:none; }

/* =====================================================
   SOCIAL (P1) — лента постов, compose, пост, комментарии, guest-gate
   ===================================================== */
/* compose */
.pp-compose{ border:1px solid var(--line); border-radius:var(--r); padding:12px; margin-bottom:14px; background:var(--bg2); }
.pp-compose-text{
  width:100%; min-height:64px; resize:vertical; border:1px solid var(--line);
  border-radius:var(--r); padding:10px 12px; font:500 14px var(--font);
  background:var(--bg); color:var(--ink); box-sizing:border-box;
}
.pp-compose-text:focus{ outline:none; border-color:var(--violet); }
.pp-compose-row{ display:flex; gap:8px; margin-top:8px; flex-wrap:wrap; }
.pp-compose-url{
  flex:1; min-width:160px; border:1px solid var(--line); border-radius:var(--pill);
  padding:8px 12px; font:500 12px var(--font); background:var(--bg); color:var(--ink); box-sizing:border-box;
}
.pp-compose-url:focus{ outline:none; border-color:var(--violet); }
.pp-compose-actions{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin-top:10px; flex-wrap:wrap; }
.pp-compose-hint{ color:var(--ink2); font:500 11px var(--font); }

/* feed post item */
.pp-feed-link{ text-decoration:none; color:inherit; }
.pp-feed-title{ font:800 16px var(--font-display,var(--font)); margin:2px 0 6px; line-height:1.25; }
.pp-feed-video{ width:100%; border-radius:var(--r); margin-top:10px; background:#000; max-height:420px; }
.pp-feed-cap{ color:var(--ink2); font:500 12px var(--font); margin-top:4px; }
.pp-feed-btn{
  display:inline-flex; align-items:center; gap:5px; border:1px solid var(--line);
  background:var(--bg); color:var(--ink2); border-radius:var(--pill); padding:5px 12px;
  font:700 12px var(--font); cursor:pointer; text-decoration:none; transition:.15s;
}
.pp-feed-btn:hover{ border-color:var(--violet); color:var(--ink); }
.pp-feed-btn.is-on{ background:var(--coral,#FF5A7A); border-color:var(--coral,#FF5A7A); color:#fff; }
.pp-pending{ color:var(--sun,#E89B00); font-weight:700; }
.pp-feed-ssr{ list-style:none; padding:0; margin:0; }
.pp-feed-ssr li{ padding:8px 0; border-bottom:1px solid var(--line); font:600 14px var(--font); }
.pp-feed-ssr a{ color:var(--violet); text-decoration:none; }

/* пост (SSR-страница /@handle/post/{id}) */
.pp-post-author{ display:flex; align-items:center; gap:8px; font:600 13px var(--font); flex-wrap:wrap; }
.pp-post-author-link{ color:var(--ink); text-decoration:none; font-weight:800; }
.pp-ava-mini-img{ width:34px; height:34px; border-radius:var(--pill); object-fit:cover; flex:none; }
.pp-post-title{ font:800 24px var(--font-display,var(--font)); margin:12px 0; line-height:1.2; }
.pp-post-cover{ width:100%; border-radius:var(--r); margin:10px 0; }
.pp-post-body{ font:500 15px/1.6 var(--font); color:var(--ink); }
.pp-post-body p{ margin:0 0 12px; }
.pp-post-img{ width:100%; border-radius:var(--r); margin:10px 0; }
.pp-post-video{ width:100%; border-radius:var(--r); margin:10px 0; background:#000; max-height:520px; }
.pp-post-meta,.pp-post-actions{ display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; align-items:center; }
.pp-post-back{ text-align:center; margin:8px 0 40px; }
.pp-post-back a{ color:var(--violet); text-decoration:none; font:700 14px var(--font); }

/* комментарии */
.pp-comment{ display:flex; gap:10px; padding:10px 0; border-bottom:1px solid var(--line); }
.pp-comment-body{ flex:1; min-width:0; }
.pp-comment-head{ font:700 13px var(--font); margin-bottom:3px; }
.pp-comment-head a{ color:var(--ink); text-decoration:none; }
.pp-comment-text{ font:500 14px/1.5 var(--font); color:var(--ink); white-space:pre-wrap; word-break:break-word; }
.pp-commentbox-wrap{ margin-top:14px; }
.pp-commentbox{ display:flex; gap:8px; align-items:flex-end; }
.pp-commentbox .pp-compose-text{ flex:1; min-height:44px; }

/* guest-gate модалка */
.pp-authgate{
  position:fixed; inset:0; z-index:9000; display:grid; place-items:center;
  background:rgba(20,16,40,.5); backdrop-filter:blur(4px);
  opacity:0; transition:opacity .18s; padding:20px;
}
.pp-authgate.is-show{ opacity:1; }
.pp-authgate-card{
  position:relative; width:min(420px,100%); background:var(--bg); border-radius:20px;
  padding:30px 26px; text-align:center; box-shadow:0 24px 80px rgba(20,16,40,.3);
  transform:translateY(10px) scale(.98); transition:transform .2s;
}
.pp-authgate.is-show .pp-authgate-card{ transform:none; }
.pp-authgate-x{
  position:absolute; top:12px; right:14px; border:none; background:none;
  font-size:24px; line-height:1; color:var(--ink2); cursor:pointer;
}
.pp-authgate-ico{ font-size:40px; }
.pp-authgate-title{ font:800 20px var(--font-display,var(--font)); margin:10px 0 6px; }
.pp-authgate-sub{ color:var(--ink2); font:500 14px/1.5 var(--font); margin:0 0 18px; }
.pp-authgate-cta{ display:flex; gap:10px; }
.pp-authgate-cta .pp-btn{ flex:1; }

/* группы — каталог */
.pp-feed-author{ font:700 12px var(--font); color:var(--ink2); margin:2px 0 4px; }
.pp-chip.s-ok{ background:rgba(46,196,134,.14); color:#1F9D63; }
.pp-group-card{
  display:flex; gap:12px; align-items:center; padding:12px; border:1px solid var(--line);
  border-radius:var(--r); margin-bottom:10px; text-decoration:none; color:inherit; transition:.15s;
}
.pp-group-card:hover{ border-color:var(--violet); transform:translateY(-1px); }
.pp-group-ava{
  width:52px; height:52px; border-radius:16px; background:var(--grad-2); color:#fff;
  display:grid; place-items:center; font:800 22px var(--font-display,var(--font)); flex:none; overflow:hidden;
}
.pp-group-ava img{ width:100%; height:100%; object-fit:cover; }
.pp-group-info{ min-width:0; flex:1; }
.pp-group-name{ font:800 16px var(--font-display,var(--font)); }
.pp-group-sub{ color:var(--ink2); font:600 12px var(--font); margin-top:2px; }
