/* =========================================================
   ULZEO — warm paper + premium blue panels (mobile-first)
   Single shared stylesheet for: base / landing / auth / dashboard
   ========================================================= */

/* ---------- Fonts (Inter) ---------- */
@font-face{
  font-family:"Inter";
  src:
    url("/static/fonts/inter/inter.ttf") format("truetype"),
    url("/static/fonts/Inter/inter.ttf") format("truetype");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:"Inter";
  src:
    url("/static/fonts/inter/extrabold.ttf") format("truetype"),
    url("/static/fonts/Inter/extrabold.ttf") format("truetype");
  font-weight:800;
  font-style:normal;
  font-display:swap;
}

/* ---------- Reset ---------- */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img,svg,video{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button,input,textarea,select{font:inherit;}
textarea{resize:vertical;}
/* better defaults */
button{background:none;border:none;}
:focus{outline:none;}
:focus-visible{
  outline:3px solid color-mix(in srgb, var(--brand) 55%, white);
  outline-offset:3px;
  border-radius:12px;
}
::selection{background:color-mix(in srgb, var(--brand) 22%, transparent);}

/* =========================================================
   Tokens
   ========================================================= */
:root{
  /* brand */
  --brand:#012056;
  --brand-2:#60a5fa;

  /* semantic */
  --success:#16a34a;
  --danger:#dc2626;
  --warning:#f59e0b;
  --info:#2563eb;

  /* neutrals */
  --bg:#fbfaf6;
  --surface:#ffffff;
  --surface-2:#f6f7fb;
  --tint:#eef4ff;

  --text:#0b0f14;
  --muted:#5b6473;
  --muted-2:#7a8596;

  --border:rgba(15,23,42,.10);
  --border-2:rgba(15,23,42,.16);

  /* shadows */
  --shadow-xs:0 1px 2px rgba(2,6,23,.06);
  --shadow-sm:0 8px 24px rgba(2,6,23,.10);
  --shadow-md:0 18px 60px rgba(2,6,23,.14);

  /* radius */
  --r-sm:14px;
  --r-md:18px;
  --r-lg:24px;
  --r-xl:30px;

  /* layout */
  --container:1100px;

  /* spacing */
  --s1:6px;
  --s2:10px;
  --s3:14px;
  --s4:18px;
  --s5:22px;
  --s6:28px;
  --s7:36px;
  --s8:48px;
  --s9:64px;

  /* type */
  --font-display:ui-serif,Georgia,"Times New Roman",serif;
  --h1:clamp(2.0rem,5.0vw,3.1rem);
  --h2:clamp(1.5rem,3.3vw,2.05rem);
  --h3:clamp(1.05rem,2.1vw,1.30rem);
  --p: clamp(1.0rem,1.2vw,1.08rem);
}

/* =========================================================
   Base typography helpers
   ========================================================= */
.h1{font-family:var(--font-display);font-size:var(--h1);line-height:1.06;letter-spacing:-.03em;}
.h2{font-family:var(--font-display);font-size:var(--h2);line-height:1.12;letter-spacing:-.02em;}
.h3{font-size:var(--h3);letter-spacing:-.02em;}
.muted{color:var(--muted);}
.microcopy{color:var(--muted-2);font-size:.94rem;}
.hidden{display:none !important;}

/* =========================================================
   Container / Page spacing
   ========================================================= */
.container{
  width:min(var(--container), calc(100% - 2 * var(--s5)));
  margin-inline:auto;
}
main{min-height:60vh;}
.page-pad{padding:var(--s7) 0;}

/* =========================================================
   Topbar
   ========================================================= */
.topbar{
  position:sticky;top:0;z-index:50;
  border-bottom:1px solid var(--border);
  background:color-mix(in srgb, var(--bg) 70%, transparent);
}
@supports (backdrop-filter: blur(10px)){
  .topbar{backdrop-filter:blur(12px);}
}
.topbar-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:var(--s4);
  padding:14px 0;
}
.brand{display:inline-flex;align-items:center;gap:10px;}
.logo{max-width:110px;height:auto;}
.topbar-nav{display:flex;align-items:center;gap:var(--s4);flex:1;justify-content:center;}
.topbar-link{
  color:var(--text);
  text-decoration:none;
  font-weight:500;
  font-size:.95rem;
  padding:8px 12px;
  border-radius:8px;
  transition:background .18s ease,color .18s ease;
}
.topbar-link:hover{
  background:color-mix(in srgb, var(--surface) 60%, transparent);
  color:var(--text);
}
.topbar-actions{display:flex;align-items:center;gap:var(--s2);}

/* Responsive topbar navigation */
@media (max-width: 768px){
  .topbar-nav{display:none;} /* Hide nav links on mobile, keep logo and actions */
  .topbar-inner{gap:var(--s2);}
}
@media (max-width: 480px){
  .topbar-actions .btn.small{padding:6px 10px;font-size:.85rem;}
  .topbar-actions{gap:var(--s1);}
}

/* =========================================================
   Buttons — supports BOTH naming styles:
   .btn.primary / .btn.secondary (legacy)
   and .btn--primary / .btn--outline / .btn--ghost (dashboard)
   ========================================================= */
.btn,
a.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:12px 16px;
  border-radius:999px;
  border:1px solid var(--border);
  background:color-mix(in srgb, var(--surface) 92%, transparent);
  color:var(--text);
  font-weight:650;
  letter-spacing:-.01em;
  cursor:pointer;
  user-select:none;
  transition:transform .12s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease, color .18s ease;
  box-shadow:var(--shadow-xs);
}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm);}
.btn:active{transform:translateY(0);box-shadow:var(--shadow-xs);}

.btn.small,
.btn--small{padding:8px 12px;font-size:.92rem;gap:6px;}
.btn.large{padding:14px 18px;font-size:1.02rem;}
.btn.full,
.btn--full{width:100%;}
.btn--wide{width:min(520px,100%);}

.btn.secondary{
  background:color-mix(in srgb, var(--surface) 78%, transparent);
  border-color:var(--border);
}
.btn.secondary:hover{
  background:color-mix(in srgb, var(--surface) 92%, transparent);
  border-color:var(--border-2);
}

