
:root{
  --bg:#fff8ef;
  --paper:rgba(255,255,255,.78);
  --paper-solid:#ffffff;
  --glass:rgba(255,255,255,.68);
  --warm:#fff2df;
  --cream:#fffaf3;
  --soft:#f3e3d1;
  --ink:#211812;
  --muted:#7a6a5e;
  --faint:#a39386;
  --line:rgba(33,24,18,.12);
  --line-strong:rgba(33,24,18,.18);
  --orange:#df6f12;
  --orange-2:#f2a13a;
  --orange-dark:#b95408;
  --brown:#241711;
  --green:#117a4d;
  --red:#b5322a;
  --shadow:0 24px 70px rgba(33,24,18,.11);
  --shadow-soft:0 14px 42px rgba(33,24,18,.08);
  --glow:0 18px 48px rgba(223,111,18,.22);
  --radius:28px;
  --radius-sm:18px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--ink);
  min-height:100vh;
  background:
    radial-gradient(circle at 12% -8%,rgba(223,111,18,.16),transparent 34rem),
    radial-gradient(circle at 92% 8%,rgba(242,161,58,.15),transparent 30rem),
    linear-gradient(180deg,#fffdf8 0%,#fff8ef 52%,#f6e7d6 100%);
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  -webkit-font-smoothing:antialiased;
}
body:before{
  content:"";
  position:fixed;
  inset:-20%;
  z-index:-1;
  background:
    radial-gradient(circle at 20% 20%,rgba(223,111,18,.08),transparent 22rem),
    radial-gradient(circle at 80% 30%,rgba(255,210,128,.11),transparent 26rem);
  animation:osoGlow 18s ease-in-out infinite alternate;
}
@keyframes osoGlow{from{transform:translate3d(-1.5%,0,0) scale(1)}to{transform:translate3d(1.5%,1%,0) scale(1.04)}}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button,input,select,textarea{font:inherit}
button:disabled{opacity:.6;cursor:not-allowed}
.container{width:min(1100px,calc(100% - 32px));margin:0 auto}
.header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,253,248,.84);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(22px);
}
.nav{min-height:78px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:4px;font-weight:950;letter-spacing:-.055em;font-size:1.75rem}
.brand img{
  width:88px!important;
  height:88px!important;
  object-fit:contain!important;
  border-radius:0!important;
  background:transparent!important;
  box-shadow:none!important;
}
.brand-word{display:inline-flex;letter-spacing:-.04em}
.brand-word .brand-oso{color:var(--orange)}
.nav-links{display:flex;align-items:center;gap:18px;color:var(--muted);font-weight:780;font-size:.94rem}
.nav-links a{transition:color .18s ease,transform .18s ease}
.nav-links a:hover{color:var(--orange-dark);transform:translateY(-1px)}
.menu-btn{display:none;border:0;background:transparent;font-size:1.75rem;color:var(--ink)}
.btn{
  min-height:46px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border-radius:999px;
  padding:0 20px;
  border:1px solid transparent;
  font-weight:920;
  cursor:pointer;
  text-align:center;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease,opacity .18s ease;
  will-change:transform;
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(1px) scale(.99)}
.btn.primary{background:linear-gradient(145deg,var(--orange),var(--orange-dark));color:#fff;box-shadow:var(--glow)}
.btn.secondary{background:rgba(255,255,255,.72);border-color:rgba(223,111,18,.24);color:var(--ink);backdrop-filter:blur(14px)}
.btn.dark{background:var(--brown);color:#fff}
.btn.ghost{background:transparent;border-color:var(--line);color:var(--muted)}
.btn.is-loading{pointer-events:none;opacity:.78}
.loading-inline{display:inline-flex;align-items:center;gap:8px}
.loading-inline:before{
  content:"";
  width:14px;height:14px;border-radius:50%;
  border:2px solid rgba(255,255,255,.5);
  border-top-color:#fff;
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.hero{padding:clamp(58px,10vw,124px) 0 clamp(52px,8vw,90px)}
.hero-grid{display:grid;grid-template-columns:1fr!important;max-width:800px}
.eyebrow,.mini{color:var(--orange-dark);text-transform:uppercase;letter-spacing:.14em;font-weight:950;font-size:.72rem}
.eyebrow{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(223,111,18,.08);border:1px solid rgba(223,111,18,.14)}
h1,h2,h3,p{margin-top:0}
h1{font-size:clamp(3.4rem,9.4vw,7.4rem);line-height:.88;letter-spacing:-.085em;margin:22px 0}
h2{font-size:clamp(2.15rem,5.6vw,4.6rem);line-height:.95;letter-spacing:-.065em;margin-bottom:14px}
h3{font-size:1.18rem;letter-spacing:-.03em;margin-bottom:8px}
p{color:var(--muted);line-height:1.62}
.lead{font-size:clamp(1.08rem,2.2vw,1.34rem);max-width:640px}
.orange{color:var(--orange)}
.actions,.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin:26px 0}
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chip{padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.65);border:1px solid var(--line);color:var(--muted);font-weight:760;font-size:.9rem;backdrop-filter:blur(10px)}
.card,.panel,.dashboard{
  background:var(--glass);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:26px;
  box-shadow:var(--shadow-soft);
  backdrop-filter:blur(20px);
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;
}
.card:hover,.dashboard:hover{box-shadow:var(--shadow)}
.section{padding:clamp(58px,8vw,92px) 0}
.section-head{max-width:720px;margin-bottom:32px}
.center{text-align:center;margin-left:auto;margin-right:auto}
.grid{display:grid;gap:18px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.icon{width:54px;height:54px;display:grid;place-items:center;border-radius:18px;background:rgba(223,111,18,.08);color:var(--orange);font-weight:950;margin:0 auto 15px}
.workflow .card{text-align:center}
.workflow .card p{font-size:.95rem}
.split{display:grid;grid-template-columns:.78fr 1.22fr;gap:18px;align-items:stretch}
.dark-panel{background:linear-gradient(145deg,#160f0b,#2a1a11);color:#fff}
.dark-panel p,.cta p{color:#e6d4c3}
.metrics{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin:18px 0 22px;
}
.metric{
  background:rgba(255,250,243,.74);
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px;
}
.metric small{display:block;color:var(--muted);font-weight:760;margin-bottom:8px}
.metric strong{display:block;font-size:clamp(2rem,4vw,3.3rem);letter-spacing:-.07em;line-height:.9}
.gallery-grid,.photos{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  gap:16px;
}
.gallery-grid.masonry{
  columns:3 220px;
  column-gap:16px;
  display:block;
}
.gallery-grid.masonry .gallery-item{
  break-inside:avoid;
  margin:0 0 16px;
}
.gallery-grid.masonry .gallery-item:nth-child(3n+1) img{aspect-ratio:4/5}
.gallery-grid.masonry .gallery-item:nth-child(3n+2) img{aspect-ratio:1}
.gallery-grid.masonry .gallery-item:nth-child(3n+3) img{aspect-ratio:5/4}
.gallery-hero{
  margin-bottom:18px;
  border-radius:32px;
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  background:#fff;
}
.gallery-hero img{width:100%;max-height:460px;object-fit:cover}
.gallery-hero-caption{padding:18px 20px;background:rgba(255,255,255,.8);backdrop-filter:blur(12px)}
.gallery-item,.photo-card{
  border-radius:20px;
  overflow:hidden;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:0 14px 36px rgba(31,23,18,.09);
  transform:translateZ(0);
}
.gallery-item img,.photo-card img{width:100%;aspect-ratio:1;object-fit:cover}
.photo-card{position:relative;transition:opacity .18s ease,transform .18s ease,filter .18s ease}
.photo-card.removing{opacity:0;transform:scale(.96);filter:blur(2px)}
.approve-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:9px}
.small{min-height:38px;border:1px solid var(--line);border-radius:13px;background:#fff;font-weight:900;color:var(--muted);cursor:pointer;transition:transform .15s ease,background .15s ease}
.small:hover{transform:translateY(-1px)}
.small.approve{color:var(--green);background:rgba(19,122,75,.08);border-color:rgba(19,122,75,.2)}
.small.hide{color:var(--red);background:rgba(181,50,42,.07);border-color:rgba(181,50,42,.18)}
.review-modal{
  position:fixed;inset:0;z-index:100;
  background:rgba(25,17,11,.78);
  backdrop-filter:blur(18px);
  display:none;
  align-items:center;
  justify-content:center;
  padding:20px;
}
.review-modal.open{display:flex}
.review-card{
  width:min(520px,100%);
  background:#fff;
  border-radius:30px;
  overflow:hidden;
  box-shadow:0 30px 100px rgba(0,0,0,.3);
}
.review-card img{width:100%;max-height:62vh;object-fit:cover}
.review-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:14px}
.price{font-size:2.9rem;font-weight:950;letter-spacing:-.06em;color:var(--ink);margin:10px 0}
.highlight{border-color:rgba(223,111,18,.32);box-shadow:0 30px 76px rgba(223,111,18,.14);transform:translateY(-6px)}
.clean{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:10px;color:var(--muted)}
.clean li{display:flex;gap:8px}
.cta{background:linear-gradient(145deg,#160f0b,#2a1a11);color:#fff;border-radius:32px;padding:clamp(32px,6vw,58px);box-shadow:var(--shadow)}
.footer{padding:34px 0;border-top:1px solid var(--line);color:var(--muted)}
.footer-row{display:flex;align-items:center;justify-content:space-between;gap:20px}
.footer-links{display:flex;gap:16px;flex-wrap:wrap}
.page-hero{padding:clamp(42px,7vw,72px) 0 18px}
.form-layout{display:grid;grid-template-columns:1fr .85fr;gap:20px;align-items:start}
.form{display:grid;gap:15px}
label{font-weight:900;color:var(--ink)}
.input,textarea,select{
  width:100%;
  border:1px solid var(--line);
  background:rgba(255,255,255,.84);
  border-radius:16px;
  padding:14px 15px;
  color:var(--ink);
  outline:none;
  min-height:50px;
  transition:border-color .16s ease,box-shadow .16s ease,background .16s ease;
}
.input:focus,textarea:focus,select:focus{border-color:rgba(223,111,18,.45);box-shadow:0 0 0 4px rgba(223,111,18,.08);background:#fff}
textarea{min-height:110px;resize:vertical}
.upload-box{
  display:block;
  border:1px dashed rgba(223,111,18,.35);
  background:rgba(223,111,18,.05);
  border-radius:22px;
  padding:28px;
  text-align:center;
  cursor:pointer;
  transition:transform .18s ease,border-color .18s ease,background .18s ease;
}
.upload-box:hover{transform:translateY(-1px);border-color:rgba(223,111,18,.55);background:rgba(223,111,18,.075)}
.upload-box input{display:none}
.notify-card{margin-top:16px;background:rgba(255,255,255,.72);border:1px solid var(--line);border-radius:22px;padding:18px}
.radio-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:12px 0}
.radio-pill{border:1px solid var(--line);border-radius:999px;padding:10px;text-align:center;font-weight:850;color:var(--muted);cursor:pointer;background:#fff}
.radio-pill input{display:none}
.radio-pill:has(input:checked){border-color:rgba(223,111,18,.44);background:rgba(223,111,18,.08);color:var(--orange-dark)}
.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:12px;margin-top:18px}
.preview{
  border-radius:18px;
  overflow:hidden;
  background:#fff;
  border:1px solid var(--line);
  position:relative;
}
.preview img{width:100%;aspect-ratio:1;object-fit:cover}
.preview span{display:block;padding:8px;color:var(--muted);font-size:.74rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.preview-status{
  position:absolute;
  top:8px;right:8px;
  min-width:28px;height:28px;
  display:grid;place-items:center;
  border-radius:999px;
  background:rgba(33,24,18,.72);
  color:#fff;
  font-size:.78rem;
  font-weight:900;
}
.preview-status.done{background:var(--green)}
.preview-status.error{background:var(--red)}
.progress-list{display:grid;gap:10px;margin:16px 0}
.progress-row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px;
  align-items:center;
  padding:12px 14px;
  border-radius:16px;
  background:rgba(255,255,255,.72);
  border:1px solid var(--line);
}
.progress-row strong{font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.progress-state{font-weight:900;color:var(--orange-dark)}
.progress-state.done{color:var(--green)}
.progress-state.error{color:var(--red)}
.notice{padding:13px 15px;border-radius:16px;background:rgba(223,111,18,.08);border:1px solid rgba(223,111,18,.16);color:var(--ink)}
.status{padding:12px 14px;border-radius:16px;background:#fff;border:1px solid var(--line);color:var(--muted)}
.status.good{background:rgba(19,122,75,.08);border-color:rgba(19,122,75,.2);color:var(--green)}
.status.bad{background:rgba(181,50,42,.07);border-color:rgba(181,50,42,.18);color:var(--red)}
.hidden{display:none!important}
.empty{padding:30px;border:1px dashed var(--line);border-radius:20px;text-align:center;color:var(--muted);grid-column:1/-1}
.qr-box{width:230px;max-width:100%;aspect-ratio:1;background:#fff;border:1px solid var(--line);border-radius:24px;display:grid;place-items:center;margin:18px 0}
.qr-box img{width:198px;height:198px}
.copy-row{display:grid;grid-template-columns:1fr auto;gap:8px}
.app-shell{display:grid;grid-template-columns:230px 1fr;gap:18px}
.side{background:linear-gradient(145deg,#160f0b,#2a1a11);border-radius:var(--radius);padding:18px;color:#fff;min-height:540px;box-shadow:var(--shadow)}
.side .brand{font-size:1.12rem;margin-bottom:24px;color:#fff}
.side .brand img{width:62px!important;height:62px!important}
.side a{display:block;padding:12px;border-radius:15px;color:#e6d4c3;transition:background .16s ease,color .16s ease,transform .16s ease}
.side a:hover,.side a.active{background:rgba(255,255,255,.09);color:#fff;transform:translateX(2px)}
.toggle-row{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:16px 0;border-bottom:1px solid var(--line)}
.switch{position:relative;width:56px;height:32px;flex:0 0 auto}
.switch input{display:none}
.slider{position:absolute;inset:0;background:#ddd;border-radius:999px;cursor:pointer;transition:background .16s ease}
.slider:before{content:"";position:absolute;width:26px;height:26px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 2px 10px rgba(0,0,0,.16)}
.switch input:checked+.slider{background:var(--orange)}
.switch input:checked+.slider:before{transform:translateX(24px)}
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.settings-card{background:rgba(255,255,255,.72);border:1px solid var(--line);border-radius:22px;padding:20px}
.danger-zone{border-color:rgba(181,50,42,.22);background:rgba(181,50,42,.04)}
@media(max-width:900px){
  .hero-grid,.split,.form-layout,.app-shell,.settings-grid{grid-template-columns:1fr}
  .side{min-height:auto}
  .grid-4,.grid-3,.grid-2{grid-template-columns:repeat(2,1fr)}
  .metrics{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .container{width:min(100% - 28px,1100px)}
  .nav{min-height:68px}
  .menu-btn{display:block}
  .nav-links{display:none;position:absolute;top:70px;left:14px;right:14px;background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:22px;padding:14px;box-shadow:var(--shadow);backdrop-filter:blur(18px)}
  .nav-links.open{display:grid}
  .brand{font-size:1.38rem}
  .brand img{width:64px!important;height:64px!important}
  .page-hero{padding:34px 0 12px}
  h1{font-size:clamp(2.8rem,14vw,4.4rem);letter-spacing:-.07em;line-height:.9}
  h2{font-size:clamp(2rem,10vw,3rem)}
  .lead{font-size:1rem}
  .hero-actions .btn,.actions .btn{width:100%}
  .grid-4,.grid-3,.grid-2{grid-template-columns:1fr}
  .card,.dashboard{padding:18px}
  .gallery-grid,.photos{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
  .gallery-grid.masonry{columns:2 150px;column-gap:12px}
  .footer-row{flex-direction:column;align-items:flex-start}
  .copy-row{grid-template-columns:1fr}
  .upload-box{padding:24px 16px}
  .radio-row{grid-template-columns:1fr}
  .metric{padding:14px}
  .metric strong{font-size:2.35rem}
  .side{border-radius:22px}
}


/* Business foundation additions */
.event-list{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:18px;
}
.event-card{
  position:relative;
  overflow:hidden;
}
.event-card:before{
  content:"";
  position:absolute;
  inset:auto -20% -40% 40%;
  height:120px;
  background:radial-gradient(circle,rgba(223,111,18,.18),transparent 70%);
  pointer-events:none;
}
.event-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:14px 0;
}
.badge{
  display:inline-flex;
  align-items:center;
  border:1px solid var(--line);
  border-radius:999px;
  padding:7px 10px;
  background:rgba(255,255,255,.66);
  color:var(--muted);
  font-size:.82rem;
  font-weight:850;
}
.badge.good{color:var(--green);background:rgba(19,122,75,.08);border-color:rgba(19,122,75,.18)}
.badge.warn{color:var(--orange-dark);background:rgba(223,111,18,.08);border-color:rgba(223,111,18,.18)}
.payment-box{
  display:grid;
  gap:14px;
}
.payment-summary{
  background:linear-gradient(145deg,#160f0b,#2a1a11);
  color:#fff;
  border-radius:26px;
  padding:24px;
  box-shadow:var(--shadow);
}
.payment-summary p{color:#e6d4c3}
.payment-total{
  font-size:3.1rem;
  font-weight:950;
  letter-spacing:-.07em;
  line-height:1;
  margin:12px 0;
}
#card-container{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:16px;
  min-height:96px;
}
@media(max-width:640px){
  .event-list{grid-template-columns:1fr}
}


/* Senior performance polish */
.performance-note{
  margin-top:12px;
  color:var(--muted);
  font-size:.92rem;
}
.progress-row{
  position:relative;
  overflow:hidden;
}
.progress-row .progress-bar{
  grid-column:1 / -1;
  height:7px;
  background:rgba(33,24,18,.08);
  border-radius:999px;
  overflow:hidden;
  margin-top:8px;
}
.progress-row .progress-fill{
  height:100%;
  width:0%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--orange),var(--orange-2));
  transition:width .22s ease;
}
.progress-state.preparing{color:var(--orange-dark)}
.progress-state.uploading{color:var(--orange-dark)}
.progress-state.done{color:var(--green)}
.progress-state.error{color:var(--red)}
.publish-banner{
  display:none;
  margin:16px 0;
  border-radius:20px;
  padding:18px;
  background:rgba(19,122,75,.08);
  border:1px solid rgba(19,122,75,.18);
  color:var(--green);
}
.publish-banner.show{display:block}
.publish-banner h3{margin-bottom:4px;color:var(--green)}
.soft-divider{
  height:1px;
  background:var(--line);
  margin:22px 0;
}
.photo-card.approved-now{
  opacity:0;
  transform:translateY(8px) scale(.96);
}
.instant-label{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight:900;
}
.instant-label:before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--green);
  box-shadow:0 0 0 6px rgba(19,122,75,.1);
}
@media(max-width:640px){
  .progress-row{
    grid-template-columns:1fr;
  }
  .progress-state{
    justify-self:start;
  }
}


/* UX + trust polish */
.nav-actions{
  display:flex;
  align-items:center;
  gap:9px;
  margin-left:auto;
}
.auth-pill,.lang-btn{
  min-height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.72);
  color:var(--ink);
  padding:0 13px;
  font-size:.83rem;
  font-weight:920;
  backdrop-filter:blur(14px);
  transition:transform .16s ease,background .16s ease,border-color .16s ease;
}
.auth-pill:hover,.lang-btn:hover{transform:translateY(-1px);border-color:rgba(223,111,18,.24)}
.lang-btn{cursor:pointer;color:var(--orange-dark)}
.auth-pill.signed-in{
  color:var(--green);
  border-color:rgba(19,122,75,.2);
  background:rgba(19,122,75,.08);
}
.auth-pill.guest{
  color:var(--muted);
}
.brand img{
  min-width:76px;
  min-height:76px;
  background:transparent!important;
}
.brand img:not([src]),.brand img[src=""]{visibility:hidden}
.hero-proof{
  display:flex;
  flex-wrap:wrap;
  gap:11px;
  margin:24px 0 0;
  color:var(--muted);
  font-weight:780;
}
.hero-proof span{
  display:inline-flex;
  align-items:center;
  gap:7px;
}
.hero-proof span:before{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--orange);
  box-shadow:0 0 0 5px rgba(223,111,18,.1);
}
.explainer{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  align-items:stretch;
}
.explainer-card{
  min-height:100%;
}
.footer{
  padding:0;
  border-top:1px solid var(--line);
  background:rgba(255,253,248,.72);
  backdrop-filter:blur(18px);
}
.footer-main{
  padding:42px 0 28px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.35fr repeat(3,1fr);
  gap:28px;
  align-items:start;
}
.footer-brand p{
  max-width:360px;
  margin-top:12px;
}
.footer-col h3{
  font-size:.88rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--orange-dark);
  margin-bottom:12px;
}
.footer-col a,.footer-col span{
  display:block;
  color:var(--muted);
  margin:9px 0;
  font-weight:720;
  font-size:.95rem;
}
.footer-bottom{
  border-top:1px solid var(--line);
  padding:18px 0;
}
.footer-bottom-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  color:var(--muted);
  font-size:.9rem;
}
.helper-text{
  color:var(--muted);
  font-size:.92rem;
}
.account-strip{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:18px;
}
.account-strip .status{
  margin:0;
}
@media(max-width:900px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .explainer{grid-template-columns:1fr}
}
@media(max-width:640px){
  .nav-actions{gap:7px}
  .auth-pill{
    max-width:96px;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    padding:0 10px;
    font-size:.78rem;
  }
  .lang-btn{
    min-width:40px;
    padding:0 10px;
  }
  .brand img{
    min-width:56px;
    min-height:56px;
  }
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom-row{flex-direction:column;align-items:flex-start}
}


/* Revamp 2: Trust, Accounts, Revenue */
.mobile-primary-action{
  min-height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  border:1px solid rgba(223,111,18,.2);
  background:rgba(223,111,18,.08);
  color:var(--orange-dark);
  padding:0 13px;
  font-size:.83rem;
  font-weight:950;
  backdrop-filter:blur(14px);
}
.verified-badge{
  display:inline-flex;
  align-items:center;
  gap:7px;
  border-radius:999px;
  padding:8px 11px;
  border:1px solid rgba(19,122,75,.18);
  background:rgba(19,122,75,.08);
  color:var(--green);
  font-weight:920;
  font-size:.86rem;
}
.unverified-badge{
  display:inline-flex;
  align-items:center;
  gap:7px;
  border-radius:999px;
  padding:8px 11px;
  border:1px solid rgba(223,111,18,.2);
  background:rgba(223,111,18,.08);
  color:var(--orange-dark);
  font-weight:920;
  font-size:.86rem;
}
.lock-card{
  max-width:740px;
  margin:0 auto;
  text-align:center;
}
.lock-icon{
  width:74px;
  height:74px;
  border-radius:26px;
  display:grid;
  place-items:center;
  margin:0 auto 18px;
  background:rgba(223,111,18,.08);
  color:var(--orange-dark);
  font-size:2rem;
  box-shadow:var(--glow);
}
.account-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:18px;
  align-items:start;
}
.account-card strong{
  display:block;
  font-size:1.45rem;
  letter-spacing:-.04em;
}
.checklist{
  display:grid;
  gap:12px;
}
.check-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(255,255,255,.72);
  border:1px solid var(--line);
}
.check-left{
  display:flex;
  align-items:center;
  gap:12px;
}
.check-dot{
  width:28px;
  height:28px;
  border-radius:999px;
  display:grid;
  place-items:center;
  border:1px solid var(--line);
  background:#fff;
  color:var(--muted);
  font-weight:950;
}
.check-item.done .check-dot{
  background:var(--green);
  border-color:var(--green);
  color:#fff;
}
.check-item.done{
  border-color:rgba(19,122,75,.18);
  background:rgba(19,122,75,.06);
}
.event-stats-mini{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin:14px 0;
}
.event-stat-mini{
  background:rgba(255,255,255,.66);
  border:1px solid var(--line);
  border-radius:15px;
  padding:10px;
}
.event-stat-mini small{
  display:block;
  color:var(--muted);
  font-size:.74rem;
  font-weight:800;
}
.event-stat-mini strong{
  display:block;
  font-size:1.2rem;
  line-height:1;
  margin-top:4px;
}
.billing-row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px;
  align-items:center;
  padding:16px;
  border-radius:18px;
  background:rgba(255,255,255,.72);
  border:1px solid var(--line);
}
.key-table{
  display:grid;
  gap:10px;
}
.key-row{
  display:grid;
  grid-template-columns:230px 1fr;
  gap:10px;
  padding:12px;
  border-radius:16px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.65);
}
.key-row code{
  white-space:normal;
  word-break:break-word;
}
@media(max-width:900px){
  .account-grid{grid-template-columns:1fr}
  .key-row{grid-template-columns:1fr}
}
@media(max-width:640px){
  .mobile-primary-action{
    padding:0 11px;
    font-size:.78rem;
  }
  .nav-actions .auth-pill{
    display:none;
  }
  .event-stats-mini{
    grid-template-columns:repeat(3,1fr);
  }
}


/* Revamp 3: guardrails + upload carousel */
.upload-carousel{
  margin-top:18px;
  display:grid;
  gap:14px;
}
.carousel-stage{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.72);
  box-shadow:var(--shadow-soft);
}
.carousel-stage img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  background:#fff;
}
.carousel-overlay{
  position:absolute;
  left:14px;
  right:14px;
  bottom:14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  color:#fff;
}
.carousel-pill{
  border-radius:999px;
  background:rgba(33,24,18,.72);
  backdrop-filter:blur(14px);
  padding:9px 12px;
  font-weight:950;
  font-size:.86rem;
}
.carousel-controls{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  pointer-events:none;
  padding:0 10px;
}
.carousel-btn{
  pointer-events:auto;
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.32);
  background:rgba(33,24,18,.55);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:1.35rem;
  cursor:pointer;
  backdrop-filter:blur(14px);
}
.thumb-strip{
  display:flex;
  gap:10px;
  overflow-x:auto;
  padding:3px 2px 8px;
  scroll-snap-type:x proximity;
}
.thumb{
  flex:0 0 74px;
  border-radius:16px;
  overflow:hidden;
  border:2px solid transparent;
  background:#fff;
  position:relative;
  cursor:pointer;
  scroll-snap-align:start;
}
.thumb.active{
  border-color:var(--orange);
  box-shadow:0 0 0 4px rgba(223,111,18,.12);
}
.thumb img{
  width:100%;
  aspect-ratio:1;
  object-fit:cover;
}
.thumb-state{
  position:absolute;
  top:5px;
  right:5px;
  width:23px;
  height:23px;
  border-radius:999px;
  background:rgba(33,24,18,.68);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:.74rem;
  font-weight:950;
}
.thumb-state.done{background:var(--green)}
.thumb-state.error{background:var(--red)}
.carousel-empty{
  padding:34px;
  text-align:center;
  border:1px dashed var(--line);
  border-radius:24px;
  color:var(--muted);
  background:rgba(255,255,255,.45);
}
.guardrail-card{
  border-color:rgba(223,111,18,.18);
  background:rgba(223,111,18,.045);
}
.email-preview{
  border:1px solid var(--line);
  border-radius:26px;
  background:#fff;
  overflow:hidden;
  box-shadow:var(--shadow-soft);
}
.email-preview-header{
  background:linear-gradient(145deg,#160f0b,#2a1a11);
  color:#fff;
  padding:22px;
}
.email-preview-body{
  padding:22px;
}
.auth-action-result{
  max-width:760px;
  margin:0 auto;
  text-align:center;
}
.turnstile-slot{
  min-height:1px;
}
@media(max-width:640px){
  .carousel-stage img{
    aspect-ratio:1;
  }
  .carousel-overlay{
    align-items:flex-end;
  }
  .carousel-pill{
    font-size:.78rem;
  }
  .thumb{
    flex-basis:66px;
  }
}

/* Shared shell helpers */
[data-site-header], [data-site-footer]{
  display:block;
}
.no-shell-fouc [data-site-header]{
  min-height:78px;
}
@media(max-width:640px){
  .no-shell-fouc [data-site-header]{
    min-height:68px;
  }
}


/* Tighten logo + wordmark spacing */
.brand{
  gap:10px !important;
}
.brand-word{
  margin-left:-10px;
}
.header .brand-word{
  margin-left:-12px;
}
.footer .brand-word{
  margin-left:-10px;
}
@media(max-width:640px){
  .brand{
    gap:6px !important;
  }
  .brand-word{
    margin-left:-8px;
  }
  .header .brand-word{
    margin-left:-10px;
  }
}
/* Make OsoSpecial wordmark bigger in the header/footer */
.brand{
  font-size:2.15rem !important;
  gap:10px !important;
}

.header .brand{
  font-size:2.25rem !important;
}

.footer .brand{
  font-size:2rem !important;
}

.brand-word{
  margin-left:0 !important;
}

@media(max-width:640px){
  .brand{
    font-size:1.55rem !important;
    gap:7px !important;
  }

  .header .brand{
    font-size:1.6rem !important;
  }

  .footer .brand{
    font-size:1.45rem !important;
  }
}


/* OsoSpecial i18n foundation */
.translate-btn,
.lang-btn.translate-btn{
  min-height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border-radius:999px;
  border:1px solid rgba(223,111,18,.34);
  background:linear-gradient(145deg,rgba(255,255,255,.96),rgba(255,242,223,.92));
  color:var(--orange-dark);
  padding:0 15px;
  font-size:.9rem;
  font-weight:950;
  letter-spacing:-.01em;
  box-shadow:0 12px 30px rgba(223,111,18,.13);
  cursor:pointer;
  backdrop-filter:blur(14px);
  transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease;
}
.translate-btn:hover,
.lang-btn.translate-btn:hover{
  transform:translateY(-1px);
  border-color:rgba(223,111,18,.52);
  box-shadow:0 16px 38px rgba(223,111,18,.18);
}
.translate-btn:before,
.lang-btn.translate-btn:before{
  content:"🌐";
  font-size:1rem;
  line-height:1;
}
html[lang="es"] .translate-btn,
html[lang="es"] .lang-btn.translate-btn{
  background:linear-gradient(145deg,var(--orange),var(--orange-dark));
  color:#fff;
  border-color:rgba(223,111,18,.58);
  box-shadow:var(--glow);
}
.translate-status{
  position:fixed;
  left:50%;
  bottom:18px;
  z-index:200;
  transform:translateX(-50%) translateY(18px);
  opacity:0;
  pointer-events:none;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(33,24,18,.86);
  color:#fff;
  font-weight:900;
  font-size:.86rem;
  box-shadow:0 20px 60px rgba(0,0,0,.22);
  backdrop-filter:blur(14px);
  transition:opacity .2s ease,transform .2s ease;
}
.translate-status.show{
  opacity:1;
  transform:translateX(-50%) translateY(0);
}
[data-i18n-cloak]{
  visibility:hidden;
}
html.i18n-ready [data-i18n-cloak]{
  visibility:visible;
}
@media(max-width:640px){
  .translate-btn,
  .lang-btn.translate-btn{
    min-height:40px;
    padding:0 11px;
    font-size:.78rem;
    gap:6px;
  }
  .translate-btn .translate-long{
    display:none;
  }
}


/* Fixed header: stays put while scrolling */
:root{
  --header-height:96px;
  --header-height-mobile:76px;
}

body{
  padding-top:var(--header-height);
}

.header{
  position:fixed !important;
  top:0;
  left:0;
  right:0;
  width:100%;
  z-index:999;
  transform:translateZ(0);
  -webkit-transform:translateZ(0);
  box-shadow:0 10px 32px rgba(33,24,18,.07);
}

.nav{
  min-height:var(--header-height);
}

html{
  scroll-padding-top:calc(var(--header-height) + 18px);
}

.no-shell-fouc [data-site-header]{
  min-height:0 !important;
}

@media(max-width:640px){
  body{
    padding-top:var(--header-height-mobile);
  }

  .nav{
    min-height:var(--header-height-mobile);
  }

  .header .brand img{
    width:64px !important;
    height:64px !important;
    min-width:64px !important;
    min-height:64px !important;
  }

  html{
    scroll-padding-top:calc(var(--header-height-mobile) + 16px);
  }

  .nav-links{
    position:fixed;
    top:calc(var(--header-height-mobile) + 8px);
    left:14px;
    right:14px;
  }
}


/* Stable translation and fixed header final overrides */
.translate-btn,
.lang-btn.translate-btn{
  min-height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border-radius:999px;
  border:1px solid rgba(223,111,18,.34);
  background:linear-gradient(145deg,rgba(255,255,255,.96),rgba(255,242,223,.92));
  color:var(--orange-dark);
  padding:0 15px;
  font-size:.9rem;
  font-weight:950;
  letter-spacing:-.01em;
  box-shadow:0 12px 30px rgba(223,111,18,.13);
  cursor:pointer;
  backdrop-filter:blur(14px);
}
.translate-btn:before,
.lang-btn.translate-btn:before{
  content:"🌐";
  font-size:1rem;
}
html[lang="es"] .translate-btn,
html[lang="es"] .lang-btn.translate-btn{
  background:linear-gradient(145deg,var(--orange),var(--orange-dark));
  color:#fff;
  border-color:rgba(223,111,18,.58);
  box-shadow:var(--glow);
}
.translate-status{
  position:fixed;
  left:50%;
  bottom:18px;
  z-index:200;
  transform:translateX(-50%) translateY(18px);
  opacity:0;
  pointer-events:none;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(33,24,18,.86);
  color:#fff;
  font-weight:900;
  font-size:.86rem;
  box-shadow:0 20px 60px rgba(0,0,0,.22);
  backdrop-filter:blur(14px);
  transition:opacity .2s ease,transform .2s ease;
}
.translate-status.show{
  opacity:1;
  transform:translateX(-50%) translateY(0);
}
:root{
  --header-height:96px;
  --header-height-mobile:76px;
}
body{
  padding-top:var(--header-height);
}
.header{
  position:fixed !important;
  top:0;
  left:0;
  right:0;
  width:100%;
  z-index:999;
  transform:translateZ(0);
  -webkit-transform:translateZ(0);
  box-shadow:0 10px 32px rgba(33,24,18,.07);
}
.nav{
  min-height:var(--header-height);
}
html{
  scroll-padding-top:calc(var(--header-height) + 18px);
}
.no-shell-fouc [data-site-header]{
  min-height:0 !important;
}
@media(max-width:640px){
  body{
    padding-top:var(--header-height-mobile);
  }
  .nav{
    min-height:var(--header-height-mobile);
  }
  .header .brand img{
    width:64px !important;
    height:64px !important;
    min-width:64px !important;
    min-height:64px !important;
  }
  html{
    scroll-padding-top:calc(var(--header-height-mobile) + 16px);
  }
  .nav-links{
    position:fixed;
    top:calc(var(--header-height-mobile) + 8px);
    left:14px;
    right:14px;
  }
  .translate-btn .translate-long{
    display:none;
  }
}


/* Guest upload progress polish */
.clean-progress-row{
  grid-template-columns:1fr auto;
  gap:8px 12px;
}
.clean-progress-row strong{
  max-width:100%;
}
.progress-detail{
  grid-column:1 / -1;
  color:var(--muted);
  font-size:.84rem;
  min-height:1em;
}
.clean-progress-row .progress-bar{
  margin-top:2px;
}


/* Guest thank-you page */
.thank-you-hero{
  min-height:calc(100vh - var(--header-height));
  display:grid;
  align-items:center;
}
.thank-you-card{
  max-width:820px;
  margin:0 auto;
  text-align:center;
}
.success-orb{
  width:78px;
  height:78px;
  border-radius:999px;
  display:grid;
  place-items:center;
  margin:0 auto 18px;
  background:rgba(19,122,75,.1);
  color:var(--green);
  font-size:2.1rem;
  font-weight:950;
  border:1px solid rgba(19,122,75,.18);
}
.thank-you-actions{
  justify-content:center;
  margin-top:22px;
}

/* Host dashboard swipe review */
.swipe-photo-card{
  touch-action:pan-y;
  user-select:none;
  will-change:transform;
}
.swipe-photo-card:before{
  content:"";
  position:absolute;
  inset:0;
  opacity:0;
  pointer-events:none;
  transition:opacity .14s ease;
  z-index:1;
}
.swipe-photo-card.swiping-approve:before{
  opacity:1;
  background:linear-gradient(90deg,rgba(19,122,75,.28),rgba(19,122,75,0));
}
.swipe-photo-card.swiping-hide:before{
  opacity:1;
  background:linear-gradient(270deg,rgba(181,50,42,.28),rgba(181,50,42,0));
}
.swipe-direction{
  position:absolute;
  top:12px;
  z-index:2;
  border-radius:999px;
  padding:9px 12px;
  color:#fff;
  font-weight:950;
  font-size:.86rem;
  opacity:0;
  transform:scale(.94);
  transition:opacity .14s ease,transform .14s ease;
  box-shadow:0 12px 28px rgba(0,0,0,.18);
}
.approve-direction{
  left:12px;
  background:var(--green);
}
.hide-direction{
  right:12px;
  background:var(--red);
}
.swipe-photo-card.swiping-approve .approve-direction,
.swipe-photo-card.swiping-hide .hide-direction{
  opacity:1;
  transform:scale(1);
}
.swipe-help{
  display:flex;
  justify-content:space-between;
  gap:8px;
  padding:8px 10px 0;
  color:var(--muted);
  font-size:.78rem;
  font-weight:900;
}
.swipe-help span:first-child{color:var(--red)}
.swipe-help span:last-child{color:var(--green)}
@media(max-width:640px){
  .swipe-help{
    font-size:.74rem;
  }
}


/* True one-photo review deck */
.review-deck-shell{
  display:block !important;
  max-width:760px;
  margin:0 auto;
}
.review-deck-card{
  position:relative;
  border:1px solid var(--line);
  border-radius:34px;
  background:rgba(255,255,255,.9);
  box-shadow:var(--shadow-soft);
  padding:14px;
  overflow:hidden;
  touch-action:pan-y;
}
.deck-topbar{
  display:flex;
  justify-content:space-between;
  gap:12px;
  color:var(--muted);
  font-weight:900;
  font-size:.88rem;
  padding:6px 6px 12px;
}
.deck-photo-wrap{
  position:relative;
  border-radius:28px;
  overflow:hidden;
  background:#120b07;
  transition:transform .16s ease;
  will-change:transform;
  min-height:420px;
}
.deck-photo-wrap img{
  width:100%;
  height:min(64vh,680px);
  min-height:420px;
  display:block;
  object-fit:contain;
  background:#120b07;
}
.deck-instructions{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding:14px 6px 4px;
  font-weight:950;
  font-size:.9rem;
}
.hide-hint{color:var(--red)}
.keep-hint{color:var(--green)}
.deck-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:12px;
}
.deck-progress{
  height:8px;
  overflow:hidden;
  border-radius:999px;
  background:rgba(223,111,18,.12);
  margin-top:14px;
}
.deck-progress div{
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--orange),var(--orange-dark));
  transition:width .2s ease;
}
.review-complete-card{
  text-align:center;
  border:1px solid var(--line);
  border-radius:34px;
  background:rgba(255,255,255,.9);
  box-shadow:var(--shadow-soft);
  padding:42px 24px;
}
.review-deck-card .swipe-direction{
  top:18px;
}
.review-deck-card.swiping-approve .deck-photo-wrap{
  box-shadow:0 0 0 6px rgba(19,122,75,.16);
}
.review-deck-card.swiping-hide .deck-photo-wrap{
  box-shadow:0 0 0 6px rgba(181,50,42,.16);
}
.fly-approve .deck-photo-wrap{
  transform:translateX(125%) rotate(9deg)!important;
  opacity:.4;
}
.fly-hide .deck-photo-wrap{
  transform:translateX(-125%) rotate(-9deg)!important;
  opacity:.4;
}
.review-modal{
  position:fixed;
  inset:0;
  z-index:2000;
  background:rgba(18,11,7,.82);
  display:grid;
  place-items:center;
  padding:18px;
}
.review-modal.hidden{display:none}
.review-panel{
  position:relative;
  width:min(920px,96vw);
  max-height:92vh;
  border-radius:30px;
  background:#fff;
  padding:14px;
  box-shadow:0 30px 90px rgba(0,0,0,.34);
}
.review-panel img{
  width:100%;
  max-height:72vh;
  object-fit:contain;
  display:block;
  border-radius:22px;
  background:#120b07;
}
.review-close{
  position:absolute;
  top:22px;
  right:22px;
  z-index:3;
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.45);
  background:rgba(18,11,7,.58);
  color:#fff;
  font-size:1.7rem;
  line-height:1;
}
@media(max-width:640px){
  .review-deck-card{
    border-radius:28px;
    padding:10px;
  }
  .deck-photo-wrap{
    min-height:360px;
    border-radius:24px;
  }
  .deck-photo-wrap img{
    height:56vh;
    min-height:360px;
  }
  .deck-actions{
    gap:10px;
  }
  .deck-actions .btn{
    padding-left:12px;
    padding-right:12px;
  }
  .deck-instructions{
    font-size:.78rem;
  }
}


