/* ─── Design tokens ──────────────────────────────────────────────────────── */
:root {
  --bg:         #08080d;
  --bg2:        #0d0d18;
  --bg-card:    #12121e;
  --bg-elev:    #181824;
  --border:     rgba(255,255,255,0.07);
  --border-hov: rgba(255,255,255,0.13);
  --border-str: rgba(255,255,255,0.20);
  --text:       #f0f0f5;
  --text-2:     #8888a0;
  --text-3:     #55556a;
  --pink:       #e1306c;
  --purple:     #833ab4;
  --blue:       #405de6;
  --green:      #22c55e;
  --red:        #ef4444;
  --grad:       linear-gradient(135deg,#833ab4 0%,#e1306c 50%,#405de6 100%);
  --grad-sub:   linear-gradient(135deg,rgba(131,58,180,.14) 0%,rgba(225,48,108,.14) 50%,rgba(64,93,230,.14) 100%);
  --radius:     .875rem;
  --radius-sm:  .625rem;
  --radius-lg:  1.25rem;
  --radius-xl:  1.75rem;
  --shadow-card:  0 4px 24px rgba(0,0,0,.45);
  --shadow-hover: 0 8px 40px rgba(0,0,0,.65);
  --shadow-glow:  0 0 40px rgba(225,48,108,.28);
}

/* ─── Reset ──────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{background:var(--bg);color:var(--text);font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;font-size:16px;line-height:1.6;min-height:100vh}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,select,textarea{font-family:inherit}
::selection{background:rgba(225,48,108,.3);color:#fff}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:99px}

/* ─── Layout ─────────────────────────────────────────────────────────────── */
.container{max-width:1100px;margin:0 auto;padding:0 1.25rem}
@media(min-width:640px){.container{padding:0 1.5rem}}

/* ─── Header ─────────────────────────────────────────────────────────────── */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s,border-color .3s,box-shadow .3s}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:64px;gap:1rem}
.site-header.scrolled{background:rgba(8,8,13,.88);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);box-shadow:0 4px 24px rgba(0,0,0,.3)}

.logo{display:flex;align-items:center;gap:.5rem;font-weight:800;font-size:1.1rem;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.logo-icon{width:32px;height:32px;border-radius:.625rem;background:var(--grad);display:flex;align-items:center;justify-content:center;flex-shrink:0}

.site-nav{display:none;gap:1.5rem;align-items:center}
.site-nav a{font-size:.875rem;color:var(--text-2);transition:color .2s}
.site-nav a:hover{color:var(--text)}
@media(min-width:768px){.site-nav{display:flex}}

/* ─── Footer ─────────────────────────────────────────────────────────────── */
.site-footer{border-top:1px solid var(--border);background:var(--bg);margin-top:6rem;padding:3.5rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2.5rem}
@media(min-width:640px){.footer-grid{grid-template-columns:2fr 1fr 1fr}}
.footer-brand p{font-size:.875rem;color:var(--text-2);line-height:1.7;margin:.75rem 0 1.25rem;max-width:280px}
.footer-whatsapp{display:inline-flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-2);transition:color .2s}
.footer-whatsapp:hover{color:#4ade80}
.footer-links h4{font-size:.875rem;font-weight:600;color:var(--text);margin-bottom:1rem}
.footer-links ul{list-style:none;display:flex;flex-direction:column;gap:.625rem}
.footer-links a{font-size:.875rem;color:var(--text-2);transition:color .2s}
.footer-links a:hover{color:var(--text)}
.footer-bottom{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem}
.footer-bottom p{font-size:.75rem;color:var(--text-3)}
.footer-secure{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--text-3)}
.footer-secure strong{color:var(--text-2)}