/* “brand” = primary blue (used on auth) */
.btn.brand,
.btn--primary{
  background:linear-gradient(180deg, color-mix(in srgb, var(--success) 92%, white), var(--success));
  color:#fff;
}
.btn.brand:hover,
.btn--primary:hover{box-shadow:0 18px 60px rgba(2,6,23,.24);}

/* “primary” legacy kept as WhatsApp-green CTA if you already use it on landing */
.btn.primary{
  background:linear-gradient(180deg, color-mix(in srgb, var(--success) 92%, white), var(--success));
  color:#fff;
  border-color:rgba(0,0,0,.18);
  box-shadow:0 16px 45px rgba(2,6,23,.16);
}
.btn.primary:hover{box-shadow:0 18px 60px rgba(2,6,23,.22);}

.btn--success{
  background:linear-gradient(180deg, color-mix(in srgb, var(--success) 92%, white), var(--success));
  border-color:color-mix(in srgb, var(--success) 55%, var(--border));
  color:#fff;
}
.btn--outline{
  background:transparent;
  border-color:color-mix(in srgb, var(--brand) 30%, var(--border));
  color:color-mix(in srgb, var(--brand) 70%, var(--text));
}
.btn--outline:hover{
  background:color-mix(in srgb, var(--brand) 8%, transparent);
  border-color:color-mix(in srgb, var(--brand) 44%, var(--border));
}
.btn--ghost{
  background:transparent;
  border-color:var(--border);
  box-shadow:none;
}
.btn--ghost:hover{
  background:color-mix(in srgb, var(--surface) 75%, transparent);
  box-shadow:var(--shadow-xs);
}

/* legacy “copied” */
.btn.is-copied{
  background:color-mix(in srgb, var(--brand) 14%, var(--surface));
  border-color:color-mix(in srgb, var(--brand) 24%, var(--border));
}

/* =========================================================
   Form controls (works with Django default widgets)
   ========================================================= */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="url"],
input[type="number"],
input[type="tel"],
input[type="file"],
select,
textarea{
  width:100%;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background:color-mix(in srgb, var(--surface) 92%, transparent);
  color:var(--text);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.55);
  transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
input[type="file"]{padding:10px 12px;}
input:focus,
select:focus,
textarea:focus{
  border-color:color-mix(in srgb, var(--brand) 55%, var(--border));
  box-shadow:0 0 0 4px color-mix(in srgb, var(--brand) 16%, transparent);
  background:#fff;
}
label{display:block;font-weight:650;margin-bottom:8px;letter-spacing:-.01em;color:color-mix(in srgb, var(--text) 90%, var(--muted));}

/* =========================================================
   Cards / Notices
   ========================================================= */
.card{
  background:color-mix(in srgb, var(--surface) 96%, transparent);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  box-shadow:var(--shadow-xs);
}
.card-pad{padding:var(--s6);}

.notice{
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background:color-mix(in srgb, var(--surface-2) 75%, transparent);
  color:var(--text);
}
.notice--error{
  background:color-mix(in srgb, var(--danger) 8%, var(--surface));
  border-color:color-mix(in srgb, var(--danger) 28%, var(--border));
  color:color-mix(in srgb, var(--danger) 70%, var(--text));
}
.notice--ok{
  background:color-mix(in srgb, var(--brand) 9%, var(--surface));
  border-color:color-mix(in srgb, var(--brand) 22%, var(--border));
  color:color-mix(in srgb, var(--brand) 75%, var(--text));
}

/* =========================================================
   AUTH (login/signup)
   ========================================================= */