/* Dashboard swipe deck hard fix */
#photoGrid.review-deck-shell{
  display:block!important;
  max-width:760px;
  margin:0 auto;
}
.review-deck-card{
  position:relative!important;
  border:1px solid var(--line);
  border-radius:34px;
  background:rgba(255,255,255,.94);
  box-shadow:var(--shadow-soft);
  padding:14px;
  overflow:hidden;
  touch-action:pan-y;
}
.deck-photo-wrap{
  position:relative;
  display:grid;
  place-items:center;
  border-radius:28px;
  overflow:hidden;
  background:#120b07;
  transition:transform .16s ease, box-shadow .16s ease, opacity .16s ease;
  will-change:transform;
  min-height:420px;
}
.deck-photo-wrap img{
  width:100%;
  height:min(64vh,680px);
  min-height:420px;
  display:block;
  object-fit:contain;
  background:#120b07;
}
.deck-instructions{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:8px;
  padding:14px 6px 4px;
  font-weight:950;
  font-size:.86rem;
}
.hide-hint{text-align:left;color:var(--red)}
.zoom-hint{text-align:center;color:var(--muted);font-size:.78rem}
.keep-hint{text-align:right;color:var(--green)}
.deck-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:12px;
}
.review-deck-card .swipe-direction{
  top:18px;
  z-index:4;
}
.review-deck-card.swiping-approve .deck-photo-wrap{
  box-shadow:0 0 0 7px rgba(19,122,75,.18);
}
.review-deck-card.swiping-hide .deck-photo-wrap{
  box-shadow:0 0 0 7px rgba(181,50,42,.18);
}
.review-deck-card.swiping-approve .approve-direction,
.review-deck-card.swiping-hide .hide-direction{
  opacity:1;
  transform:scale(1);
}
.fly-approve .deck-photo-wrap{
  transform:translateX(125%) rotate(9deg)!important;
  opacity:.35;
}
.fly-hide .deck-photo-wrap{
  transform:translateX(-125%) rotate(-9deg)!important;
  opacity:.35;
}
.oso-preview-modal{
  position:fixed;
  inset:0;
  z-index:3000;
  background:rgba(18,11,7,.92);
  display:grid;
  place-items:center;
  padding:18px;
}
.oso-preview-modal.hidden{
  display:none!important;
}
.oso-preview-panel{
  width:min(980px,96vw);
  height:min(92vh,980px);
  display:grid;
  grid-template-rows:1fr auto;
  gap:12px;
  position:relative;
}
.oso-preview-panel img{
  width:100%;
  height:100%;
  object-fit:contain;
  border-radius:22px;
  background:#120b07;
}
.oso-preview-panel p{
  color:#fff;
  text-align:center;
  margin:0;
  font-weight:800;
  opacity:.84;
}
.oso-preview-close{
  position:absolute;
  top:12px;
  right:12px;
  z-index:2;
  width:48px;
  height:48px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.4);
  background:rgba(18,11,7,.65);
  color:#fff;
  font-size:1.8rem;
  line-height:1;
}
.review-modal,
#reviewModal{
  display:none!important;
}
@media(max-width:640px){
  #photoGrid.review-deck-shell{
    max-width:100%;
  }
  .review-deck-card{
    border-radius:28px;
    padding:10px;
  }
  .deck-photo-wrap{
    min-height:390px;
    border-radius:24px;
  }
  .deck-photo-wrap img{
    height:58vh;
    min-height:390px;
  }
  .deck-instructions{
    font-size:.76rem;
    grid-template-columns:1fr;
    text-align:center;
  }
  .hide-hint,.keep-hint,.zoom-hint{
    text-align:center;
  }
}