/* ─── Buttons ────────────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--radius-sm);font-weight:700;font-size:.9375rem;transition:transform .2s,box-shadow .2s,background .3s;white-space:nowrap}
.btn-sm{padding:.625rem 1.25rem;font-size:.875rem}
.btn-lg{padding:1rem 2rem;font-size:1rem;border-radius:var(--radius)}
.btn-block{width:100%}
.btn-gradient{background:var(--grad);background-size:200% 200%;color:#fff}
.btn-gradient:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(225,48,108,.4)}
.btn-gradient:active{transform:none}
.btn-ghost{background:rgba(255,255,255,.05);border:1px solid var(--border-hov);color:var(--text-2)}
.btn-ghost:hover{background:rgba(255,255,255,.09);color:var(--text)}
.btn-green{background:rgba(34,197,94,.15);border:1px solid rgba(34,197,94,.3);color:#4ade80}
.btn-green:hover{background:rgba(34,197,94,.22)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}

/* ─── Inputs ─────────────────────────────────────────────────────────────── */
.input{width:100%;padding:.875rem 1rem;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.9375rem;outline:none;transition:border-color .2s,box-shadow .2s}
.input::placeholder{color:var(--text-3)}
.input:focus{border-color:rgba(225,48,108,.5);box-shadow:0 0 0 3px rgba(225,48,108,.12)}
.input.error{border-color:rgba(239,68,68,.5)!important;box-shadow:0 0 0 3px rgba(239,68,68,.1)!important}
.input-icon-wrap{position:relative}
.input-icon-wrap .input{padding-left:2.75rem}
.input-icon-wrap .input-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none}
.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-2);margin-bottom:.5rem}
.form-error{font-size:.75rem;color:#f87171;margin-top:.375rem}
.form-group{display:flex;flex-direction:column;gap:0}

/* ─── Cards ──────────────────────────────────────────────────────────────── */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .2s,box-shadow .2s}
.card:hover{border-color:var(--border-hov);box-shadow:var(--shadow-hover)}
.card-p{padding:1.5rem}
.card-featured{position:relative;background:var(--bg-card);border-radius:var(--radius)}
.card-featured::before{content:'';position:absolute;inset:0;border-radius:var(--radius);padding:1px;background:var(--grad);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}