.auth{
  padding:var(--s8) 0;
  background:
    radial-gradient(1200px 520px at 18% 0%,
      color-mix(in srgb, #012056 14%, transparent), transparent 60%),
    linear-gradient(180deg,
      color-mix(in srgb, var(--surface) 65%, transparent), transparent 55%),
    color-mix(in srgb, var(--bg) 92%, white);
}
.auth-inner{display:grid;place-items:center;}
.auth-card{
  width:min(520px, 100%);
  padding:var(--s6);
}
.auth-head{display:grid;gap:var(--s2);margin-bottom:var(--s5);}
.auth-title{
  font-family:var(--font-display);
  font-size:clamp(1.6rem, 3.2vw, 2.0rem);
  line-height:1.1;
  letter-spacing:-.03em;
}
.auth-form{display:grid;gap:var(--s4);}
.form-row{display:grid;gap:8px;}
.auth-error{margin-bottom:var(--s4);}
.auth-link{  font-weight:650; }
.auth-link:hover{text-decoration:underline;}

/* =========================================================
   DASHBOARD (layout / sidebar / sessions / panel / results)
   ========================================================= */
.layout{
  width:min(var(--container), calc(100% - 2 * var(--s5)));
  margin:var(--s6) auto var(--s8);
  display:grid;
  grid-template-columns: 1fr;
  gap:var(--s5);
}
.sidebar{
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  background:color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow:var(--shadow-xs);
  padding:var(--s5);
  display:grid;
  gap:var(--s4);
}
.sidebar__title{
  font-size:1.02rem;
  letter-spacing:-.02em;
  color:color-mix(in srgb, var(--text) 88%, var(--muted));
}
.sessions{display:grid;gap:10px;}
.sessions__empty{color:var(--muted);font-size:.95rem;}

.session{
  display:flex;
  gap:12px;
  align-items:center;
  padding:10px;
  border-radius:16px;
  border:1px solid var(--border);
  background:color-mix(in srgb, var(--surface) 92%, transparent);
  transition:transform .12s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.session:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm);}
.session--active{
  border-color:color-mix(in srgb, var(--brand) 30%, var(--border));
  background:color-mix(in srgb, var(--brand) 7%, var(--surface));
}
.session__thumb{
  width:46px;height:46px;border-radius:14px;
  border:1px solid var(--border);
  overflow:hidden;
  background:color-mix(in srgb, var(--surface-2) 92%, transparent);
  display:grid;place-items:center;
}
.session__thumb img{width:100%;height:100%;object-fit:cover;}
.session__meta{display:grid;gap:2px;min-width:0;}
.session__name{font-weight:750;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.session__sub{color:var(--muted);font-size:.9rem;}

.main{min-width:0;}
.panel{
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  background:
    linear-gradient(180deg,
      color-mix(in srgb, var(--surface) 92%, transparent),
      color-mix(in srgb, #012056 6%, white));
  box-shadow:var(--shadow-sm);
  padding:var(--s6);
}
.panel__header{
  display:flex;
  align-items:flex-start;
  gap:var(--s4);
  margin-bottom:var(--s6);
}
.avatar-circle{
  width:44px;height:44px;border-radius:999px;
  border:1px solid color-mix(in srgb, var(--brand) 22%, var(--border));
  background:
    radial-gradient(circle at 30% 30%,
      color-mix(in srgb, var(--brand-2) 80%, white),
      color-mix(in srgb, var(--brand) 55%, #012056));
  box-shadow:var(--shadow-xs);
  flex:0 0 auto;
}

.section-title{
  font-weight:800;
  letter-spacing:-.02em;
  margin:var(--s4) 0 var(--s3);
}

/* Dashboard avatar grid: keep your landing styles intact by scoping overrides to .panel */
.panel .avatar-grid{
  background:transparent;
  border:none;
  padding:0;
  box-shadow:none;
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap:12px;
}
.panel .avatar-card{
  padding:0;
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--border);
  background:color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow:var(--shadow-xs);
  cursor:pointer;
}
.panel .avatar-card img{
  width:100%;
  height:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  transition:transform .18s ease;
}
.panel .avatar-card:hover img{transform:scale(1.03);}
.panel .avatar-card:focus-visible{outline-offset:4px;}

.upload-row{
  display:flex;
  flex-wrap:wrap;
  gap:var(--s3);
  align-items:center;
  margin-top:var(--s2);
}
.file-input{flex:1 1 240px;}

.preview{margin-top:var(--s4);}
.preview__box{
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  background:color-mix(in srgb, var(--surface) 92%, transparent);
  padding:var(--s4);
  box-shadow:var(--shadow-xs);
}
.preview__label{font-weight:750;color:var(--muted);font-size:.92rem;margin-bottom:10px;}
.preview__img{
  width:100%;
  border-radius:var(--r-md);
  border:1px solid var(--border);
  background:color-mix(in srgb, var(--surface-2) 85%, transparent);
}

.loading{
  margin-top:var(--s4);
  display:flex;
  align-items:center;
  gap:12px;
  color:var(--muted);
  font-weight:650;
}
.spinner{
  width:18px;height:18px;border-radius:999px;
  border:2px solid color-mix(in srgb, var(--brand) 25%, var(--border));
  border-top-color:color-mix(in srgb, var(--brand) 85%, var(--text));
  animation:spin .9s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

.error{
  margin-top:var(--s4);
  padding:12px 14px;
  border-radius:14px;
  border:1px solid color-mix(in srgb, var(--danger) 30%, var(--border));
  background:color-mix(in srgb, var(--danger) 8%, var(--surface));
  color:color-mix(in srgb, var(--danger) 70%, var(--text));
}

/* Results */
.results__title{
  font-weight:850;
  letter-spacing:-.02em;
  margin-bottom:var(--s4);
}
.results__group{margin-top:var(--s5);}
.results__group-title{
  color:var(--muted);
  font-weight:750;
  margin-bottom:12px;
}
.results__grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap:12px;
}
.result-card{
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  background:color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow:var(--shadow-xs);
  padding:12px;
  display:grid;
  gap:10px;
}
.result-card__frame{
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--border);
  background:color-mix(in srgb, var(--surface-2) 90%, transparent);
}
.result-card__frame img{width:100%;height:auto;display:block;}
.result-card__frame--vertical img{aspect-ratio:9/16;object-fit:cover;}

/* =========================================================
   Landing/marketing sections (kept from your current identity)
   ========================================================= */
.section{
  background-color: #EDEDED;

  border-top:1px solid var(--border);
  padding:var(--s9) 0;
}
.section-head{
  max-width:760px;
  display:grid;
  gap:var(--s2);
  margin-bottom:var(--s7);
}
.section-head h2{
  font-family:var(--font-display);
  font-size:var(--h2);
  letter-spacing:-.02em;
  line-height:1.12;
}
.section-head p{color:var(--muted);font-size:var(--p);}

/* anchor offset for sticky topbar */
#como-funciona,#preco,#avatares{background-color: #FBFAF7;scroll-margin-top:92px;border-top:1px solid var(--border);}
#avatares{background:#EDEDED;}

/* Hero */
.hero{
  position:relative;
  padding:40px 0 var(--s8);
  background:
    radial-gradient(1200px 520px at 18% 0%,
      color-mix(in srgb, #012056 15%, transparent), transparent 60%),
    linear-gradient(180deg,
      color-mix(in srgb, var(--surface) 65%, transparent), transparent 55%),
    color-mix(in srgb, var(--bg) 92%, white);
}
.hero-inner{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:var(--s5);
  align-items:center;
}
.hero-copy h1{
  font-family:var(--font-display);
  font-size:var(--h1);
  line-height:1.05;
  letter-spacing:-.03em;
  margin-bottom:var(--s3);
}
.hero-copy p{color:var(--muted);font-size:var(--p);margin-bottom:var(--s5);}

/* Pricing page hero - smaller text */
.hero-pricing .hero-copy h1{
  font-size:clamp(1.5rem, 3vw, 2rem);
  margin-bottom:var(--s2);
}

.hero-pricing .hero-copy p{
  font-size:.95rem;
  margin-bottom:var(--s4);
}
.hero-cta{display:flex;gap:var(--s3);align-items:center;}
.whatsapp{max-width:25px;}
.hero-footnote{margin-top:var(--s3);color:var(--muted-2);font-size:.92rem;}

/* Marketing preview cards */
.preview-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4);}
.preview-card{
  border-radius:var(--r-lg);
  border:1px solid var(--border);
  background:color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow:var(--shadow-xs);
  overflow:hidden;
}
.preview-frame{
  aspect-ratio:9/16;
  display:grid;
  place-items:center;
  background-color:transparent;
}
.preview-placeholder{font-weight:750;color:color-mix(in srgb, var(--muted) 80%, var(--text));}
.initialimage{width:100%;}

/* Panels */
.steps,
.avatar-grid{
  background:#01205617;
  border:1px solid color-mix(in srgb, var(--brand) 14%, var(--border));
  border-radius:var(--r-xl);
  padding:var(--s5);
  box-shadow:var(--shadow-xs);
}
.steps{display:grid;grid-template-columns:1fr;gap:var(--s4);}
.step-card{
  background:color-mix(in srgb, var(--surface) 96%, transparent);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:var(--s5);
  box-shadow:var(--shadow-xs);
  display:grid;
  gap:var(--s3);
}
.step-top{display:flex;align-items:center;justify-content:space-between;}
.step-card h3{font-size:var(--h3);letter-spacing:-.02em;}
.step-card p{color:var(--muted);}

/* Marketing avatar cards */
.avatar-grid{display:grid;grid-template-columns:1fr;gap:var(--s4);}
.avatar-card{
  background:color-mix(in srgb, var(--surface) 96%, transparent);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:var(--s5);
  box-shadow:var(--shadow-xs);
  display:grid;
  gap:var(--s3);
  transition:transform .14s ease, box-shadow .18s ease, border-color .18s ease;
}
.avatar-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-sm);
  border-color:color-mix(in srgb, var(--brand) 18%, var(--border));
}

/* Carousel mode */
.avatar-grid.is-carousel{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(82%,1fr);
  overflow-x:auto;
  gap:var(--s3);
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding-bottom:var(--s3);
}
.avatar-grid.is-carousel .avatar-card{scroll-snap-align:start;}
.avatar-grid.is-carousel::-webkit-scrollbar{height:10px;}
.avatar-grid.is-carousel::-webkit-scrollbar-thumb{
  background:color-mix(in srgb, var(--border-2) 55%, transparent);
}

/* =========================================================
   Footer
   ========================================================= */
.footer{
  border-top:1px solid var(--border);
  padding:var(--s8) 0;
  background:linear-gradient(180deg, transparent, color-mix(in srgb, var(--surface) 85%, transparent));
}
.footer-inner{
  display:grid;
  grid-template-columns:1fr;
  gap:var(--s6);
}
.footer-brand{
  font-weight:800;
  letter-spacing:-.04em;
  font-size:1.25rem;
}
.footer-links{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--s5);
}
.footer-col{display:grid;gap:10px;}
.footer-col-title{font-weight:750;}
.footer-col a{
  color:var(--muted);
  border-radius:10px;
  transition:color .18s ease;
}
.footer-col a:hover{color:color-mix(in srgb, var(--brand) 75%, var(--text));}

/* =========================================================
   Responsive
   ========================================================= */
@media (min-width: 920px){
  .layout{grid-template-columns: 360px 1fr; align-items:start;}
  .sidebar{position:sticky; top:92px;}
}
@media (min-width: 820px){
  .steps{grid-template-columns:1fr 1fr;}
  .avatar-grid{grid-template-columns:1fr 1fr; background:#01205612;}
  .footer-inner{grid-template-columns:1fr 1.2fr;}
  .footer-links{grid-template-columns:repeat(3, minmax(0,1fr));}
}
@media (max-width: 920px){
  .hero-inner{grid-template-columns:1fr;}
  .hero-cta{flex-direction:column;align-items:stretch;}
  .preview-grid{grid-template-columns:1fr 1fr;}
  .layout { margin: 0;}
}
@media (max-width: 620px){
  .section{padding:var(--s8) 0;}
  .preview-grid{grid-template-columns:1fr;}
  .btn{padding:10px 14px;}
  .panel{padding:var(--s5);}
}

/* Motion safety */
@media (prefers-reduced-motion: reduce){
  *{transition:none !important;scroll-behavior:auto !important;animation:none !important;}
}

/* =========================================================
   HERO PREVIEWS — real carousel (2 visible on mobile)
   ========================================================= */
.hero-previews{
  position:relative;
  padding:0;border:0;background:transparent;box-shadow:none;
  overflow:visible;
}
.hero-carousel-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  z-index:5;
  width:44px;height:44px;border-radius:999px;
  border:1px solid var(--border-2);
  background:color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow:var(--shadow-sm);
  display:grid;place-items:center;
  cursor:pointer;user-select:none;
  font-size:24px;line-height:1;
}
.hero-carousel-btn.prev{left:6px;}
.hero-carousel-btn.next{right:6px;}
.hero-carousel-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:var(--shadow-xs);}