/* Dashboard real mount fix */
#pendingGrid.review-deck-shell,
#photoGrid.review-deck-shell{
  display:block!important;
  max-width:760px;
  margin:0 auto;
}
.review-deck-mount{
  min-height:120px;
}
.dashboard #emptyState{
  margin-top:16px;
}


/* Final gallery share/save/download */
.gallery-actions,
.gallery-filter-buttons{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.gallery-toolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
}
.gallery-filter-buttons .small.active{
  background:var(--ink);
  color:#fff;
  border-color:var(--ink);
}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.gallery-photo-card{
  position:relative;
  border-radius:24px;
  overflow:hidden;
  background:#120b07;
  box-shadow:var(--shadow-soft);
  border:1px solid rgba(255,255,255,.52);
  min-height:220px;
}
.gallery-photo-card img{
  width:100%;
  height:100%;
  min-height:260px;
  object-fit:cover;
  display:block;
}
.save-photo,
.photo-download{
  position:absolute;
  z-index:2;
  top:12px;
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.46);
  background:rgba(18,11,7,.58);
  color:#fff;
  font-weight:950;
  text-decoration:none;
  backdrop-filter:blur(10px);
}
.save-photo{
  left:12px;
  font-size:1.42rem;
}
.save-photo.saved{
  background:rgba(223,111,18,.92);
}
.photo-download{
  right:12px;
  font-size:1.2rem;
}
.gallery-viewer{
  position:fixed;
  inset:0;
  z-index:3000;
  background:rgba(18,11,7,.92);
  display:grid;
  place-items:center;
  padding:18px;
}
.gallery-viewer.hidden{
  display:none!important;
}
.gallery-viewer-panel{
  position:relative;
  width:min(980px,96vw);
  max-height:94vh;
  display:grid;
  grid-template-rows:1fr auto;
  gap:12px;
}
.gallery-viewer-panel img{
  width:100%;
  height:min(78vh,820px);
  object-fit:contain;
  border-radius:24px;
  background:#120b07;
}
.gallery-viewer-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.gallery-viewer-close{
  position:absolute;
  top:12px;
  right:12px;
  z-index:3;
  width:48px;
  height:48px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.42);
  background:rgba(18,11,7,.68);
  color:#fff;
  font-size:1.8rem;
  line-height:1;
}
.viewer-save.saved{
  border-color:rgba(223,111,18,.4);
  color:var(--orange-dark);
  background:rgba(223,111,18,.1);
}
.btn.disabled{
  opacity:.55;
  pointer-events:none;
}
@media(max-width:800px){
  .gallery-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:520px){
  .gallery-toolbar{
    align-items:stretch;
    flex-direction:column;
  }
  .gallery-grid{
    grid-template-columns:1fr;
  }
  .gallery-photo-card img{
    min-height:320px;
  }
  .gallery-actions .btn{
    width:100%;
  }
}