/* ─── Badges ─────────────────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:99px;font-size:.75rem;font-weight:700}
.badge-gradient{background:var(--grad);color:#fff;box-shadow:0 0 16px rgba(225,48,108,.3)}
.badge-discount{background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.25);color:#4ade80}
.badge-pending{background:rgba(234,179,8,.1);border:1px solid rgba(234,179,8,.25);color:#fbbf24}
.badge-paid{background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.25);color:#4ade80}
.badge-cancelled{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);color:#f87171}
.badge-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:.375rem;animation:pulse 2s infinite}
.badge-dot-pending{background:#fbbf24}
.badge-dot-paid{background:#4ade80;animation:none}
.badge-dot-cancelled{background:#f87171;animation:none}

/* ─── Alert ──────────────────────────────────────────────────────────────── */
.alert{padding:1rem 1.25rem;border-radius:var(--radius-sm);font-size:.875rem;line-height:1.6}
.alert-error{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);color:#fca5a5}
.alert-success{background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.2);color:#86efac}
.alert-info{background:rgba(64,93,230,.08);border:1px solid rgba(64,93,230,.2);color:#a5b4fc}

/* ─── Step indicator ─────────────────────────────────────────────────────── */
.steps{display:flex;align-items:flex-start;justify-content:center;gap:0;margin-bottom:2.5rem}
.step-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.step-connector{height:1px;width:48px;background:rgba(255,255,255,.08);margin-top:14px;transition:background .3s}
.step-connector.done{background:rgba(34,197,94,.35)}
@media(min-width:640px){.step-connector{width:72px}}
.step-circle{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0;transition:all .3s}
.step-circle-active{background:var(--grad);color:#fff;box-shadow:0 0 20px rgba(225,48,108,.3)}
.step-circle-done{background:rgba(34,197,94,.2);border:1.5px solid rgba(34,197,94,.5);color:#4ade80}
.step-circle-inactive{background:rgba(255,255,255,.05);border:1px solid var(--border);color:var(--text-3)}
.step-label{font-size:.6875rem;font-weight:500;color:var(--text-3);white-space:nowrap;display:none}
.step-label-active{color:var(--text)}
@media(min-width:600px){.step-label{display:block}}

/* ─── Skeleton ───────────────────────────────────────────────────────────── */
.skeleton{background:linear-gradient(90deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.08) 50%,rgba(255,255,255,.04) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:.5rem}

/* ─── Spinner ────────────────────────────────────────────────────────────── */
.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
.spinner-sm{width:14px;height:14px}

/* ─── Gradient text ──────────────────────────────────────────────────────── */
.grad-text{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ═══════════════════════════════════════════════════════════════════════════
   LANDING PAGE
═══════════════════════════════════════════════════════════════════════════ */

/* Hero */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:5rem 1.25rem 4rem;overflow:hidden}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-glow-1{position:absolute;top:25%;left:50%;transform:translateX(-50%);width:600px;height:600px;border-radius:50%;background:rgba(131,58,180,.1);filter:blur(120px)}
.hero-glow-2{position:absolute;top:35%;left:50%;transform:translateX(-50%);width:400px;height:400px;border-radius:50%;background:rgba(225,48,108,.07);filter:blur(100px)}
.hero-badge{display:inline-flex;align-items:center;gap:.625rem;background:rgba(255,255,255,.04);border:1px solid var(--border-hov);border-radius:99px;padding:.5rem 1rem;margin-bottom:2rem;font-size:.8125rem;color:var(--text-2)}
.hero-badge-avatars{display:flex;margin-right:.25rem}
.hero-badge-avatars span{width:22px;height:22px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:.5rem;font-weight:700;color:#fff;border:1.5px solid var(--bg);margin-left:-6px}
.hero-badge-avatars span:first-child{margin-left:0}
.hero-stars{color:#facc15;font-size:.875rem;letter-spacing:1px}
.hero h1{font-size:clamp(2.25rem,7vw,3.75rem);font-weight:900;line-height:1.1;letter-spacing:-.03em;margin-bottom:1.25rem;max-width:700px}
.hero p{font-size:1.0625rem;color:var(--text-2);max-width:440px;margin:0 auto 2.5rem;line-height:1.7}
.hero-search-wrap{width:100%;max-width:440px;margin:0 auto}
.hero-search-form{display:flex;flex-direction:column;gap:.75rem}
@media(min-width:480px){.hero-search-form{flex-direction:row}}
.hero-trust{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1.25rem 2rem;margin-top:2rem}
.hero-trust span{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--text-2)}
.hero-scroll{display:flex;flex-direction:column;align-items:center;gap:.375rem;margin-top:3.5rem;opacity:.35}
.hero-scroll span{font-size:.6875rem;color:var(--text-3);letter-spacing:.05em}
.hero-scroll-line{width:1px;height:32px;background:linear-gradient(to bottom,rgba(255,255,255,.2),transparent)}

/* Section helper */
.section{padding:5rem 0}
.section-alt{background:rgba(13,13,24,.6)}
.section-header{text-align:center;margin-bottom:3.5rem}
.section-eyebrow{display:block;font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:.75rem}
.section-header h2{font-size:clamp(1.75rem,5vw,2.5rem);font-weight:900;letter-spacing:-.025em;line-height:1.2}
.section-header p{margin-top:.75rem;font-size:1rem;color:var(--text-2);max-width:420px;margin-left:auto;margin-right:auto}

/* Benefits */
.benefits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem}
.benefit-card{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}
.benefit-icon{font-size:1.5rem;flex-shrink:0;margin-top:.1rem}
.benefit-card h3{font-size:.9375rem;font-weight:700;margin-bottom:.375rem}
.benefit-card p{font-size:.875rem;color:var(--text-2);line-height:1.6}

/* Stats strip */
.stats-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);padding:2rem 1.5rem;margin-top:3.5rem;text-align:center}
.stat-value{font-size:1.75rem;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat-label{font-size:.75rem;color:var(--text-2);margin-top:.25rem}

/* How it works */
.steps-grid{display:grid;grid-template-columns:1fr;gap:1.25rem;position:relative}
@media(min-width:768px){.steps-grid{grid-template-columns:repeat(3,1fr)}}
.step-card{padding:1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}
.step-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.step-card-icon{width:44px;height:44px;border-radius:.75rem;background:var(--grad);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}
.step-number{font-size:3rem;font-weight:900;color:rgba(255,255,255,.04);line-height:1}
.step-card h3{font-size:1rem;font-weight:700;margin-bottom:.375rem}
.step-card p{font-size:.875rem;color:var(--text-2);line-height:1.65}

/* Packages grid */
.packages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem}
.pkg-card{border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);display:flex;flex-direction:column;padding:1.5rem;transition:border-color .2s,box-shadow .2s,transform .2s;cursor:pointer;position:relative}
.pkg-card:hover{border-color:var(--border-hov);box-shadow:var(--shadow-hover);transform:translateY(-3px)}
.pkg-card-featured{border-color:transparent!important}
.pkg-card-featured::before{content:'';position:absolute;inset:0;border-radius:var(--radius);padding:1px;background:var(--grad);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.pkg-badge-wrap{position:absolute;top:-14px;left:50%;transform:translateX(-50%);z-index:1}
.pkg-followers{font-size:2rem;font-weight:900;color:var(--text);line-height:1}
.pkg-followers span{font-size:.875rem;font-weight:500;color:var(--text-2)}
.pkg-desc{font-size:.8125rem;color:var(--text-3);margin:.25rem 0 1rem}
.pkg-pricing{margin-top:auto}
.pkg-original{font-size:.9375rem;text-decoration:line-through;color:var(--text-3);display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}
.pkg-amount{font-size:1.625rem;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.pkg-per100{font-size:.6875rem;color:var(--text-3);margin:.25rem 0 1rem}
.pkg-features{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}
.pkg-features li{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--text-2)}
.pkg-features li::before{content:'';width:14px;height:14px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%2322c55e'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41L9 16.17z'/%3E%3C/svg%3E") no-repeat center / contain;flex-shrink:0}
.pkg-btn{width:100%;padding:.75rem;border-radius:.75rem;font-size:.9rem;font-weight:700;transition:all .2s;text-align:center}
.pkg-btn-primary{background:var(--grad);color:#fff}
.pkg-btn-secondary{background:rgba(255,255,255,.05);border:1px solid var(--border-hov);color:var(--text-2)}
.pkg-btn-secondary:hover{background:rgba(255,255,255,.09);color:var(--text)}

/* FAQ */
.faq-list{display:flex;flex-direction:column;gap:.5rem;max-width:680px;margin:0 auto}
.faq-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .2s}
.faq-item.open{border-color:var(--border-hov)}
.faq-question{display:flex;align-items:center;justify-content:space-between;padding:1.125rem 1.25rem;gap:1rem;cursor:pointer;user-select:none}
.faq-question span{font-size:.9375rem;font-weight:600}
.faq-toggle{width:22px;height:22px;border-radius:50%;border:1px solid var(--border-str);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .25s,border-color .2s;color:var(--text-2)}
.faq-item.open .faq-toggle{transform:rotate(45deg);border-color:rgba(225,48,108,.4)}
.faq-answer{display:none;padding:0 1.25rem 1.25rem}
.faq-item.open .faq-answer{display:block}
.faq-answer p{font-size:.875rem;color:var(--text-2);line-height:1.75}

/* CTA section */
.cta-box{position:relative;border-radius:var(--radius-xl);overflow:hidden;text-align:center;padding:4rem 2rem;max-width:680px;margin:0 auto}
.cta-bg{position:absolute;inset:0;background:var(--grad-sub);border:1px solid var(--border-hov)}
.cta-glow{position:absolute;top:-40px;left:50%;transform:translateX(-50%);width:320px;height:320px;border-radius:50%;background:rgba(131,58,180,.18);filter:blur(80px);pointer-events:none}
.cta-box .content{position:relative}
.cta-box h2{font-size:clamp(1.75rem,5vw,2.375rem);font-weight:900;letter-spacing:-.02em;margin-bottom:1rem}
.cta-box p{color:var(--text-2);max-width:380px;margin:0 auto 2rem}
.cta-trust{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1rem 1.5rem;margin-top:1.5rem}
.cta-trust span{font-size:.8125rem;color:var(--text-3);display:flex;align-items:center;gap:.375rem}
.cta-trust span::before{content:'';width:6px;height:6px;border-radius:50%;background:#4ade80;flex-shrink:0}

/* ═══════════════════════════════════════════════════════════════════════════
   FLUXO: PERFIL + CHECKOUT
═══════════════════════════════════════════════════════════════════════════ */

.flow-page{padding-top:6rem;padding-bottom:4rem;min-height:100vh}
.flow-container{max-width:960px;margin:0 auto;padding:0 1.25rem}

/* Profile card */
.profile-card{padding:1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg)}
.profile-inner{display:flex;align-items:flex-start;gap:1rem}
.profile-avatar-wrap{position:relative;flex-shrink:0}
.profile-avatar{width:76px;height:76px;border-radius:1rem;object-fit:cover;border:2px solid rgba(255,255,255,.1)}
.profile-verified{position:absolute;bottom:-4px;right:-4px;width:20px;height:20px;background:#4ade80;border-radius:50%;border:2px solid var(--bg-card);display:flex;align-items:center;justify-content:center}
.profile-name{font-size:1rem;font-weight:700;display:flex;align-items:center;gap:.375rem}
.profile-username{font-size:.875rem;color:var(--text-2);margin-top:.125rem}
.profile-stats{display:flex;gap:1.5rem;margin-top:.875rem}
.profile-stat{text-align:left}
.profile-stat-value{font-size:.9375rem;font-weight:700}
.profile-stat-label{font-size:.6875rem;color:var(--text-3)}
.profile-confirmed{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:rgba(34,197,94,.06);border-top:1px solid rgba(34,197,94,.12);border-radius:0 0 var(--radius) var(--radius);margin-top:1rem;font-size:.8125rem;color:#86efac}
.profile-dot{width:7px;height:7px;border-radius:50%;background:#4ade80}

/* Checkout layout */
.checkout-grid{display:grid;grid-template-columns:1fr;gap:2rem}
@media(min-width:768px){.checkout-grid{grid-template-columns:1fr 360px}}
.checkout-form-section{display:flex;flex-direction:column;gap:1.25rem}
.checkout-summary{position:sticky;top:6rem;height:fit-content}
.checkout-summary-inner{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem}
.summary-profile{display:flex;align-items:center;gap:.875rem;padding-bottom:1.25rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border)}
.summary-avatar{width:44px;height:44px;border-radius:.75rem;object-fit:cover;flex-shrink:0;border:1.5px solid rgba(255,255,255,.1)}
.summary-row{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;margin-bottom:.75rem}
.summary-row label{color:var(--text-2)}
.summary-row span{font-weight:600}
.summary-delivery{color:#4ade80!important}
.summary-total{padding-top:1rem;margin-top:.5rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:baseline}
.summary-total label{color:var(--text-2);font-size:.9rem}
.summary-total-price{font-size:1.625rem;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.security-note{display:flex;align-items:flex-start;gap:.625rem;padding:.875rem 1rem;border-radius:.75rem;background:rgba(255,255,255,.02);border:1px solid var(--border);margin-top:.5rem;font-size:.8125rem;color:var(--text-3);line-height:1.6}

/* ═══════════════════════════════════════════════════════════════════════════
   PAGAMENTO (PIX)
═══════════════════════════════════════════════════════════════════════════ */

.pix-page{max-width:860px;margin:0 auto;padding:0 1.25rem}
.pix-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:680px){.pix-grid{grid-template-columns:1fr 300px}}
.pix-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem}
.qrcode-wrap{background:#fff;padding:1rem;border-radius:1rem;width:196px;height:196px;display:flex;align-items:center;justify-content:center}
.qrcode-wrap img{width:100%;height:100%;object-fit:contain;image-rendering:pixelated}
.pix-countdown{font-size:.875rem;text-align:center;color:var(--text-2)}
.pix-countdown strong{color:var(--text);font-family:monospace;font-size:1rem}
.pix-countdown.expiring strong{color:#f87171}
.copy-wrap{width:100%;display:flex;gap:.5rem}
.copy-input{flex:1;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:.75rem;padding:.75rem 1rem;font-size:.75rem;font-family:monospace;color:var(--text-2);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;outline:none}
.copy-btn{flex-shrink:0;padding:.75rem 1.25rem;border-radius:.75rem;font-size:.875rem;font-weight:700;transition:all .2s;background:var(--grad);color:#fff}
.copy-btn.copied{background:rgba(34,197,94,.15)!important;border:1px solid rgba(34,197,94,.3);color:#4ade80!important;box-shadow:none!important;transform:none!important}
.pix-instructions{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}
.pix-instructions h3{font-size:.9375rem;font-weight:700;margin-bottom:1rem}
.pix-step{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.875rem;font-size:.875rem;color:var(--text-2);line-height:1.6}
.pix-step-n{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.05);border:1px solid var(--border-hov);font-size:.6875rem;font-weight:700;color:var(--text-3);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.125rem}

/* ═══════════════════════════════════════════════════════════════════════════
   SUCESSO
═══════════════════════════════════════════════════════════════════════════ */

.success-page{max-width:560px;margin:0 auto;padding:0 1.25rem;text-align:center}
.success-icon-wrap{width:72px;height:72px;border-radius:1.5rem;background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.25);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}
.success-details{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;text-align:left;margin:2rem 0}
.success-detail-row{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;padding:.5rem 0;border-bottom:1px solid var(--border)}
.success-detail-row:last-child{border-bottom:none}
.success-detail-row label{color:var(--text-2)}
.success-detail-row span{font-weight:600}
.success-actions{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}
@media(min-width:480px){.success-actions{flex-direction:row;justify-content:center}}

/* ═══════════════════════════════════════════════════════════════════════════
   ADMIN
═══════════════════════════════════════════════════════════════════════════ */

.admin-page{background:rgba(13,13,24,.5);min-height:100vh;padding:2rem 1.25rem}
.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}
.admin-header h1{font-size:1.375rem;font-weight:800}
.admin-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;margin-bottom:2rem}
.admin-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}
.admin-stat-card h3{font-size:.75rem;color:var(--text-2);font-weight:500;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.06em}
.admin-stat-card span{font-size:1.75rem;font-weight:900}
.admin-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}
.admin-table th{padding:.875rem 1rem;text-align:left;font-size:.75rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);background:rgba(255,255,255,.02)}
.admin-table td{padding:.875rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text-2)}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{background:rgba(255,255,255,.02);color:var(--text)}
.admin-username{color:var(--text);font-weight:600}
.admin-order-n{font-family:monospace;font-size:.8125rem;color:var(--text-2)}
.admin-login{max-width:380px;margin:0 auto;padding:3rem 1.25rem;display:flex;flex-direction:column;align-items:center}