.preview-grid.hero-carousel{
  --hero-gap:14px;
  gap:12px;
  display:grid;
  grid-auto-flow:column;
  grid-template-columns:none;
  grid-auto-columns:calc((100% - var(--hero-gap)) / 2);
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scroll-snap-type:x mandatory;
  scroll-padding:12px;
  padding:0;
  scrollbar-width:none;
  overscroll-behavior-x:contain;
}
.preview-grid.hero-carousel::-webkit-scrollbar{display:none;}

@media (max-width: 380px){
  .preview-grid.hero-carousel{--hero-gap:10px;}
  .hero-carousel-btn{width:40px;height:40px;}
}

.sec2-images {
  border-radius: var(--r-lg);
}

/* =========================================================
   DASHBOARD — ChatGPT-inspired (scoped)
   Keeps ULZEO identity but makes UI professional + product-like.
   ========================================================= */

.page-dashboard{
  /* ChatGPT-like neutral canvas, but tinted with ULZEO warm bg */
  --dash-bg: color-mix(in srgb, #f7f7f8 78%, var(--bg));
  --dash-surface: #ffffff;
  --dash-border: rgba(15,23,42,.12);
  --dash-muted: color-mix(in srgb, var(--muted) 92%, #111827);
  --dash-radius: 14px;
  --dash-radius-sm: 12px;
  --dash-shadow: 0 1px 0 rgba(15,23,42,.04);

  background: var(--dash-bg);
}

/* Optional: ChatGPT typically has no marketing footer in-app */
.page-dashboard .footer{ display:none; }

/* Make main area feel like an app shell */
.page-dashboard main{
  min-height: calc(100vh - 72px);
}

/* Layout: tighter and more "app" */
.page-dashboard .layout{
  width: min(var(--container), calc(100% - 2 * var(--s5)));
  gap: 14px;
}

/* Sidebar: flat, subtle, scrollable list */
.page-dashboard .sidebar{
  background: #012056;
  border: 1px solid var(--dash-border);
  border-radius: var(--dash-radius);
  box-shadow: var(--dash-shadow);
  padding: 14px;
  gap: 12px;
}

.page-dashboard .sidebar__title{
  font-size: .95rem;
  font-weight: 700;
  color: var(--dash-muted);
  margin-top: 6px;
}

/* Sessions list feels like ChatGPT conversation list */
.page-dashboard .sessions{
  gap: 6px;
  max-height: calc(100vh - 200px);
  overflow: auto;
  padding-right: 4px;
}
.page-dashboard .sessions::-webkit-scrollbar{ width: 10px; }
.page-dashboard .sessions::-webkit-scrollbar-thumb{
  background: color-mix(in srgb, var(--dash-border) 70%, transparent);
  border-radius: 999px;
}

/* Session row: cleaner, no heavy card shadows */
.page-dashboard .session{
  border: 1px solid transparent;
  background: transparent;
  border-radius: 12px;
  padding: 10px;
  box-shadow: none;
  transform: none;
  position: relative;
}
.page-dashboard .session:hover{
  background: color-mix(in srgb, var(--brand) 6%, #f3f4f6);
  border-color: color-mix(in srgb, var(--dash-border) 65%, transparent);
  box-shadow: none;
}
.page-dashboard .session--active{
  background: color-mix(in srgb, var(--brand) 10%, #ffffff);
  border-color: color-mix(in srgb, var(--brand) 18%, var(--dash-border));
}
.page-dashboard .session--active::before{
  content:"";
  position:absolute;
  left: 6px;
  top: 10px;
  bottom: 10px;
  width: 3px;
  border-radius: 999px;
  background: var(--brand);
  opacity: .9;
}

/* "Nova foto" button in sidebar – destacado como botão de novo chat (ChatGPT-like) */
.page-dashboard .sidebar #btnNew{
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--brand) 40%, var(--dash-border));
  background: radial-gradient(circle at 0 0, color-mix(in srgb, var(--brand) 40%, #ffffff), var(--brand));
  color: #ffffff;
  font-weight: 700;
  justify-content: flex-start;
  gap: 10px;
  padding-inline: 14px;
}
.page-dashboard .sidebar #btnNew:hover{
  filter: brightness(1.02);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--brand) 20%, transparent);
}