/* Android/mobile reliability polish */
button,
.btn,
input,
select,
textarea{
  touch-action:manipulation;
}
a.btn,
button.btn{
  min-height:48px;
}
.compact-form{
  gap:12px;
}
.profile-card{
  margin-bottom:22px;
}
.profile-card input{
  font-size:16px;
}


.verify-next-actions{
  margin-top:14px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
@media(max-width:520px){
  .verify-next-actions{
    grid-template-columns:1fr;
  }
}


/* Android-safe Create Event choices */
.choice-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin-top:8px;
}
.event-type-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.tier-grid{
  grid-template-columns:1fr;
}
.limit-grid{
  grid-template-columns:repeat(4,minmax(0,1fr));
}
.choice-card{
  position:relative;
  min-height:54px;
  border:1px solid var(--line);
  border-radius:18px;
  padding:13px 14px;
  background:rgba(255,255,255,.84);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  text-align:center;
  font-weight:900;
  cursor:pointer;
  user-select:none;
  touch-action:manipulation;
  box-shadow:0 6px 18px rgba(29,19,13,.05);
}
.choice-card input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.choice-card span{
  line-height:1.1;
}
.choice-card small{
  display:block;
  color:var(--muted);
  font-weight:800;
  margin-top:4px;
}
.choice-card.selected{
  border-color:rgba(223,111,18,.46);
  background:linear-gradient(135deg,rgba(223,111,18,.14),rgba(255,255,255,.92));
  box-shadow:0 0 0 4px rgba(223,111,18,.08),0 14px 30px rgba(29,19,13,.08);
}
.choice-card.selected:after{
  content:"✓";
  position:absolute;
  top:8px;
  right:10px;
  color:var(--orange-dark);
  font-weight:950;
}
.choice-card.disabled{
  opacity:.45;
  filter:grayscale(.3);
}
.tier-card{
  align-items:flex-start;
  justify-content:flex-start;
  text-align:left;
  flex-direction:column;
}
@media(max-width:520px){
  .choice-grid,
  .event-type-grid{
    grid-template-columns:1fr;
  }
  .limit-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}