/* ═══════════════════════════════════════════════════════════════════════════
   INSTITUCIONAL
═══════════════════════════════════════════════════════════════════════════ */

.inst-page{max-width:720px;margin:0 auto;padding:6rem 1.25rem 4rem}
.inst-page h1{font-size:clamp(1.625rem,4vw,2.25rem);font-weight:900;margin-bottom:.5rem}
.inst-page .updated{font-size:.875rem;color:var(--text-3);margin-bottom:2.5rem}
.inst-page h2{font-size:1.1875rem;font-weight:700;margin:2.25rem 0 .875rem;color:var(--text)}
.inst-page p{font-size:.9375rem;color:var(--text-2);line-height:1.8;margin-bottom:1rem}
.inst-page ul{padding-left:1.5rem;margin-bottom:1rem}
.inst-page ul li{font-size:.9375rem;color:var(--text-2);line-height:1.8;margin-bottom:.375rem}

/* 404 */
.page-404{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:2rem}
.page-404 h1{font-size:clamp(4rem,15vw,8rem);font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.page-404 p{font-size:1.125rem;color:var(--text-2);margin:1rem 0 2rem}

/* ═══════════════════════════════════════════════════════════════════════════
   ANIMAÇÕES
═══════════════════════════════════════════════════════════════════════════ */

@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}

.anim-fade{animation:fadeIn .4s ease-out both}
.anim-up{animation:slideUp .45s ease-out both}
.anim-up-1{animation:slideUp .45s .1s ease-out both}
.anim-up-2{animation:slideUp .45s .2s ease-out both}
.anim-up-3{animation:slideUp .45s .3s ease-out both}

/* ─── Utils ──────────────────────────────────────────────────────────────── */
.text-center{text-align:center}
.text-muted{color:var(--text-3)}
.text-secondary{color:var(--text-2)}
.fw-bold{font-weight:700}
.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}
.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}
.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}
.gap-3{gap:.75rem}.gap-4{gap:1rem}
.flex{display:flex}.flex-col{flex-direction:column}
.items-center{align-items:center}.justify-center{justify-content:center}
.w-full{width:100%}
.hidden{display:none!important}