.page-dashboard .session__thumb{
  width: 40px;
  height: 40px;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--dash-border) 70%, transparent);
  background: #f3f4f6;
}
.page-dashboard .session__name{
  font-weight: 650;
  letter-spacing: -.01em;
}
.page-dashboard .session__sub{
  font-size: .86rem;
  color: color-mix(in srgb, var(--muted) 92%, #111827);
}

/* Main panel: flatter, like ChatGPT message area */
.page-dashboard .panel{
  background: var(--dash-surface);
  border: 1px solid var(--dash-border);
  border-radius: var(--dash-radius);
  box-shadow: var(--dash-shadow);
  padding: 18px;
}

/* Header: professional typography (no serif display on dashboard) */
.page-dashboard .panel__header{
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}

.page-dashboard .h1{
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 1.35rem;
  line-height: 1.25;
  letter-spacing: -.02em;
}

.page-dashboard .avatar-circle{
  width: 34px;
  height: 34px;
  border-radius: 10px; /* chatgpt-ish squared avatar */
  border: 1px solid color-mix(in srgb, var(--dash-border) 80%, transparent);
  background: color-mix(in srgb, var(--brand) 10%, #ffffff);
  box-shadow: none;
}

/* Section titles: ChatGPT-like labels */
.page-dashboard .section-title{
  font-weight: 700;
  font-size: .92rem;
  color: color-mix(in srgb, var(--text) 84%, var(--muted));
  margin: 16px 0 10px;
}

/* Buttons: less “pill”, more professional */
.page-dashboard .btn,
.page-dashboard a.btn{
  border-radius: 12px;
  box-shadow: none;
  padding: 10px 12px;
  font-weight: 650;
}
.page-dashboard .btn:hover{ transform:none; box-shadow:none; }
.page-dashboard .btn:active{ transform:none; }

.page-dashboard .btn--ghost{
  background: #fff;
  border-color: var(--dash-border);
}
.page-dashboard .btn--ghost:hover{
  background: #f7f7f8;
}
.page-dashboard .btn--outline{
  border-color: var(--dash-border);
  color: color-mix(in srgb, var(--text) 85%, var(--muted));
}
.page-dashboard .btn--outline:hover{
  background: #f7f7f8;
}
.page-dashboard .btn--success{
  background: linear-gradient(180deg, color-mix(in srgb, var(--success) 92%, white), var(--success));
  border-color: color-mix(in srgb, var(--success) 35%, var(--dash-border));
}

/* Avatar grid: professional selector tiles */
.page-dashboard .panel .avatar-grid{
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 10px;
}
.page-dashboard .panel .avatar-card{
  border-radius: 12px;
  border: 1px solid var(--dash-border);
  background: #fff;
  box-shadow: none;
}
.page-dashboard .panel .avatar-card:hover{
  border-color: color-mix(in srgb, var(--brand) 22%, var(--dash-border));
}
.page-dashboard .panel .avatar-card img{
  border-radius: 12px 0px 0px 0;
}

/* Upload row: cleaner alignment */
.page-dashboard .upload-row{
  gap: 10px;
}
.page-dashboard .file-input{
  border-radius: 12px;
  border-color: var(--dash-border);
  background: #fff;
}

/* Preview: like attachment card */
.page-dashboard .preview__box{
  border-radius: 14px;
  border-color: var(--dash-border);
  background: #fff;
  box-shadow: none;
}
.page-dashboard .preview__label{
  font-weight: 650;
  color: color-mix(in srgb, var(--muted) 92%, #111827);
}

/* Results grid: less “cardy”, more gallery */
.page-dashboard .results__title{
  font-weight: 750;
  margin-bottom: 10px;
}
.page-dashboard .result-card{
  border-radius: 14px;
  border-color: var(--dash-border);
  background: #fff;
  box-shadow: none;
}
.page-dashboard .result-card__frame{
  border-radius: 12px;
  border-color: var(--dash-border);
  background: #f7f7f8;
}

/* Desktop: slightly wider sidebar like ChatGPT */
@media (min-width: 920px){
  .page-dashboard .layout{ grid-template-columns: 320px 1fr; }
  .page-dashboard .sidebar{ top: 76px; } /* topbar height-ish */
}

.topbar-logout{ display:inline; margin:0; }
.topbar-logout button{ appearance:none; -webkit-appearance:none; }

/* =========================================================
   DASHBOARD UX upgrades (professional, ChatGPT-like) — scoped
   ========================================================= */

/* accessible hidden */
.sr-only{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

.page-dashboard .btn-ico{
  width:18px;height:18px;
  display:inline-grid;place-items:center;
}
.page-dashboard .btn-ico svg{width:18px;height:18px;}

/* Header */
.page-dashboard .dash-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(15,23,42,.08);
  margin-bottom:14px;
}
.page-dashboard .dash-header__left{
  display:flex;align-items:center;gap:12px;
}
.page-dashboard .dash-mark{
  width:36px;height:36px;
  border-radius:12px;
  border:1px solid rgba(15,23,42,.10);
  background: color-mix(in srgb, var(--brand) 12%, #fff);
}
.page-dashboard .dash-title{
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  font-size:1.35rem;
  line-height:1.25;
  letter-spacing:-.02em;
  margin:0;
}
.page-dashboard .dash-subtitle{
  margin-top:2px;
  color:var(--muted);
  font-size:.96rem;
}

.page-dashboard .dash-header__right{
  display:flex;
  align-items:center;
  gap:14px;
  justify-content:flex-end;
}

.page-dashboard .dash-user{
  display:flex;align-items:center;gap:10px;
  border:1px solid rgba(15,23,42,.10);
  border-radius:14px;
  background:#fff;
  padding: 0 12px;
  min-height: 60px;
}
.page-dashboard .dash-user__avatar{
  width:34px;height:34px;border-radius:12px;
  display:grid;place-items:center;
  font-weight:750;
  color:color-mix(in srgb, var(--brand) 70%, #111827);
  background:color-mix(in srgb, var(--brand) 10%, #fff);
  border:1px solid rgba(15,23,42,.08);
}
.page-dashboard .dash-user__name{font-weight:700;letter-spacing:-.01em;}
.page-dashboard .dash-user__sub{font-size:.86rem;color:var(--muted);}

.page-dashboard .dash-stats{
  display:flex;
  gap:10px;
}
.page-dashboard .dash-stat{
  padding: 8px 10px;
    border: 1px solid rgba(15, 23, 42, .10);
    border-radius: 14px;
    background: #fff;
    min-width: 92px;
    display: flex;
    align-items: center;
    min-height: 60px;
    gap: 10px;
}
.page-dashboard .dash-stat__label{
  font-size:.78rem;
  color:var(--muted);
}
.page-dashboard .dash-stat__value{
  font-size:1.05rem;
  font-weight:800;
  letter-spacing:-.02em;
}

/* Avatar selected state (clear & professional) */
.page-dashboard .panel .avatar-card{
  position:relative;
  gap: 0;
}
.page-dashboard .panel .avatar-check{
  position:absolute;
  right:10px;
  top:10px;
  width:26px;height:26px;
  border-radius:10px;
  display:grid;place-items:center;
  background:#fff;
  border:1px solid rgba(15,23,42,.12);
  opacity:0;
  transform:scale(.96);
  transition:opacity .15s ease, transform .15s ease;
  color:var(--brand);
}
.page-dashboard .panel .avatar-check svg{width:16px;height:16px;}

.page-dashboard .panel .avatar-card.selected{
  border-color:color-mix(in srgb, var(--brand) 35%, rgba(15,23,42,.12));
  box-shadow:0 0 0 3px color-mix(in srgb, var(--brand) 16%, transparent);
}
.page-dashboard .panel .avatar-card.selected .avatar-check{
  opacity:1;
  transform:scale(1);
}

/* Upload block */
.page-dashboard .upload-block{
  margin-top:8px;
  display:grid;
  gap:12px;
}

.page-dashboard .dropzone{
  display:flex;
  gap:12px;
  align-items:center;
  padding:14px;
  border-radius:14px;
  border:1px dashed rgba(15,23,42,.18);
  background:#fff;
  cursor:pointer;
  transition:border-color .15s ease, background .15s ease;
}
.page-dashboard .dropzone:hover{
  border-color:color-mix(in srgb, var(--brand) 35%, rgba(15,23,42,.18));
  background:color-mix(in srgb, var(--brand) 4%, #fff);
}
.page-dashboard .dropzone.is-drag{
  border-color:color-mix(in srgb, var(--brand) 55%, rgba(15,23,42,.18));
  background:color-mix(in srgb, var(--brand) 6%, #fff);
}
.page-dashboard .dropzone__icon{
  width:38px;height:38px;
  border-radius:14px;
  display:grid;place-items:center;
  border:1px solid rgba(15,23,42,.10);
  background:#f7f7f8;
  color:color-mix(in srgb, var(--text) 82%, var(--muted));
}
.page-dashboard .dropzone__icon svg{width:18px;height:18px;}
.page-dashboard .dropzone__title{font-weight:750;letter-spacing:-.01em;}
.page-dashboard .dropzone__sub{font-size:.88rem;color:var(--muted);}

.page-dashboard .file-pill{
  margin-left:auto;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid rgba(15,23,42,.10);
  background:#fff;
  color:var(--muted);
  font-size:.88rem;
  max-width:42%;
  overflow:hidden;
  white-space:nowrap;
  text-overflow:ellipsis;
}

.page-dashboard .upload-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

/* Sidebar top bar for mobile drawer */
.page-dashboard .sidebar-top{
  display:none;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.page-dashboard .sidebar-top__title{
  font-weight:800;
  letter-spacing:-.02em;
  font-size:1rem;
}

.page-dashboard .icon-btn{
  width:36px;height:36px;
  border-radius:12px;
  border:1px solid rgba(15,23,42,.12);
  background:#fff;
  cursor:pointer;
}

/* Mobile tabs + drawer behavior */
.page-dashboard .dash-tabs{display:none;}

.page-dashboard .sidebar-overlay{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.35);
  z-index:79;
}

@media (max-width: 920px){
  .page-dashboard .dash-tabs{
    display:flex;
    width:min(1240px, calc(100% - 2 * var(--s5)));
    margin: 12px auto 0;
    gap:8px;
  }


  .page-dashboard .panel .avatar-card{
    border-radius: 0px;
    border: none;
    background: #fff;
    box-shadow: none;
  }

  .page-dashboard .layout {
    width: 100%;
  }

  .page-dashboard .dash-tab{
    flex:1;
    border:1px solid rgba(15,23,42,.12);
    background:#fff;
    color:color-mix(in srgb, var(--text) 86%, var(--muted));
    border-radius:14px;
    padding:10px 12px;
    font-weight:750;
    cursor:pointer;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:8px;
  }
  .page-dashboard .dash-tab.is-active{
    border-color:color-mix(in srgb, var(--brand) 26%, rgba(15,23,42,.12));
    box-shadow:0 0 0 3px color-mix(in srgb, var(--brand) 10%, transparent);
    color:var(--text);
  }
  .page-dashboard .dash-tab-badge{
    display:inline-grid;place-items:center;
    min-width:24px;height:20px;
    padding:0 8px;
    border-radius:999px;
    border:1px solid rgba(15,23,42,.10);
    background:#f7f7f8;
    font-size:.78rem;
    color:var(--muted);
    font-weight:800;
  }

  .page-dashboard .sidebar-top{display:flex;}

  .page-dashboard .sidebar{
    position:fixed;
    top:72px;
    left:0;
    bottom:0;
    width:min(86vw, 360px);
    transform:translateX(-105%);
    transition:transform .18s ease;
    z-index:80;
    border-radius:0 16px 16px 0;
  }

  .page-dashboard.sidebar-open .sidebar{transform:none;}
  .page-dashboard .sidebar-overlay{display:block;opacity:0;pointer-events:none;transition:opacity .18s ease;}
  .page-dashboard.sidebar-open .sidebar-overlay{opacity:1;pointer-events:auto;}

  .page-dashboard .file-pill{max-width:100%; margin-left:0; margin-top:10px;}
  .page-dashboard .dropzone{flex-wrap:wrap; align-items:flex-start;}
}

/* Keep header readable on small screens */
@media (max-width: 720px){
  .page-dashboard .dash-header{flex-direction:column; align-items:stretch;}
  .page-dashboard .dash-header__right{justify-content:flex-start;}
  .page-dashboard .dash-stats{width:100%; flex-wrap:wrap;}
  .page-dashboard .dash-stat{flex:1; min-width:110px;}

  .page-dashboard .dash-header__right {
    flex-wrap: wrap;
  } .page-dashboard .layout {
    width: 100%;
  } .page-dashboard .dash-tabs {
    margin: 15px auto;
  }
}

/* =========================================================
   Dashboard gutters (not too left, still full-width)
   ========================================================= */

body.page-dashboard{
  overflow-x: hidden; /* keep horizontal scrollbar away */

  /* responsive side padding */
  --dash-gutter: clamp(24px, 4vw, 72px);
}

/* Full-bleed dashboard but with nicer inset */
.page-dashboard .layout{
  width: min(var(--container), calc(100% - 2 * var(--s5)));
  max-width: none;
}

/* =========================================================
   PRICING PAGE
   ========================================================= */
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
  gap:var(--s6);
  margin-bottom:var(--s9);
  max-width:900px;
  margin-left:auto;
  margin-right:auto;
}

.pricing-grid.pricing-single{
  grid-template-columns:1fr;
  max-width:600px;
}

.pricing-card{
  position:relative;
  background:var(--surface);
  border:2px solid var(--border);
  border-radius:var(--r-xl);
  padding:var(--s7);
  display:flex;
  flex-direction:column;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.pricing-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:var(--border-2);
}

.pricing-card.featured{

  border-width:2px;
  box-shadow:var(--shadow-sm);
  background:linear-gradient(180deg, var(--surface) 0%, color-mix(in srgb, var(--tint) 15%, var(--surface)) 100%);
}

.pricing-card.featured:hover{
  box-shadow:var(--shadow-md);
  border-color:color-mix(in srgb, var(--brand) 80%, var(--border));
}

.pricing-badge{
  position:absolute;
  top:-12px;
  left:50%;
  transform:translateX(-50%);
  background:linear-gradient(180deg, var(--brand), var(--brand-2));
  color:white;
  padding:6px 16px;
  border-radius:999px;
  font-size:.85rem;
  font-weight:700;
  letter-spacing:-.01em;
  box-shadow:var(--shadow-sm);
}

.pricing-header{
  text-align:center;
  margin-bottom:var(--s6);
}

.pricing-header h3{
  font-size:1.5rem;
  font-weight:800;
  margin-bottom:var(--s3);
  color:var(--text);
}

.pricing-price{
  display:flex;
  align-items:baseline;
  justify-content:center;
  gap:var(--s2);
  margin-bottom:var(--s2);
}

.price-amount{
  font-size:clamp(2rem, 4vw, 3rem);
  font-weight:800;
  color:var(--text);
  line-height:1;
}

.price-period{
  font-size:1rem;
  color:var(--muted);
  font-weight:500;
}

.pricing-description{
  color:var(--muted);
  font-size:.95rem;
}

.pricing-features{
  list-style:none;
  flex:1;
  margin-bottom:var(--s6);
  display:flex;
  flex-direction:column;
  gap:var(--s3);
}

.feature-item{
  display:flex;
  align-items:flex-start;
  gap:var(--s3);
}

.feature-item.disabled{
  opacity:.5;
}

.feature-icon{
  flex-shrink:0;
  width:20px;
  height:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:color-mix(in srgb, var(--success) 12%, transparent);
  color:var(--success);
  border-radius:50%;
  font-weight:700;
  font-size:.85rem;
}

.feature-item.disabled .feature-icon{
  background:color-mix(in srgb, var(--muted) 12%, transparent);
  color:var(--muted);
}

.pricing-card .btn{
  margin-top:auto;
}

/* Comparison Table */
.pricing-comparison{
  margin:var(--s9) 0;
  max-width:800px;
  margin-left:auto;
  margin-right:auto;
}

.comparison-title{
  text-align:center;
  font-size:var(--h3);
  margin-bottom:var(--s6);
  color:var(--text);
}

.comparison-table{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow-xs);
}

.comparison-row{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  border-bottom:1px solid var(--border);
}

.comparison-row:last-child{
  border-bottom:none;
}

.comparison-row.header{
  background:color-mix(in srgb, var(--surface-2) 60%, transparent);
  font-weight:700;
}

.comparison-cell{
  padding:var(--s4) var(--s5);
  display:flex;
  align-items:center;
}

.comparison-row.header .comparison-cell{
  font-size:.95rem;
  color:var(--text);
}

.comparison-row:not(.header) .comparison-cell:first-child{
  color:var(--muted);
  font-weight:500;
}

.comparison-row:not(.header) .comparison-cell:not(:first-child){
  justify-content:center;
  font-weight:600;
}

/* Try-On Showcase Section */
.tryon-showcase{
  margin:var(--s9) 0;
  padding:var(--s7) 0;
  background:transparent;
}

.tryon-showcase-header{
  text-align:center;
  margin-bottom:var(--s6);
  max-width:700px;
  margin-left:auto;
  margin-right:auto;
}

.tryon-showcase-title{
  font-size:clamp(1.8rem, 4vw, 2.5rem);
  font-weight:800;
  color:var(--text);
  margin-bottom:var(--s3);
  line-height:1.2;
}

.tryon-showcase-subtitle{
  font-size:1.1rem;
  color:var(--muted);
  line-height:1.6;
}

.tryon-gallery{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:var(--s5);
  margin-bottom:var(--s6);
}

.tryon-gallery-item{
  display:flex;
  flex-direction:column;
}

.tryon-image-wrapper{
  position:relative;
  width:100%;
  aspect-ratio:9/16;
  border-radius:var(--r-sm);
  overflow:hidden;
  background:var(--surface-2);
  border:1px solid var(--border);
  transition:transform .2s ease, box-shadow .2s ease;
}

.tryon-image-wrapper:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-xs);
}

.tryon-image{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.tryon-badge{
  position:absolute;
  top:10px;
  right:10px;
  background:var(--surface);
  color:var(--text);
  padding:4px 10px;
  border-radius:999px;
  font-size:.75rem;
  font-weight:600;
  border:1px solid var(--border);
  z-index:2;
}

.tryon-caption{
  margin-top:var(--s3);
  text-align:center;
  color:var(--text);
  font-weight:500;
  font-size:.95rem;
}

.tryon-cta{
  text-align:center;
  padding-top:var(--s7);
  margin-top:var(--s7);
}

.tryon-cta-text{
  font-size:1.1rem;
  font-weight:600;
  color:var(--text);
  margin-bottom:var(--s5);
}

/* Responsive Try-On Showcase */
@media (max-width: 768px){
  .tryon-showcase{
    padding: 0;
  }
  
  .tryon-gallery{
    grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));
    gap:var(--s4);
  }
  
  .tryon-showcase-title{
    font-size:1.6rem;
  }
  
  .tryon-showcase-subtitle{
    font-size:1rem;
  }
  
  .tryon-cta{
    padding-top:var(--s6);
    margin-top:var(--s6);
  }
}

@media (max-width: 480px){
  .tryon-gallery{
    grid-template-columns:1fr;
  }
  
  .tryon-image-wrapper{
    aspect-ratio:3/4;
  }
}

/* Testimonials Section */
.pricing-testimonials{
  margin:var(--s9) 0;
  max-width:1000px;
  margin-left:auto;
  margin-right:auto;
}

.testimonials-title{
  text-align:center;
  font-size:var(--h3);
  margin-bottom:var(--s6);
  color:var(--text);
}

.testimonials-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:var(--s5);
  margin-top:var(--s6);
}

.testimonial-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:var(--s5);
  display:flex;
  flex-direction:column;
  transition:transform .2s ease, box-shadow .2s ease;
}

.testimonial-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-sm);
}