/* Create Event premium mobile choices v2 */
#createEventForm .field-group{
  margin:6px 0 14px;
}
#createEventForm .field-label{
  display:block;
  margin:0 0 9px;
  font-weight:950;
  color:var(--ink);
  letter-spacing:-.02em;
}
#createEventForm .oso-choice-grid,
#createEventForm .oso-chip-grid{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
#createEventForm .oso-tier-stack{
  display:grid!important;
  grid-template-columns:1fr;
  gap:10px;
}
#createEventForm .oso-limit-row{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
}
#createEventForm .oso-choice-chip,
#createEventForm .oso-tier-card,
#createEventForm .oso-limit-card{
  position:relative!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:54px;
  width:100%;
  margin:0!important;
  padding:13px 14px!important;
  border:1px solid rgba(29,19,13,.12)!important;
  border-radius:18px!important;
  background:rgba(255,255,255,.9)!important;
  color:var(--ink)!important;
  text-align:center!important;
  font-size:1rem!important;
  font-weight:950!important;
  letter-spacing:-.02em!important;
  line-height:1.08!important;
  cursor:pointer;
  user-select:none;
  touch-action:manipulation;
  box-shadow:0 10px 24px rgba(29,19,13,.055);
  transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease,background .12s ease;
}
#createEventForm .oso-choice-chip input[type="radio"],
#createEventForm .oso-tier-card input[type="radio"],
#createEventForm .oso-limit-card input[type="radio"]{
  position:absolute!important;
  opacity:0!important;
  width:1px!important;
  height:1px!important;
  margin:0!important;
  padding:0!important;
  pointer-events:none!important;
  appearance:none!important;
  -webkit-appearance:none!important;
}
#createEventForm .oso-choice-chip span,
#createEventForm .oso-tier-card span,
#createEventForm .oso-limit-card span{
  display:block;
}
#createEventForm .oso-choice-chip.selected,
#createEventForm .oso-tier-card.selected,
#createEventForm .oso-limit-card.selected{
  border-color:rgba(223,111,18,.5)!important;
  background:linear-gradient(135deg,rgba(223,111,18,.16),rgba(255,255,255,.96))!important;
  box-shadow:0 0 0 4px rgba(223,111,18,.08),0 16px 34px rgba(29,19,13,.09)!important;
}
#createEventForm .oso-choice-chip.selected:after,
#createEventForm .oso-tier-card.selected:after,
#createEventForm .oso-limit-card.selected:after{
  content:"✓";
  position:absolute;
  top:8px;
  right:10px;
  width:22px;
  height:22px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:var(--orange);
  color:#fff;
  font-size:.78rem;
  font-weight:950;
}
#createEventForm .oso-choice-chip:active,
#createEventForm .oso-tier-card:active,
#createEventForm .oso-limit-card:active{
  transform:scale(.985);
}
#createEventForm .oso-tier-card{
  align-items:flex-start!important;
  justify-content:center!important;
  flex-direction:column!important;
  text-align:left!important;
  min-height:74px;
  padding:16px 18px!important;
}
#createEventForm .oso-tier-card .tier-title{
  font-size:1.04rem;
}
#createEventForm .oso-tier-card .tier-meta{
  margin-top:5px;
  color:var(--muted);
  font-size:.9rem;
  font-weight:850;
}
#createEventForm .oso-limit-card{
  min-height:58px;
}
#createEventForm .oso-limit-card.disabled{
  opacity:.42!important;
  filter:grayscale(.25);
  pointer-events:none;
}
@media(max-width:640px){
  #createEventForm .oso-choice-grid,
  #createEventForm .oso-chip-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  #createEventForm .oso-limit-row{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:390px){
  #createEventForm .oso-choice-grid,
  #createEventForm .oso-chip-grid{
    grid-template-columns:1fr;
  }
}


