/* Frontend core styles for Lithops Page Constructor
   Scoped under .lpc-block to avoid leaking styles site-wide. */

.lpc-block{
  --lpc-text:#121826;
  --lpc-muted:#5b6472;
  --lpc-line:#e7ebf3;
  --lpc-shadow:0 10px 24px rgba(18,24,38,.08);
  --lpc-dark:#111827;
  --lpc-dark2:#0b1220;
  --lpc-soft:#f3f4f6;

  color:var(--lpc-text);
  padding:22px 0;
  line-height:1.45;
}

.lpc-block.lpc-soft{ background: var(--lpc-soft); }

.lpc-block .lpc-container{
  width:100%;
  max-width:1140px;
  margin:0 auto;
  padding:0 16px;
}

.lpc-block h2,
.lpc-block h3,
.lpc-block h4,
.lpc-block h5{
  letter-spacing:-0.02em;
  margin:0 0 10px;
}
.lpc-block h2{ font-size: clamp(22px, 2.2vw, 32px); }
.lpc-block h3{ font-size: 18px; }
.lpc-block p{ margin:0 0 10px; }
.lpc-block .lpc-muted{ color: var(--lpc-muted); }
.lpc-block .lpc-tight p:last-child{ margin-bottom:0; }

.lpc-block .lpc-btn-row{ display:flex; gap:10px; flex-wrap:wrap; margin-top:12px; }
.lpc-block .lpc-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:12px;
  border:1px solid var(--lpc-dark);
  background:var(--lpc-dark);
  color:#fff;
  font-size:14px;
  font-weight:700;
  text-decoration:none;
  transition:background .12s ease;
}
.lpc-block .lpc-btn:hover{ background:var(--lpc-dark2); color:#fff; }
.lpc-block .lpc-btn--secondary{
  background:#fff;
  color:var(--lpc-text);
  border-color:var(--lpc-line);
  font-weight:600;
}
.lpc-block .lpc-btn--secondary:hover{ background:#fff; }

.lpc-block .lpc-img{
  width:100%;
  height:auto;
  border-radius:12px;
  box-shadow:0 10px 22px rgba(18,24,38,.10);
  display:block;
}

.lpc-block .lpc-grid-2{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
  align-items:center;
}
@media (min-width: 992px){
  .lpc-block .lpc-grid-2{ grid-template-columns: 7fr 5fr; gap:28px; }
  .lpc-block .lpc-grid-2.lpc-reverse{ grid-template-columns: 5fr 7fr; }
}

/* Centered header */
.lpc-block .lpc-centered-head{ text-align:center; margin-bottom:18px; }
.lpc-block .lpc-centered-head p{ max-width:760px; margin:0 auto; }
.lpc-block .lpc-centered-text{ max-width:760px; margin:0 auto; text-align:left; }

/* ===== Services grid ===== */
.lpc-services .lpc-svc-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:0 44px;
  margin-top:6px;
}
@media (min-width: 768px){
  .lpc-services .lpc-svc-grid{ grid-template-columns: 1fr 1fr; }
}
@media (min-width: 1200px){
  .lpc-services .lpc-svc-grid{ grid-template-columns: 1fr 1fr 1fr; }
}
.lpc-services .lpc-svc-item{
  display:grid;
  grid-template-columns:44px 1fr;
  gap:14px;
  padding:18px 0;
  border-top:1px solid var(--lpc-line);
}
.lpc-services .lpc-svc-item:first-child{ border-top:0; }
@media (min-width: 992px){
  .lpc-services .lpc-svc-item{ padding:20px 0; }
}
.lpc-services .lpc-svc-ico img{
  width:44px; height:44px; object-fit:contain; display:block;
  filter:grayscale(1); opacity:.92;
}
.lpc-services .lpc-svc-title{
  margin:0 0 6px;
  font-size:18px;
  font-weight:750;
  letter-spacing:-0.01em;
  line-height:1.25;
}
.lpc-services .lpc-svc-title a{
  color:var(--lpc-text);
  text-decoration:underline;
  text-decoration-thickness:1px;
  text-underline-offset:4px;
  text-decoration-color:#c9d1e3;
}
.lpc-services .lpc-svc-title a:hover{ text-decoration-color:var(--lpc-text); }
.lpc-services .lpc-svc-desc{ margin:0; color:var(--lpc-muted); }

/* ===== Process steps ===== */
.lpc-process .lpc-proc-head{ margin-bottom:14px; }
.lpc-process .lpc-proc-list{ border-top:1px solid var(--lpc-line); }
.lpc-process .lpc-proc-step{
  display:grid;
  grid-template-columns:44px 1fr;
  gap:14px;
  padding:16px 0;
  border-bottom:1px solid var(--lpc-line);
}
@media (min-width: 992px){
  .lpc-process .lpc-proc-step{ padding:18px 0; }
}
@media (max-width: 360px){
  .lpc-process .lpc-proc-step{ grid-template-columns:38px 1fr; }
}
.lpc-process .lpc-proc-mark{ width:44px; height:44px; display:flex; align-items:flex-start; justify-content:center; }
@media (max-width: 360px){
  .lpc-process .lpc-proc-mark{ width:38px; height:38px; }
}
.lpc-process .lpc-proc-num{
  width:44px; height:44px; border-radius:12px;
  border:1px solid var(--lpc-line); background:#fff; color:var(--lpc-text);
  font-weight:800; display:flex; align-items:center; justify-content:center;
  letter-spacing:-0.02em;
}
@media (max-width: 360px){
  .lpc-process .lpc-proc-num{ width:38px; height:38px; border-radius:10px; }
}
.lpc-process .lpc-proc-mark img{
  width:44px; height:44px; object-fit:contain; display:block;
  filter:grayscale(1); opacity:.92;
}
@media (max-width: 360px){
  .lpc-process .lpc-proc-mark img{ width:38px; height:38px; }
}
.lpc-process .lpc-proc-title{
  margin:0 0 6px;
  font-size:17px;
  font-weight:750;
  letter-spacing:-0.01em;
  line-height:1.25;
}
.lpc-process .lpc-proc-title a{
  color:var(--lpc-text);
  text-decoration:underline;
  text-underline-offset:4px;
  text-decoration-thickness:1px;
  text-decoration-color:#c9d1e3;
}
.lpc-process .lpc-proc-title a:hover{ text-decoration-color:var(--lpc-text); }
.lpc-process .lpc-proc-desc{ margin:0; color:var(--lpc-muted); }
.lpc-process .lpc-proc-meta{ margin-top:10px; display:flex; gap:8px; flex-wrap:wrap; }
.lpc-process .lpc-chip{
  font-size:12px;
  color:var(--lpc-muted);
  border:1px solid var(--lpc-line);
  border-radius:999px;
  padding:6px 10px;
  background:#fff;
}
.lpc-process .lpc-proc-actions{ margin-top:10px; display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.lpc-process .lpc-link{
  font-size:14px;
  color:var(--lpc-text);
  text-decoration:underline;
  text-underline-offset:4px;
  text-decoration-thickness:1px;
  text-decoration-color:#c9d1e3;
}
.lpc-process .lpc-link:hover{ text-decoration-color:var(--lpc-text); }

/* ===== FAQ Accordion ===== */
.lpc-faq .lpc-faq-head{ margin-bottom:24px; }
.lpc-faq .lpc-faq-acc{ margin-top:12px; border-top:1px solid var(--lpc-line); }
.lpc-faq .lpc-faq-item{ padding:0 20px; border-bottom:1px solid var(--lpc-line); }
@media (min-width: 768px){
  .lpc-faq .lpc-faq-item{ padding:0 24px; }
}
.lpc-faq .lpc-faq-btn{
  width:100%;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  padding:22px 0;
  border:0;
  background:none;
  text-align:left;
  color:var(--lpc-text);
  font-weight:750;
  font-size:16px;
  letter-spacing:-0.01em;
  cursor:pointer;
}
@media (min-width: 992px){
  .lpc-faq .lpc-faq-btn{ padding:26px 0; }
}
.lpc-faq .lpc-faq-icon{
  flex:0 0 auto;
  width:32px; height:32px;
  border-radius:12px;
  border:1px solid var(--lpc-line);
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  color:var(--lpc-text);
  transition:transform .15s ease, border-color .15s ease;
}
.lpc-faq .lpc-faq-btn[aria-expanded="true"] .lpc-faq-icon{
  transform:rotate(45deg);
  border-color:#d9dfec;
}
.lpc-faq .lpc-faq-body{
  padding:4px 0 26px 0;
  color:var(--lpc-muted);
  display:none;
}
.lpc-faq .lpc-faq-body.is-open{ display:block; }
.lpc-faq .lpc-faq-meta{ margin-top:16px; display:flex; gap:12px; flex-wrap:wrap; align-items:center; }

/* ===== Tables ===== */
.lpc-table{
  border:1px solid var(--lpc-line);
  border-radius:12px;
  background:#fff;
  box-shadow:var(--lpc-shadow);
  overflow:hidden;
}
.lpc-table .lpc-table-scroll{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}
.lpc-table table{
  width:max-content;
  min-width:100%;
  border-collapse:separate;
  border-spacing:0;
  font-size:14px;
}
.lpc-table thead th{
  text-align:left;
  font-weight:800;
  color:var(--lpc-text);
  background:#fbfcff;
  padding:14px 16px;
  border-bottom:1px solid var(--lpc-line);
  white-space:nowrap;
}
.lpc-table tbody td{
  padding:14px 16px;
  border-bottom:1px solid var(--lpc-line);
  vertical-align:top;
}
.lpc-table thead th{
  position:sticky;
  top:0;
  z-index:3;
}
.lpc-table thead th:first-child,
.lpc-table tbody td:first-child{
  position:sticky;
  left:0;
  z-index:2;
  background:#fff;
}
.lpc-table thead th:first-child{
  z-index:4;
  background:#fbfcff;
}
.lpc-table tbody tr:last-child td{ border-bottom:0; }
.lpc-table .lpc-cell-muted{ color:var(--lpc-muted); }
.lpc-table .lpc-cell-strong{ font-weight:800; white-space:nowrap; }
.lpc-table .lpc-note{
  padding:12px 16px;
  border-top:1px solid var(--lpc-line);
  font-size:13px;
  color:var(--lpc-muted);
  background:#fff;
  text-align:left;
}
@media (max-width: 575px){
  .lpc-table table{ min-width:560px; }
}
.lpc-left-table .lpc-grid-2{ align-items:start; }
@media (min-width: 992px){
  .lpc-left-table .lpc-grid-2{ grid-template-columns:minmax(360px, 1fr) minmax(420px, 520px); }
}
.lpc-centered-table .lpc-table-wrap{ display:flex; justify-content:center; }
.lpc-centered-table .lpc-table{ width:100%; max-width:920px; }

/* ===== Tabs ===== */
.lpc-tabs .lpc-tabs-head{ text-align:center; margin-bottom:20px; }
.lpc-tabs .lpc-tabs-head p{ max-width:760px; margin:0 auto; }
.lpc-tabs .lpc-tabs-nav{ display:flex; justify-content:center; gap:8px; flex-wrap:wrap; margin-bottom:18px; }
.lpc-tabs .lpc-tabs-btn{
  appearance:none;
  border:1px solid var(--lpc-line);
  background:#fff;
  color:var(--lpc-text);
  padding:10px 14px;
  border-radius:12px;
  font-size:14px;
  font-weight:700;
  cursor:pointer;
}
.lpc-tabs .lpc-tabs-btn:hover{ border-color:#d9dfec; }
.lpc-tabs .lpc-tabs-btn.is-active{
  background:var(--lpc-dark);
  border-color:var(--lpc-dark);
  color:#fff;
}
.lpc-tabs .lpc-tabs-content{ display:flex; justify-content:center; }
.lpc-tabs .lpc-tab-pane{
  width:100%;
  max-width:920px;
  border:1px solid var(--lpc-line);
  border-radius:12px;
  background:#fff;
  box-shadow:var(--lpc-shadow);
  padding:18px;
  display:none;
}
.lpc-tabs .lpc-tab-pane.is-active{ display:block; }
@media (min-width: 992px){
  .lpc-tabs .lpc-tab-pane{ padding:22px; }
}
.lpc-tabs .lpc-tab-grid{ display:grid; grid-template-columns:1fr; gap:16px; }
@media (min-width: 768px){
  .lpc-tabs .lpc-tab-grid{ grid-template-columns:1fr 1fr; gap:20px; }
}

/* ===== Two-column text ===== */
.lpc-two-col .lpc-tc-wrap{ display:grid; grid-template-columns:1fr; gap:24px; }
@media (min-width: 768px){
  .lpc-two-col .lpc-tc-wrap{ grid-template-columns:1fr 1fr; gap:32px; }
}
.lpc-two-col .lpc-tc-col{ max-width:520px; margin:0 auto; }
.lpc-two-col .lpc-tc-title{ text-align:center; margin-bottom:10px; }

/* ===== Registration gated ===== */
.lpc-reg .lpc-grid-2{ align-items:start; }
@media (min-width: 992px){
  .lpc-reg .lpc-grid-2{ grid-template-columns:minmax(360px, 1fr) minmax(420px, 520px); align-items:center; }
}
.lpc-reg .lpc-reg-card{
  background:#fff;
  border:1px solid var(--lpc-line);
  border-radius:12px;
  box-shadow:var(--lpc-shadow);
  padding:16px;
}
@media (min-width: 992px){
  .lpc-reg .lpc-reg-card{ padding:18px; }
}
.lpc-reg .lpc-reg-card-title{
  font-weight:800;
  font-size:14px;
  margin:0 0 12px;
}

/* ===== YouTube lazy ===== */
.lpc-youtube .lpc-grid-2{ align-items:start; }
@media (min-width: 992px){
  .lpc-youtube .lpc-grid-2{ grid-template-columns:minmax(360px, 1fr) minmax(420px, 520px); align-items:center; }
}
.lpc-youtube .lpc-video{
  width:100%;
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 10px 22px rgba(18,24,38,.10);
  background:#000;
}
.lpc-youtube .lpc-aspect{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  background:#000;
}
.lpc-youtube .lpc-thumb{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  padding:0;
  margin:0;
  cursor:pointer;
  background:transparent;
  display:block;
}
.lpc-youtube .lpc-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:saturate(.95) contrast(1.02);
  opacity:.98;
}
.lpc-youtube .lpc-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.18));
  pointer-events:none;
}
.lpc-youtube .lpc-play{
  position:absolute;
  left:16px;
  bottom:16px;
  display:flex;
  align-items:center;
  gap:10px;
  pointer-events:none;
}
.lpc-youtube .lpc-play-circle{
  width:48px;
  height:48px;
  border-radius:14px;
  background:rgba(17,24,39,.86);
  border:1px solid rgba(255,255,255,.18);
  display:flex;
  align-items:center;
  justify-content:center;
}
.lpc-youtube .lpc-play-label{
  color:#fff;
  font-weight:800;
  font-size:14px;
  letter-spacing:-0.01em;
  padding:8px 10px;
  border-radius:12px;
  background:rgba(17,24,39,.72);
  border:1px solid rgba(255,255,255,.14);
}
.lpc-youtube .lpc-frame{ position:absolute; inset:0; width:100%; height:100%; border:0; }