.testimonial-image{
  width:80px;
  height:80px;
  border-radius:50%;
  overflow:hidden;
  margin:0 auto var(--s4);
  border:3px solid var(--border);
  flex-shrink:0;
}

.testimonial-image img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.testimonial-content{
  flex:1;
  display:flex;
  flex-direction:column;
  text-align:center;
}

.testimonial-text{
  color:var(--text);
  font-style:italic;
  line-height:1.6;
  margin-bottom:var(--s4);
  flex:1;
}

.testimonial-author{
  margin-top:auto;
}

.testimonial-name{
  font-weight:700;
  color:var(--text);
  margin-bottom:var(--s1);
}

.testimonial-role{
  font-size:.9rem;
  color:var(--muted);
}

/* Responsive Testimonials */
@media (max-width: 768px){
  .testimonials-grid{
    grid-template-columns:1fr;
    gap:var(--s4);
  }

  .page-dashboard .layout{
    width: 100%;
  }
  
  .testimonial-card{
    padding:var(--s4);
  }
}

/* FAQ Section */
.pricing-faq{
  margin-top:var(--s9);
  max-width:700px;
  margin-left:auto;
  margin-right:auto;
}

.faq-title{
  text-align:center;
  font-size:var(--h3);
  margin-bottom:var(--s6);
  color:var(--text);
}