/* guest-upload-button-fix */
#progressList{
  display:grid;
  gap:10px;
  margin:14px 0;
}
.progress-row{
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.86);
  padding:12px;
}
.progress-row strong{
  display:block;
  margin-bottom:4px;
}
.progress-state{
  display:inline-block;
  font-weight:900;
  margin-bottom:8px;
}
.progress-state.done{color:var(--green)}
.progress-state.error{color:var(--red)}
.progress-detail{
  color:var(--muted);
  font-size:.88rem;
  margin-bottom:8px;
}
.progress-bar{
  height:8px;
  border-radius:999px;
  background:rgba(223,111,18,.12);
  overflow:hidden;
}
.progress-fill{
  height:100%;
  width:0;
  border-radius:999px;
  background:linear-gradient(90deg,var(--orange),var(--orange-dark));
  transition:width .18s ease;
}


/* Simplified premium experience polish */
@keyframes osoFadeUp{
  from{opacity:0;transform:translateY(14px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes osoSoftGlow{
  0%,100%{transform:translate3d(0,0,0) scale(1);opacity:.52}
  50%{transform:translate3d(10px,-8px,0) scale(1.06);opacity:.8}
}
@keyframes osoButtonBreathe{
  0%,100%{box-shadow:0 16px 38px rgba(223,111,18,.22)}
  50%{box-shadow:0 18px 46px rgba(223,111,18,.32)}
}
.calm-hero{
  position:relative;
  overflow:hidden;
}
.calm-hero:before{
  content:"";
  position:absolute;
  width:320px;
  height:320px;
  right:-120px;
  top:20px;
  border-radius:999px;
  background:radial-gradient(circle,rgba(223,111,18,.16),rgba(223,111,18,0) 68%);
  animation:osoSoftGlow 8s ease-in-out infinite;
  pointer-events:none;
}
.card,
.page-hero .container > *,
.section .container > *{
  animation:osoFadeUp .42s ease both;
}
.btn.primary{
  animation:osoButtonBreathe 5s ease-in-out infinite;
}
.account-simple-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:18px;
  align-items:start;
}
.account-main-actions{
  display:grid;
  gap:12px;
  margin-top:20px;
}
.quick-guide-card{
  max-width:880px;
  margin:0 auto;
}
.guide-steps{
  display:grid;
  gap:14px;
}
.guide-step{
  display:grid;
  grid-template-columns:42px 1fr;
  gap:14px;
  align-items:start;
  padding:14px;
  border:1px solid var(--line);
  border-radius:20px;
  background:rgba(255,255,255,.7);
}
.guide-step > span{
  width:42px;
  height:42px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:rgba(223,111,18,.12);
  color:var(--orange-dark);
  font-weight:950;
}
.guide-step strong{
  display:block;
  color:var(--ink);
  margin-bottom:3px;
}
.guide-step p{
  margin:0;
  color:var(--muted);
}
.simple-support-card .clean{
  margin:16px 0 20px;
}
.simple-support-card .clean li{
  margin:8px 0;
}
@media(max-width:760px){
  .account-simple-grid{
    grid-template-columns:1fr;
  }
  .page-hero h1{
    font-size:clamp(3.15rem,16vw,5.8rem);
    line-height:.92;
    letter-spacing:-.075em;
  }
}
@media(prefers-reduced-motion:reduce){
  *,
  *:before,
  *:after{
    animation:none!important;
    transition:none!important;
  }
}


/* Launch polish: minimal account, clean guidance, gallery beauty */
.minimal-account-wrap{
  max-width:860px;
  margin:0 auto;
}
.minimal-account-card{
  text-align:left;
}
.minimal-account-card h2{
  margin-bottom:6px;
}
.minimal-details{
  margin-top:16px;
}
.minimal-details summary{
  cursor:pointer;
  font-weight:950;
  font-size:1.15rem;
  color:var(--ink);
}
.minimal-details form{
  margin-top:16px;
}
.settings-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.danger-zone{
  border-color:rgba(181,50,42,.18);
}
.btn.danger{
  background:#b5322a;
  color:#fff;
  border-color:#b5322a;
}
.gallery-cover-card{
  display:grid;
  grid-template-columns:minmax(220px,42%) 1fr;
  gap:20px;
  align-items:center;
  border:1px solid var(--line);
  border-radius:34px;
  background:linear-gradient(135deg,rgba(29,19,13,.96),rgba(84,43,19,.86));
  color:#fff;
  padding:18px;
  margin-bottom:18px;
  overflow:hidden;
  box-shadow:var(--shadow-soft);
}
.gallery-cover-card img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:24px;
  background:#120b07;
}
.gallery-cover-card h2{
  color:#fff;
}
.gallery-cover-card .muted{
  color:rgba(255,255,255,.74);
}
.polished-gallery-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.polished-gallery-grid .gallery-photo-card{
  transform:translateZ(0);
  transition:transform .18s ease, box-shadow .18s ease;
}
.polished-gallery-grid .gallery-photo-card:active{
  transform:scale(.985);
}
@media(max-width:760px){
  .settings-grid,
  .gallery-cover-card{
    grid-template-columns:1fr;
  }
  .polished-gallery-grid{
    grid-template-columns:1fr;
  }
}