.faq-list{
  display:flex;
  flex-direction:column;
  gap:var(--s5);
}

.faq-item{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:var(--s5);
  transition:box-shadow .2s ease;
}

.faq-item:hover{
  box-shadow:var(--shadow-xs);
}

.faq-question{
  font-size:1.1rem;
  font-weight:700;
  margin-bottom:var(--s2);
  color:var(--text);
}

.faq-answer{
  color:var(--muted);
  line-height:1.6;
}

/* Responsive Pricing */
@media (max-width: 768px){
  .pricing-grid{
    grid-template-columns:1fr;
    gap:var(--s5);
  }
  
  .pricing-card{
    padding:var(--s6);
  }
  
  .comparison-row{
    grid-template-columns:1.5fr 1fr 1fr;
    font-size:.9rem;
  }
  
  .comparison-cell{
    padding:var(--s3) var(--s4);
  }
}

@media (max-width: 480px){
  .pricing-card{
    padding:var(--s5);
  }
  
  .price-amount{
    font-size:2rem;
  }
  
  .comparison-row{
    grid-template-columns:1.2fr 1fr 1fr;
    font-size:.85rem;
  }
  
  .comparison-cell{
    padding:var(--s2) var(--s3);
  }
}

/* Topbar aligned with dashboard gutter */
.page-dashboard .topbar .container{
  width: min(var(--container), calc(100% - 2 * var(--s5)));
  max-width: none;
}

.container.py-5.text-center {
  margin: 20px;
  margin-inline: auto;
  padding: clamp(16px, 3vw, 24px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(12px, 2.5vw, 20px);
  text-align: center;
  border: 1px solid var(--border);
  background: #ededed;
  border-radius: clamp(14px, 2.5vw, 20px);
}
