﻿
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --ink:#14100c; --ink2:#2d2519; --ink3:#4a3d2d; --muted:#7d6b54;
  --pale:#ede2c8; --warm:#e6d6b0; --warm2:#d4c197;
  --accent:#b8482a; --accent2:#d35a32; --accent-soft:#e8b59a;
  --gold:#c4a576;
  --paper:#f7eed7; --cream:#fdf6e3;
  --line:rgba(20,16,12,0.14); --line2:rgba(20,16,12,0.3);
}
html{scroll-behavior:smooth;overflow-x:hidden;font-size:17px}
body{background:var(--paper);color:var(--ink);font-family:'Manrope',sans-serif;font-weight:400;cursor:none;overflow-x:hidden;position:relative}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:1;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.2  0 0 0 0 0.15  0 0 0 0 0.08  0 0 0 0.4 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");mix-blend-mode:multiply;opacity:0.12}
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:1;background:radial-gradient(ellipse at center,transparent 30%,rgba(20,16,12,0.08) 100%)}
*{cursor:none!important}
::selection{background:var(--accent);color:white}

/* SCROLL PROGRESS */
#scroll-bar{position:fixed;top:0;left:0;height:2px;background:var(--accent);width:0%;z-index:9998;transition:width 0.1s linear}

/* LOADING SCREEN */
#loader{position:fixed;inset:0;background:var(--ink);z-index:10000;display:flex;align-items:center;justify-content:center;flex-direction:column;transition:opacity 0.8s,visibility 0.8s}
#loader.hide{opacity:0;visibility:hidden}
.loader-logo{font-family:'Cormorant Garamond',serif;font-size:2.5rem;font-weight:300;color:var(--paper);letter-spacing:0.15em;text-transform:uppercase;margin-bottom:2rem;overflow:hidden}
.loader-logo span{display:inline-block;animation:lett 0.7s cubic-bezier(0.7,0,0.3,1) both}
.loader-bar{width:200px;height:1px;background:rgba(245,242,237,0.15);position:relative;overflow:hidden}
.loader-bar::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:var(--accent-soft);animation:loadbar 1.6s cubic-bezier(0.7,0,0.3,1) forwards}
@keyframes loadbar{to{left:100%}}
@keyframes lett{from{transform:translateY(110%) rotate(8deg);opacity:0}to{transform:none;opacity:1}}

/* CURSOR */
#cursor{position:fixed;width:8px;height:8px;background:var(--ink);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform 0.1s,width 0.25s,height 0.25s,background 0.25s,border-color 0.25s}
#cursor.big{width:60px;height:60px;background:transparent;border:1.5px solid var(--ink);mix-blend-mode:difference}
#cursor.drag{width:80px;height:80px;background:var(--accent);mix-blend-mode:normal;border:none}
#cursor.drag::after{content:'⟷';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:white;font-size:1.4rem;font-weight:300}
#cursor.light{background:var(--cream)}
#cursor.light.big{background:transparent;border:1.5px solid var(--cream);mix-blend-mode:normal}
body:has(.dashboard.open) #cursor.light{background:var(--ink)}
body:has(.dashboard.open) #cursor.light.big{border-color:var(--ink);mix-blend-mode:difference}
body:has(.modal-backdrop.open) #cursor.light{background:var(--ink)}
body:has(.modal-backdrop.open) #cursor.light.big{border-color:var(--ink);mix-blend-mode:difference}
body:has(.arch-page.open) #cursor.light{background:var(--ink)}
body:has(.arch-page.open) #cursor.light.big{border-color:var(--ink);mix-blend-mode:difference}
body:has(.topup-modal.open) #cursor.light,
body:has(.hist-modal.open) #cursor.light,
body:has(.wlc-modal.open) #cursor.light,
body:has(.fr-modal.open) #cursor.light,
body:has(.proj-page.open) #cursor.light{background:var(--ink)}
body:has(.topup-modal.open) #cursor.light.big,
body:has(.hist-modal.open) #cursor.light.big,
body:has(.wlc-modal.open) #cursor.light.big,
body:has(.fr-modal.open) #cursor.light.big,
body:has(.proj-page.open) #cursor.light.big{border-color:var(--ink);mix-blend-mode:difference}

/* NAV */
.topbar{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 3rem;height:64px;background:rgba(20,16,12,0.85);backdrop-filter:blur(20px);border-bottom:1px solid rgba(232,225,200,0.08);transition:background 0.4s,border-color 0.4s}
.topbar.light{background:rgba(240,227,197,0.9);border-bottom:1px solid var(--line)}
.logo{font-family:'Cormorant Garamond',serif;font-size:1.45rem;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;color:var(--cream);text-decoration:none;position:relative;transition:color 0.4s}
.topbar.light .logo{color:var(--ink)}
.logo sup{font-size:0.45rem;vertical-align:super;letter-spacing:0.2em;color:var(--accent-soft);margin-left:2px}
.nav-links{display:flex;gap:2.5rem;list-style:none;align-items:center}
.nav-links a{font-size:0.78rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(248,236,206,0.6);text-decoration:none;transition:color 0.3s;position:relative;padding:0.3rem 0}
.topbar.light .nav-links a{color:var(--muted)}
.nav-links a:not(.nav-cta):not(.nav-login)::after{content:'';position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--cream);transform:scaleX(0);transform-origin:right;transition:transform 0.4s cubic-bezier(0.7,0,0.3,1)}
.topbar.light .nav-links a:not(.nav-cta):not(.nav-login)::after{background:var(--ink)}
.nav-links a:not(.nav-cta):not(.nav-login):hover{color:var(--cream)}
.topbar.light .nav-links a:not(.nav-cta):not(.nav-login):hover{color:var(--ink)}
.nav-links a:not(.nav-cta):not(.nav-login):hover::after{transform:scaleX(1);transform-origin:left}
.nav-cta{font-size:0.78rem;letter-spacing:0.18em;text-transform:uppercase;background:var(--accent);color:var(--cream)!important;padding:0.6rem 1.6rem;transition:background 0.3s!important}
.nav-cta:hover{background:var(--accent2)!important}
.nav-login{position:relative;padding:0.55rem 1.2rem!important;border:1px solid rgba(232,225,200,0.25);color:var(--cream)!important}
.topbar.light .nav-login{border-color:var(--line2);color:var(--ink)!important}
.nav-login::after{display:none!important}
.nav-login:hover{border-color:var(--cream)}
.topbar.light .nav-login:hover{border-color:var(--ink)}

/* === NAV USER AVATAR + DROPDOWN === */
.nav-user{position:relative}
.nav-avatar{background:transparent;border:1px solid var(--line2);padding:0.35rem 0.7rem 0.35rem 0.4rem;display:flex;align-items:center;gap:0.5rem;cursor:pointer;font-family:'Manrope',sans-serif;color:var(--ink);transition:border-color 0.3s}
.nav-avatar:hover{border-color:var(--ink)}
.nav-avatar-letter{width:28px;height:28px;background:var(--ink);color:var(--paper);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:500;font-style:italic}
.nav-avatar-arr{font-size:0.6rem;color:var(--muted);transition:transform 0.3s}
.nav-user.open .nav-avatar-arr{transform:rotate(180deg)}
.nav-dropdown{position:absolute;top:calc(100% + 12px);right:0;background:var(--paper);border:1px solid var(--line);min-width:240px;padding:0.6rem;opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity 0.3s,transform 0.3s,visibility 0.3s;box-shadow:0 20px 40px -10px rgba(26,23,20,0.15);z-index:99}
.nav-user.open .nav-dropdown{opacity:1;visibility:visible;transform:none}
.nav-dropdown a{display:flex;align-items:center;gap:0.8rem;padding:0.7rem 0.9rem;color:var(--ink2);text-decoration:none;font-size:0.85rem;letter-spacing:0;text-transform:none;font-weight:400;transition:background 0.2s,color 0.2s}
.nav-dropdown a::after{display:none!important}
.nav-dropdown a:hover{background:var(--warm);color:var(--ink)}
.nav-dropdown a span{width:18px;text-align:center;color:var(--accent);font-family:'Cormorant Garamond',serif;font-size:1rem;font-style:italic}
.nav-dd-sep{height:1px;background:var(--line);margin:0.4rem 0.4rem}

/* === DASHBOARD === */
/* DASHBOARD — ARCHIVE EDITION */
.dashboard{position:fixed;inset:0;background:var(--paper);z-index:200;overflow-y:auto;opacity:0;visibility:hidden;transition:opacity 0.5s,visibility 0.5s;color:var(--ink)}
.dashboard.open{opacity:1;visibility:visible}
.dashboard-inner{max-width:1200px;margin:0 auto;padding:3.5rem 4rem 4rem}
.dash-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;padding-bottom:1.2rem;border-bottom:1px solid var(--line)}
.dash-crumb{font-size:0.9rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(20,16,12,0.65);display:flex;align-items:center;gap:1.1rem}
.dash-crumb-num{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-style:italic;color:var(--accent);letter-spacing:0;text-transform:none}
.dash-crumb-sep{color:var(--line)}
.dash-close{background:transparent;border:1px solid var(--line);padding:0.6rem 1.4rem;font-size:0.85rem;letter-spacing:0.12em;text-transform:uppercase;color:rgba(20,16,12,0.7);cursor:pointer;font-family:'Manrope',sans-serif;transition:all 0.3s;display:flex;align-items:center;gap:0.6rem}
.dash-close:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* Identity strip */
.dash-identity{display:grid;grid-template-columns:auto 1fr auto auto;gap:2.5rem;align-items:center;padding:1.8rem 0;border-bottom:1px solid var(--line);margin-bottom:0}
.dash-monogram{font-family:'Cormorant Garamond',serif;font-size:7.5rem;font-weight:300;font-style:italic;color:var(--accent);line-height:0.85;width:88px;text-align:center}
.dash-identity-label{font-size:0.78rem;letter-spacing:0.25em;text-transform:uppercase;color:rgba(20,16,12,0.55);margin-bottom:0.7rem}
.dash-identity-name{font-family:'Cormorant Garamond',serif;font-size:2.8rem;font-weight:300;line-height:1;letter-spacing:-0.02em;color:var(--ink)}
.dash-identity-name em{font-style:italic;color:var(--accent)}
.dash-identity-email{font-size:1rem;color:rgba(20,16,12,0.6);letter-spacing:0.02em;margin-top:0.5rem}
.dash-identity-badge{padding:1.2rem 2.2rem;border-left:1px solid var(--line);border-right:1px solid var(--line);text-align:center}
.dash-pro-label{display:block;font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:300;font-style:italic;color:var(--accent);line-height:1}
.dash-pro-sub{display:block;font-size:0.78rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(20,16,12,0.55);margin-top:0.5rem}
.dash-identity-balance{text-align:right}
.dash-balance-n{font-family:'Manrope',sans-serif;font-size:4.5rem;font-weight:300;color:var(--ink);line-height:0.85;letter-spacing:-0.03em}
.dash-balance-label{font-size:0.88rem;letter-spacing:0.12em;text-transform:uppercase;color:rgba(20,16,12,0.6);line-height:1.7;margin:0.6rem 0 1rem}
.dash-balance-label span{color:rgba(20,16,12,0.4)}
.dash-topup{background:transparent;border:1px solid rgba(168,52,31,0.5);color:var(--accent);padding:0.5rem 0.9rem;font-family:'Manrope',sans-serif;font-size:0.82rem;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;transition:all 0.3s;display:block;width:100%}
.dash-topup:hover{background:var(--accent);color:white;border-color:var(--accent)}

/* Body columns */
.dash-body{display:flex;flex-direction:column;gap:0}
.dash-divider-v{display:none}
.dash-section-num{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:300;font-style:italic;color:rgba(20,16,12,0.2);line-height:1;margin-bottom:0;letter-spacing:-0.05em;flex-shrink:0}
.dash-section-title{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:300;color:var(--ink);letter-spacing:-0.01em;margin-bottom:1.5rem;padding-bottom:0.8rem;border-bottom:1px solid var(--line)}
.dash-new-project{display:inline-flex;align-items:center;gap:1.2rem;padding:1.05rem 2.2rem 1.05rem 1.4rem;border:none;text-decoration:none;color:var(--paper);transition:all 0.35s cubic-bezier(0.7,0,0.3,1);margin-bottom:1.8rem;background:var(--accent);box-shadow:0 8px 24px -6px rgba(184,72,42,0.45);position:relative;overflow:hidden}
.dash-new-project::before{content:'';position:absolute;inset:0;background:var(--ink);transform:translateY(100%);transition:transform 0.4s cubic-bezier(0.7,0,0.3,1);z-index:0}
.dash-new-project:hover::before{transform:translateY(0)}
.dash-new-project:hover{box-shadow:0 12px 32px -8px rgba(20,16,12,0.35)}
.dash-new-project .dash-new-icon,.dash-new-project .dash-new-text{position:relative;z-index:1}
.dash-new-icon{width:38px;height:38px;border:1px solid currentColor;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;transition:all 0.3s}
.dash-new-project:hover .dash-new-icon{border-color:rgba(255,255,255,0.5)}
.dash-new-text{font-size:1rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase}
.dash-empty-note{font-size:0.95rem;color:rgba(20,16,12,0.55);line-height:1.7;margin-top:1rem;margin-bottom:0}
.dash-all-link{font-size:0.9rem;letter-spacing:0.14em;text-transform:uppercase;color:rgba(20,16,12,0.75);text-decoration:none;transition:color 0.3s;font-weight:500}
.dash-all-link:hover{color:var(--accent)}
.dash-row{display:flex;align-items:center;gap:1.2rem;padding:1.2rem 0;border-bottom:1px solid var(--line)}
.dash-row-label{font-size:0.82rem;letter-spacing:0.14em;text-transform:uppercase;color:rgba(20,16,12,0.7);width:130px;flex-shrink:0;line-height:1.5;font-weight:500}
.dash-row-value{flex:1;font-size:1.05rem;color:var(--ink);display:flex;align-items:center;gap:0.5rem}
.dash-row-value.mono{font-family:'IBM Plex Mono',monospace;font-size:0.95rem;letter-spacing:0.06em;color:var(--accent)}
.dash-row-action{background:transparent;border:1px solid rgba(20,16,12,0.25);color:rgba(20,16,12,0.75);padding:0.45rem 0.9rem;font-family:'Manrope',sans-serif;font-size:0.78rem;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;transition:all 0.3s;white-space:nowrap;flex-shrink:0}
.dash-row-action:hover{border-color:var(--ink);color:var(--ink)}
.dash-row-action.danger{border-color:rgba(168,52,31,0.5);color:var(--accent)}
.dash-row-action.danger:hover{background:var(--accent);color:white;border-color:var(--accent)}
.dash-logout{background:transparent;border:none;color:rgba(20,16,12,0.65);font-family:'Manrope',sans-serif;font-size:0.9rem;letter-spacing:0.14em;text-transform:uppercase;cursor:pointer;padding:1.8rem 0 0;transition:color 0.3s;display:block;font-weight:500}
.dash-logout:hover{color:var(--accent)}

/* Dash sections */
.dash-section--wide{padding:2rem 0 2.5rem;border-bottom:1px solid var(--line)}
.dash-section--account{padding:2rem 0 0}
.dash-section-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}
.dash-section-hd-left{display:flex;align-items:baseline;gap:0.8rem}
.dash-section-hd .dash-section-title{border-bottom:none;margin-bottom:0;padding-bottom:0}
.dash-film-row{display:flex;align-items:center;gap:1.5rem;overflow-x:auto;padding-bottom:0.5rem}
.dash-film-row::-webkit-scrollbar{height:2px}
.dash-film-row::-webkit-scrollbar-track{background:var(--line)}
.dash-film-row::-webkit-scrollbar-thumb{background:var(--accent)}
.dash-film-row .dash-new-project{margin-bottom:0;flex-shrink:0}
.dash-acc-sep{border-bottom:1px solid var(--line);margin-bottom:1.5rem}
.dash-thumb{width:130px;height:95px;flex-shrink:0;overflow:hidden;border:1px solid var(--line);display:block;transition:border-color 0.2s}
.dash-thumb:hover{border-color:var(--accent)}
.dash-thumb img{width:100%;height:100%;object-fit:cover;display:block}

/* === LOGIN MODAL === */
.modal-backdrop{position:fixed;inset:0;background:rgba(26,23,20,0.55);backdrop-filter:blur(8px);z-index:9000;opacity:0;visibility:hidden;transition:opacity 0.4s,visibility 0.4s;display:flex;align-items:center;justify-content:center;padding:2rem}
.modal-backdrop.open{opacity:1;visibility:visible}
.modal{background:var(--paper);max-width:460px;width:100%;padding:3rem 2.5rem;position:relative;transform:translateY(30px) scale(0.96);transition:transform 0.5s cubic-bezier(0.7,0,0.3,1);border:1px solid var(--line)}
.modal-backdrop.open .modal{transform:none}
.modal-close{position:absolute;top:1.2rem;right:1.2rem;width:32px;height:32px;border:1px solid var(--line);background:transparent;color:var(--ink);font-size:1rem;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all 0.3s}
.modal-close:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.modal-mark{width:54px;height:54px;border:1px solid var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;color:var(--accent);font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-style:italic}
.modal h2{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:400;text-align:center;line-height:1.1;margin-bottom:0.8rem;letter-spacing:-0.01em}
.modal h2 em{font-style:italic;color:var(--accent)}
.modal-sub{font-size:0.85rem;color:var(--muted);text-align:center;line-height:1.7;margin-bottom:2rem;font-weight:300}
.login-btn{width:100%;padding:0.9rem 1.4rem;background:var(--ink);color:var(--paper);border:none;font-family:'Manrope',sans-serif;font-size:0.78rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:0.7rem;transition:background 0.3s;margin-bottom:1.2rem}
.login-btn:hover{background:var(--accent)}
.login-btn svg{width:18px;height:18px}
.login-or{display:flex;align-items:center;gap:0.8rem;margin:1.2rem 0;color:var(--muted);font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase}
.login-or::before,.login-or::after{content:'';flex:1;height:1px;background:var(--line)}
.login-grid{display:grid;grid-template-columns:1fr 1fr;gap:0.8rem;margin-bottom:1.5rem}
.login-mini{padding:0.8rem;background:transparent;border:1px solid var(--line);font-family:'Manrope',sans-serif;font-size:0.75rem;font-weight:500;letter-spacing:0.08em;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:0.5rem;transition:all 0.3s;color:var(--ink)}
.login-mini:hover{border-color:var(--ink);background:var(--warm)}
.login-mini svg{width:16px;height:16px}
.login-legal{font-size:0.7rem;color:var(--muted);text-align:center;line-height:1.7;font-weight:300}
.login-legal a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}

/* HERO */
/* HERO — DARK DRAMATIC */
.hero{padding-top:64px;display:grid;grid-template-columns:1fr 1fr;min-height:100vh;position:relative;background:var(--ink);color:var(--cream)}
.hero::before{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='n2'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.95  0 0 0 0 0.85  0 0 0 0 0.65  0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n2)' opacity='0.12'/%3E%3C/svg%3E");pointer-events:none;mix-blend-mode:screen;opacity:0.4}
.hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 30% 50%,rgba(184,72,42,0.12) 0%,transparent 60%);pointer-events:none}
.hero-left{padding:5rem 3rem 3rem 3rem;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;border-right:1px solid rgba(232,225,200,0.08);position:relative;z-index:2}
.hero-issue{font-size:0.78rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--gold);margin-bottom:2.5rem;display:flex;align-items:center;gap:1rem}
.hero-issue::before{content:'';width:40px;height:1px;background:var(--gold)}
.hero-issue span{color:var(--accent-soft)}
.hero-h1{font-family:'Cormorant Garamond',serif;font-size:clamp(3.8rem,6vw,6.5rem);font-weight:300;line-height:1;margin-bottom:2rem;letter-spacing:-0.02em;color:var(--cream)}
.hero-h1 .word{display:inline-block;overflow:hidden;vertical-align:bottom}
.hero-h1 .word > span{display:inline-block;transform:translateY(110%);transition:transform 1s cubic-bezier(0.7,0,0.3,1)}
.loaded .hero-h1 .word > span{transform:none}
.hero-h1 .word:nth-child(2) > span{transition-delay:0.1s}
.hero-h1 .word:nth-child(3) > span{transition-delay:0.2s}
.hero-h1 .word:nth-child(4) > span{transition-delay:0.3s}
.hero-h1 em{font-style:italic;color:var(--accent-soft);font-weight:400}
.hero-h1 strong{font-weight:500;color:var(--gold)}
.hero-desc{font-size:1.2rem;color:rgba(248,236,206,0.7);line-height:1.75;max-width:520px;margin-bottom:3rem;font-weight:300;opacity:0;transform:translateY(20px);transition:opacity 1s 0.7s,transform 1s 0.7s}
.loaded .hero-desc{opacity:1;transform:none}

.hero-note{font-size:0.85rem;color:rgba(248,236,206,0.55);letter-spacing:0.04em;line-height:1.5}

.hero-numbers{position:absolute;bottom:3rem;left:3rem;right:3rem;display:flex;gap:3rem;justify-content:center;border-top:1px solid rgba(232,225,200,0.1);padding-top:2rem;opacity:0;transform:translateY(20px);transition:opacity 1s 1.1s,transform 1s 1.1s}
.loaded .hero-numbers{opacity:1;transform:none}
.hnum-n{font-family:'Cormorant Garamond',serif;font-size:2.8rem;font-weight:300;color:var(--cream);line-height:1;letter-spacing:-0.02em}
.hnum-n em{font-style:italic;color:var(--accent-soft)}
.hnum-l{font-size:0.75rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--gold);margin-top:0.5rem;opacity:0.7}

/* HERO RIGHT — PHOTO BEFORE/AFTER */
.hero-actions{display:flex;align-items:center;gap:2rem;opacity:0;transform:translateY(20px);transition:opacity 1s 0.9s,transform 1s 0.9s}
.loaded .hero-actions{opacity:1;transform:none}

.btn-main{position:relative;background:var(--accent);color:var(--cream);padding:1.1rem 2.6rem;font-family:'Manrope',sans-serif;font-size:0.85rem;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;border:none;border-radius:0;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:0.8rem;overflow:hidden;transition:transform 0.3s cubic-bezier(0.7,0,0.3,1)}
.btn-main::before{content:'';position:absolute;inset:0;background:var(--gold);transform:translateY(100%);transition:transform 0.5s cubic-bezier(0.7,0,0.3,1);z-index:0}
.btn-main:hover::before{transform:translateY(0)}
.btn-main:hover{color:var(--ink)}
.btn-main span{position:relative;z-index:1}
.btn-main .arr{position:relative;z-index:1;display:inline-block;transition:transform 0.4s}
.btn-main:hover .arr{transform:translateX(5px)}

.hero-right{background:#1a1310;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:3rem 4rem 3rem 2rem}
.hero-right::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(196,165,118,0.15) 0%,transparent 60%);pointer-events:none;z-index:0}
.hero-right::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:115%;height:115%;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='n3'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.95  0 0 0 0 0.85  0 0 0 0 0.65  0 0 0 0.6 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n3)' opacity='0.15'/%3E%3C/svg%3E");mix-blend-mode:screen;opacity:0.5;pointer-events:none}
.ba-frame{width:100%;max-width:620px;aspect-ratio:3/4;position:relative;overflow:hidden;box-shadow:0 60px 120px -20px rgba(0,0,0,0.6),0 20px 50px -10px rgba(0,0,0,0.4),0 0 0 8px var(--gold),0 0 0 9px rgba(20,16,12,0.5);transform:perspective(1500px) rotateY(-4deg) rotateX(2deg);transition:transform 0.6s cubic-bezier(0.7,0,0.3,1);z-index:2}

.ba-photo{position:absolute;inset:0;background-size:cover;background-position:center}
.ba-photo.before{background-image:url('../images/foto9.jpg')}
.ba-photo.after{background-image:url('../images/foto10.jpg')}

.ba-scratch-overlay{position:absolute;inset:0;pointer-events:none;z-index:1}
.ba-scratch{position:absolute;background:linear-gradient(to bottom,transparent,rgba(255,250,240,0.5),transparent)}

.ba-after-wrap{position:absolute;inset:0;clip-path:inset(0 0 0 60%);transition:clip-path 0.05s}
.ba-line{position:absolute;top:0;bottom:0;left:40%;width:2px;background:linear-gradient(to bottom,transparent,white 10%,white 90%,transparent);z-index:5;transition:left 0.05s;box-shadow:0 0 20px rgba(255,255,255,0.6)}
.ba-handle{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:white;display:flex;align-items:center;justify-content:center;left:-21px;box-shadow:0 4px 20px rgba(0,0,0,0.25);color:var(--ink);user-select:none;transition:transform 0.3s}
.ba-handle:hover{transform:translateY(-50%) scale(1.1)}
.ba-handle svg{width:18px;height:18px}

.ba-labels{position:absolute;bottom:1.4rem;left:0;right:0;display:flex;justify-content:space-between;padding:0 1.4rem;z-index:6;pointer-events:none}
.ba-tag{font-size:0.6rem;letter-spacing:0.25em;text-transform:uppercase;background:rgba(255,255,255,0.95);color:var(--ink);padding:0.4rem 0.8rem;backdrop-filter:blur(10px)}
.ba-tag-accent{color:var(--accent);font-weight:500}
.year-tag{position:absolute;top:1.4rem;left:1.4rem;font-family:'Cormorant Garamond',serif;font-size:0.85rem;font-weight:400;background:rgba(255,255,255,0.95);padding:0.4rem 0.8rem;color:var(--ink2);z-index:6;letter-spacing:0.05em;backdrop-filter:blur(10px)}
.year-tag em{font-style:italic;color:var(--accent)}

/* MARQUEE */
.marquee-strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--ink);overflow:hidden;padding:1rem 0}
.marquee-inner{display:flex;gap:4rem;animation:marquee 30s linear infinite;white-space:nowrap;width:max-content}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-item{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:300;font-style:italic;color:var(--warm);display:flex;align-items:center;gap:1.5rem}
.marquee-item::after{content:'✦';color:var(--accent-soft);font-size:0.9rem;font-style:normal}

/* SECTIONS */
.section{max-width:1320px;margin:0 auto;padding:7rem 3rem;position:relative;z-index:2}
.section-no-top{padding-top:0}
.section-head{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:end;margin-bottom:5rem;border-bottom:1px solid var(--line);padding-bottom:1.8rem}
.section-num{font-family:'Cormorant Garamond',serif;font-size:0.95rem;font-weight:400;color:var(--muted);letter-spacing:0.18em;text-transform:uppercase;margin-bottom:0.8rem;display:flex;align-items:center;gap:0.6rem}
.section-num::before{content:'';width:18px;height:1px;background:var(--accent)}
.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2.8rem,4vw,3.6rem);font-weight:300;line-height:1.05;letter-spacing:-0.02em;color:var(--ink)}
.section-title em{font-style:italic;color:var(--accent);font-weight:400}
.section-sub{font-size:0.88rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);max-width:280px;text-align:right;line-height:1.8}

/* Gallery — DARK DRAMATIC */
#gallery{background:var(--ink);color:var(--cream);padding:7rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);max-width:none;margin:0;position:relative;overflow:hidden}
#gallery::before{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='ng'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.95  0 0 0 0 0.85  0 0 0 0 0.65  0 0 0 0.6 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23ng)' opacity='0.1'/%3E%3C/svg%3E");mix-blend-mode:screen;pointer-events:none;opacity:0.4}
#gallery .section-head{max-width:1320px;margin-left:auto;margin-right:auto;padding:0 3rem 1.8rem;border-color:rgba(232,225,200,0.1)}
#gallery .section-title{color:var(--cream)}
#gallery .section-title em{color:var(--accent-soft)}
#gallery .section-num{color:var(--gold)}
#gallery .section-num::before{background:var(--accent-soft)}
#gallery .section-sub{color:rgba(248,236,206,0.5)}
#gallery .gallery-grid{max-width:1320px;margin:0 auto;padding:0 3rem;position:relative;z-index:2}
.gphoto{box-shadow:0 30px 60px -15px rgba(0,0,0,0.4),0 0 0 1px rgba(196,165,118,0.15)}
.gphoto-info{background:linear-gradient(to top,rgba(20,16,12,0.95),transparent)}
.gphoto-year{color:var(--cream)}
.gphoto-year em{color:var(--accent-soft)}
.gphoto-badge{background:var(--cream);color:var(--ink)}
.gphoto:hover .gphoto-badge{background:var(--accent);color:var(--cream)}

/* === EDITORIAL STEPS (2-COLUMN) === */
.steps-editorial{display:grid;grid-template-columns:0.95fr 1.3fr;gap:5rem;align-items:start;position:relative}
.steps-controls{display:flex;flex-direction:column;gap:0}

.estep{padding:2rem 0;border-top:1px solid var(--line);position:relative}
.estep:first-child{border-top:none;padding-top:0}
.estep-last{padding-bottom:2rem}
.estep-marker{display:flex;align-items:baseline;gap:1.2rem;margin-bottom:0.7rem}
.estep-num{font-family:'Cormorant Garamond',serif;font-size:2.8rem;font-style:italic;font-weight:300;color:var(--accent);line-height:0.9;letter-spacing:-0.02em}
.estep-label{font-size:0.78rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--muted);position:relative;top:-3px}
.estep-title{font-family:'Cormorant Garamond',serif;font-size:1.95rem;font-weight:400;letter-spacing:-0.01em;margin-bottom:1.5rem;line-height:1.1}
.estep-hint{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.2rem;color:var(--ink2);line-height:1.6;font-weight:300}

/* photo selector — horizontal strip */
.estep-photos{display:flex;gap:0.6rem}
.ephoto{width:62px;height:62px;cursor:pointer;position:relative;transition:transform 0.3s}
.ephoto:hover{transform:translateY(-3px)}
.ephoto-img{position:absolute;inset:0;background-size:cover;background-position:center;filter:sepia(0.55) contrast(0.88) brightness(0.92);transition:filter 0.3s}
.ephoto::after{content:'';position:absolute;inset:-4px;border:1px solid transparent;pointer-events:none;transition:border-color 0.3s}
.ephoto.active::after{border-color:var(--accent)}
.ephoto.active .ephoto-img{filter:sepia(0.35) contrast(0.95)}

/* mode selector — text list with markers */
.estep-modes{display:flex;flex-direction:column;gap:0.2rem}
.emode{display:flex;align-items:flex-start;gap:1rem;padding:0.7rem 0;cursor:pointer;transition:opacity 0.3s;position:relative}
.emode:not(.active){opacity:0.55}
.emode:hover{opacity:1}
.emode-dot{width:11px;height:11px;border:1.5px solid var(--ink2);border-radius:50%;margin-top:0.45rem;flex-shrink:0;transition:all 0.3s;position:relative}
.emode.active .emode-dot{border-color:var(--accent);background:var(--accent)}
.emode.active .emode-dot::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:5px;height:5px;background:var(--paper);border-radius:50%}
.emode-title{font-size:1.15rem;font-weight:500;letter-spacing:-0.01em;display:flex;align-items:center;gap:0.6rem;margin-bottom:0.2rem}
.emode-tag{font-size:0.65rem;background:var(--accent);color:white;padding:0.18rem 0.45rem;letter-spacing:0.1em;font-weight:600;border-radius:1px}
.emode-desc{font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-style:italic;color:var(--muted);line-height:1.5;font-weight:300}
.emode.active .emode-desc{color:var(--ink2)}

.estep-privacy{display:flex;align-items:center;gap:0.6rem;padding-top:1.5rem;border-top:1px solid var(--line);font-size:0.85rem;color:var(--muted);letter-spacing:0.04em}

/* big preview */
.steps-preview{position:sticky;top:90px}
.sp-meta{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1rem;font-size:0.68rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted)}
.sp-meta-l em{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--accent);font-size:0.85rem;text-transform:none;letter-spacing:0;margin-left:0.3rem}
.sp-meta-r{font-size:0.65rem}
.sp-frame{position:relative;width:100%;aspect-ratio:4/5;background:var(--warm);overflow:hidden;cursor:ew-resize;box-shadow:0 30px 60px -20px rgba(26,23,20,0.2)}
.sp-before,.sp-after{position:absolute;inset:0;background-size:cover;background-position:center}
.sp-before{background-image:url('../images/foto11.jpg')}
.sp-after{background-image:url('../images/foto12.jpg')}
.sp-after-wrap{position:absolute;inset:0;clip-path:inset(0 0 0 50%);transition:clip-path 0.05s}
.sp-after{filter:contrast(1.08) saturate(1.15) brightness(1.05)}
.sp-line{position:absolute;top:0;bottom:0;left:50%;width:2px;background:white;z-index:3;transition:left 0.05s;box-shadow:0 0 16px rgba(255,255,255,0.5)}
.sp-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:42px;height:42px;border-radius:50%;background:var(--paper);color:var(--ink);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,0.25);user-select:none;cursor:ew-resize;transition:transform 0.2s}
.sp-handle:hover{transform:translate(-50%,-50%) scale(1.1)}
.sp-handle svg{width:20px;height:20px}
.sp-tags{position:absolute;bottom:1rem;left:0;right:0;display:flex;justify-content:space-between;padding:0 1rem;z-index:4;pointer-events:none}
.sp-tag{font-size:0.6rem;letter-spacing:0.25em;text-transform:uppercase;background:rgba(255,255,255,0.95);color:var(--ink);padding:0.35rem 0.7rem;backdrop-filter:blur(8px)}
.sp-tag-a{color:var(--accent);font-weight:500}



/* GALLERY */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.gphoto{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--warm);transform:translateY(0);transition:transform 0.5s cubic-bezier(0.7,0,0.3,1)}
.gphoto:hover{transform:translateY(-8px)}
.gphoto-before,.gphoto-after{position:absolute;inset:0;background-size:cover;background-position:center;transition:opacity 0.6s,filter 0.6s}
.gphoto-before{filter:sepia(0.6) contrast(0.85) brightness(0.92) blur(0.5px);opacity:1;z-index:1}
.gphoto-before::after{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E");mix-blend-mode:multiply;opacity:0.55}
.gphoto-after{filter:contrast(1.08) saturate(1.15) brightness(1.05);opacity:0;z-index:2}
.gphoto:hover .gphoto-before{opacity:0}
.gphoto:hover .gphoto-after{opacity:1}
.gphoto-info{position:absolute;bottom:0;left:0;right:0;padding:1.2rem;background:linear-gradient(to top,rgba(26,23,20,0.85),transparent);color:var(--paper);z-index:3;transform:translateY(100%);transition:transform 0.5s cubic-bezier(0.7,0,0.3,1)}
.gphoto:hover .gphoto-info{transform:translateY(0)}
.gphoto-year{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-style:italic;font-weight:300;margin-bottom:0.3rem}
.gphoto-desc{font-size:0.82rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(245,242,237,0.75)}
.gphoto-badge{position:absolute;top:1rem;right:1rem;font-size:0.6rem;letter-spacing:0.2em;text-transform:uppercase;background:var(--paper);padding:0.3rem 0.6rem;color:var(--ink);z-index:4;transition:all 0.4s}
.gphoto:hover .gphoto-badge{background:var(--accent);color:white}

/* Gallery touch slider (mobile) */
.gphoto-tline{position:absolute;top:0;bottom:0;width:2px;background:rgba(255,255,255,0.85);z-index:5;transform:translateX(-50%);pointer-events:none;box-shadow:0 0 6px rgba(0,0,0,0.4)}
.gphoto-thandle{position:absolute;top:50%;transform:translate(-50%,-50%);width:44px;height:44px;background:white;border-radius:50%;z-index:6;display:flex;align-items:center;justify-content:center;color:var(--ink);box-shadow:0 2px 12px rgba(0,0,0,0.35);pointer-events:none;animation:ghandle-hint 1.8s ease-in-out 0.8s 2}
.gphoto-thandle svg{display:block;flex-shrink:0}
@keyframes ghandle-hint{0%,100%{transform:translate(-50%,-50%)}40%{transform:translate(calc(-50% - 12px),-50%)}60%{transform:translate(calc(-50% + 12px),-50%)}}
.gphoto.touched .gphoto-thandle{animation:none}
@media (hover:none) and (pointer:coarse){
  .gphoto:hover{transform:none}
  .gphoto:hover .gphoto-before{opacity:1}
  .gphoto:hover .gphoto-after{opacity:1}
  .gphoto:hover .gphoto-info{transform:translateY(100%)}
  .gphoto:hover .gphoto-badge{background:var(--paper);color:var(--ink)}
  .gphoto-after{opacity:1;clip-path:inset(0 0 0 50%)}
  .gphoto-info{transform:translateY(0)!important;background:linear-gradient(to top,rgba(26,23,20,0.75),transparent)}
}

/* UPLOAD */
.upload-section{background:linear-gradient(180deg,var(--warm) 0%,var(--pale) 100%);border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.upload-section::before{content:'';position:absolute;top:-100px;left:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(184,72,42,0.08),transparent 70%);pointer-events:none}
.upload-section::after{content:'';position:absolute;bottom:-150px;right:-100px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(196,165,118,0.12),transparent 70%);pointer-events:none}
.upload-inner{max-width:1320px;margin:0 auto;padding:7rem 3rem;position:relative}
.upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.upload-copy .big-num{font-family:'Cormorant Garamond',serif;font-size:9rem;font-weight:300;color:rgba(168,52,31,0.15);line-height:0.8;margin-bottom:1rem;font-style:italic}
.upload-copy h2{font-family:'Cormorant Garamond',serif;font-size:clamp(2.4rem,3.2vw,3.2rem);font-weight:300;line-height:1.15;margin-bottom:1.5rem;letter-spacing:-0.02em}
.upload-copy h2 em{font-style:italic;color:var(--accent);font-weight:400}
.upload-copy p{font-size:1.05rem;color:var(--ink2);line-height:1.85;font-weight:300;max-width:460px}
.upload-copy .features-mini{margin-top:2rem;display:flex;flex-direction:column;gap:0.9rem}
.fmini{display:flex;align-items:center;gap:0.8rem;font-size:0.95rem;color:var(--ink2)}
.fmini::before{content:'';width:6px;height:6px;background:var(--accent);border-radius:50%;flex-shrink:0}

.dz{border:2px dashed var(--line2);background:var(--paper);padding:3rem 2.5rem;transition:all 0.4s;position:relative;overflow:hidden}
.dz.drag,.dz:hover{border-color:var(--accent);background:#fff}
.dz-inner{text-align:center}
.dz-icon{width:60px;height:60px;margin:0 auto 1.5rem;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--muted);transition:all 0.4s}
.dz:hover .dz-icon{border-color:var(--accent);color:var(--accent);transform:rotate(180deg)}
.dz h3{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:400;margin-bottom:0.5rem}
.dz p{font-size:0.85rem;color:var(--muted);line-height:1.7}
.dz-link{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.format-row{display:flex;gap:0.5rem;margin-top:1.5rem;flex-wrap:wrap;justify-content:center}
.ftag{font-size:0.6rem;letter-spacing:0.18em;text-transform:uppercase;border:1px solid var(--line);padding:0.3rem 0.7rem;color:var(--muted);background:var(--paper)}

.preview-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.5rem}
.pbox{background:var(--paper);border:1px solid var(--line);position:relative;min-height:240px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.pbox img{width:100%;height:100%;object-fit:contain;display:block}
.pbox-tag{position:absolute;bottom:0.8rem;left:0.8rem;font-size:0.6rem;letter-spacing:0.2em;text-transform:uppercase;background:rgba(250,248,244,0.95);padding:0.3rem 0.6rem;color:var(--muted);backdrop-filter:blur(8px)}
.pbox-tag.a{color:var(--accent);font-weight:500}
.pbox-placeholder{font-size:0.7rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted)}

.process-btn{width:100%;background:var(--ink);color:var(--paper);border:none;padding:1.1rem 2rem;font-family:'Manrope',sans-serif;font-size:0.76rem;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;margin-top:1.2rem;cursor:pointer;transition:background 0.3s;position:relative;overflow:hidden}
.process-btn:hover:not(:disabled){background:var(--accent)}
.process-btn:disabled{opacity:0.35;cursor:not-allowed}

.prog-wrap{height:1px;background:var(--line);margin-top:1.4rem;overflow:hidden;display:none}
.prog-fill{height:100%;background:var(--accent);width:0%;transition:width 0.5s}
.status{font-size:0.68rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--accent);margin-top:0.7rem;min-height:1.2em;font-weight:500}

.result-card{border:1px solid var(--line);background:var(--paper);padding:1.6rem;margin-top:1.4rem;font-size:0.84rem;color:var(--ink2);line-height:2}
.result-card b{color:var(--ink);font-weight:500}

.btn-row{display:flex;gap:0.8rem;margin-top:1rem;flex-wrap:wrap}
.dl-btn{background:var(--accent);color:#fff;border:none;padding:0.8rem 1.8rem;font-family:'Manrope',sans-serif;font-size:0.72rem;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;cursor:pointer;transition:background 0.3s}
.dl-btn:hover{background:var(--ink)}
.rs-btn{background:transparent;color:var(--muted);border:1px solid var(--line);padding:0.8rem 1.5rem;font-family:'Manrope',sans-serif;font-size:0.72rem;letter-spacing:0.15em;text-transform:uppercase;cursor:pointer;transition:all 0.3s}
.rs-btn:hover{color:var(--ink);border-color:var(--ink)}
.hidden{display:none!important}

/* FEATURES */
.features-list{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line)}
.feat{padding:3rem 2.8rem 3.5rem;border-right:1px solid var(--line);border-bottom:none;transition:background 0.4s;position:relative;overflow:hidden}
.feat:last-child{border-right:none}
.feat::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform 0.5s cubic-bezier(0.7,0,0.3,1)}
.feat:hover{background:var(--warm)}
.feat:hover::after{transform:scaleX(1)}
.feat-label{font-family:'Cormorant Garamond',serif;font-size:5.5rem;font-weight:300;font-style:italic;color:var(--accent);line-height:0.85;margin-bottom:2rem;opacity:0.75;letter-spacing:-0.02em}
.feat h3{font-size:1.1rem;font-weight:500;margin-bottom:0.9rem;line-height:1.35;letter-spacing:0.005em}
.feat p{font-size:0.95rem;color:var(--ink2);line-height:1.85;font-weight:300}

/* REVIEWS */
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.review{border:1px solid var(--line);padding:2.2rem;position:relative;transition:all 0.4s;background:var(--paper)}
.review:hover{background:var(--warm);transform:translateY(-4px)}
.review-stars{color:var(--accent);font-size:0.7rem;letter-spacing:0.2em;margin-bottom:1rem}
.review-q-mark{font-family:'Cormorant Garamond',serif;font-size:3rem;font-style:italic;color:var(--accent);line-height:0.5;margin-bottom:0.5rem;opacity:0.4}
.review q{font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:300;font-style:italic;line-height:1.55;color:var(--ink);display:block;margin-bottom:1.3rem;quotes:none}
.review q::before,.review q::after{content:''}
.review-who{display:flex;align-items:center;gap:0.9rem;padding-top:1rem;border-top:1px solid var(--line)}
.review-av{width:36px;height:36px;border-radius:50%;background:var(--warm);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:0.7rem;font-weight:600;color:var(--accent);flex-shrink:0;font-family:'Manrope',sans-serif}
.review-name{font-size:0.85rem;font-weight:500}
.review-city{font-size:0.72rem;color:var(--muted);margin-top:0.1rem}

/* CTA — DRAMATIC */
.cta-block{background:var(--ink);text-align:center;padding:9rem 3rem;position:relative;overflow:hidden}
.cta-block::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:900px;height:900px;border-radius:50%;background:radial-gradient(circle,rgba(184,72,42,0.2),transparent 60%);pointer-events:none}
.cta-block::after{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='nc'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.95  0 0 0 0 0.85  0 0 0 0 0.65  0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23nc)' opacity='0.1'/%3E%3C/svg%3E");mix-blend-mode:screen;opacity:0.4;pointer-events:none}
.cta-content{position:relative;z-index:1;max-width:800px;margin:0 auto}
.cta-block .cta-pretitle{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--gold);font-size:1.3rem;margin-bottom:1.5rem;letter-spacing:0.02em;opacity:0.85}
.cta-block h2{font-family:'Cormorant Garamond',serif;font-size:clamp(2.8rem,5vw,4.2rem);font-weight:300;color:var(--cream);line-height:1.1;margin-bottom:1.5rem;letter-spacing:-0.02em}
.cta-block h2 em{font-style:italic;color:var(--accent-soft);font-weight:400}
.cta-block p{color:rgba(248,236,206,0.55);margin-bottom:2.8rem;font-size:1.05rem;font-weight:300;line-height:1.8}
.cta-btn{background:var(--accent);color:var(--cream);padding:1.15rem 3.2rem;border:none;font-family:'Manrope',sans-serif;font-size:0.85rem;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;cursor:pointer;transition:all 0.4s;text-decoration:none;display:inline-flex;align-items:center;gap:0.8rem;position:relative;overflow:hidden}
.cta-btn::before{content:'';position:absolute;inset:0;background:var(--gold);transform:translateY(100%);transition:transform 0.5s cubic-bezier(0.7,0,0.3,1)}
.cta-btn:hover::before{transform:translateY(0)}
.cta-btn:hover{color:var(--ink)}
.cta-btn span{position:relative;z-index:1}

/* FOOTER */
footer{border-top:1px solid var(--line);display:grid;grid-template-columns:auto 1fr auto;align-items:center;padding:2.5rem 3rem;gap:2rem}
.foot-logo{font-family:'Cormorant Garamond',serif;font-size:1.1rem;letter-spacing:0.15em;text-transform:uppercase;font-weight:500}
.foot-sup{font-size:0.5rem;color:var(--accent)}
.foot-links{display:flex;gap:2rem;justify-content:center}
.foot-links a{font-size:0.7rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color 0.3s}
.foot-links a:hover{color:var(--ink)}
.foot-copy{font-size:0.65rem;color:var(--muted);letter-spacing:0.1em;font-family:'Cormorant Garamond',serif;font-style:italic}

/* === PRICING === */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:0}
.tier{background:var(--paper);border:1px solid var(--line);padding:2.5rem 2rem;position:relative;transition:all 0.4s;display:flex;flex-direction:column}
.tier:hover{transform:translateY(-6px);box-shadow:0 30px 60px -20px rgba(26,23,20,0.15)}
.tier-name{font-size:0.78rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--muted);margin-bottom:1.5rem}
.tier-price{font-family:'Cormorant Garamond',serif;font-size:3.4rem;font-weight:300;line-height:1;margin-bottom:0.3rem;letter-spacing:-0.02em}
.tier-price em{font-style:italic;color:var(--accent);font-size:2.2rem}
.tier-credits{font-size:0.88rem;color:var(--muted);letter-spacing:0.04em;padding-bottom:1.2rem;margin-bottom:1.2rem;border-bottom:1px solid var(--line)}
.tier-desc{font-size:0.95rem;color:var(--ink2);line-height:1.6;margin-bottom:1.5rem;font-weight:300;font-style:italic;font-family:'Cormorant Garamond',serif;font-size:1.15rem}
.tier-list{list-style:none;margin-bottom:2rem;flex:1}
.tier-list li{font-size:0.95rem;color:var(--ink2);padding:0.5rem 0;display:flex;align-items:center;gap:0.6rem;font-weight:300}
.tier-list li::before{content:'';width:5px;height:5px;background:var(--accent);border-radius:50%;flex-shrink:0}
.tier-btn{width:100%;padding:0.95rem 1.5rem;background:transparent;color:var(--ink);border:1px solid var(--ink);font-family:'Manrope',sans-serif;font-size:0.78rem;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;cursor:pointer;transition:all 0.3s;text-decoration:none;display:block;text-align:center}
.tier-btn:hover{background:var(--ink);color:var(--paper)}
.tier.featured{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.tier.featured .tier-name{color:var(--accent-soft)}
.tier.featured .tier-credits{color:rgba(245,242,237,0.5);border-color:rgba(245,242,237,0.15)}
.tier.featured .tier-desc{color:rgba(245,242,237,0.7)}
.tier.featured .tier-list li{color:rgba(245,242,237,0.85)}
.tier.featured .tier-list li::before{background:var(--accent-soft)}
.tier.featured .tier-btn{background:var(--accent);border-color:var(--accent);color:#fff}
.tier.featured .tier-btn:hover{background:var(--accent2);border-color:var(--accent2)}
.tier-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:white;font-size:0.6rem;letter-spacing:0.25em;text-transform:uppercase;padding:0.35rem 0.9rem;font-weight:500}

/* === FAQ === */
.faq-wrap{display:grid;grid-template-columns:1fr 1.5fr;gap:4rem;align-items:start}
.faq-intro p{font-size:1.05rem;color:var(--ink2);line-height:1.85;font-weight:300;max-width:360px}
.faq-list{display:flex;flex-direction:column;gap:0.7rem}
.faq-item{border:1px solid var(--line);background:var(--paper);overflow:hidden;transition:all 0.3s}
.faq-item:hover{border-color:var(--line2)}
.faq-item.open{border-color:var(--accent)}
.faq-q{padding:1.5rem 1.7rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:1.05rem;font-weight:500;color:var(--ink);transition:color 0.3s}
.faq-item.open .faq-q{color:var(--accent)}
.faq-arr{width:30px;height:30px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.8rem;transition:all 0.3s;flex-shrink:0;color:var(--muted)}
.faq-item.open .faq-arr{background:var(--accent);border-color:var(--accent);color:white;transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height 0.5s cubic-bezier(0.7,0,0.3,1)}
.faq-item.open .faq-a{max-height:300px}
.faq-a-inner{padding:0 1.7rem 1.5rem;font-size:0.98rem;color:var(--ink2);line-height:1.8;font-weight:300}

/* === EDITORIAL FOOTER === */
.footer-big{background:var(--ink);color:var(--paper);padding:5rem 3rem 2rem;border-top:1px solid var(--line);position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center}
.footer-big::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--accent-soft) 30%,var(--accent-soft) 70%,transparent)}
.footer-inner{width:100%;max-width:1320px;text-align:center}
.footer-top{display:flex;flex-direction:column;align-items:center;gap:1.8rem;padding-bottom:3.5rem;border-bottom:1px solid rgba(245,242,237,0.08)}
.footer-brand{display:flex;flex-direction:column;align-items:center}
.footer-brand .foot-logo-big{font-family:'Cormorant Garamond',serif;font-size:2.6rem;font-weight:400;letter-spacing:0.08em;text-transform:uppercase;color:var(--paper);margin-bottom:0.6rem;line-height:1}
.footer-brand .foot-logo-big sup{color:var(--accent-soft);font-size:0.6rem;letter-spacing:0.2em}
.footer-tag{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.4rem;color:var(--accent-soft);font-weight:300;margin-bottom:1.2rem;line-height:1.4}
.footer-brand p{font-size:0.88rem;color:rgba(245,242,237,0.5);line-height:1.85;max-width:440px;font-weight:300;text-align:center}

.footer-contact{display:flex;flex-direction:column;align-items:center;gap:0.5rem;margin-top:0.5rem}
.footer-contact-label{font-size:0.65rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--accent-soft)}
.footer-contact-mail{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:400;color:var(--paper);text-decoration:none;letter-spacing:-0.01em;transition:color 0.3s;display:inline-block}
.footer-contact-mail:hover{color:var(--accent-soft)}
.footer-contact-mail em{font-style:italic;color:var(--accent-soft)}

.footer-links-row{display:flex;flex-wrap:wrap;justify-content:center;gap:0.5rem 2.2rem;padding:2.5rem 0;border-bottom:1px solid rgba(245,242,237,0.08)}
.footer-links-row a{color:rgba(245,242,237,0.65);text-decoration:none;font-size:0.78rem;letter-spacing:0.12em;text-transform:uppercase;transition:color 0.3s;position:relative}
.footer-links-row a:hover{color:var(--paper)}
.footer-links-row a:not(:last-child)::after{content:'·';position:absolute;right:-1.3rem;color:rgba(245,242,237,0.25);pointer-events:none}

.footer-legal{display:flex;flex-wrap:wrap;justify-content:center;gap:0.5rem 1.8rem;padding-top:1.5rem;margin-bottom:2rem}
.footer-legal a{color:rgba(245,242,237,0.4);text-decoration:none;font-size:0.7rem;letter-spacing:0.05em;transition:color 0.3s}
.footer-legal a:hover{color:rgba(245,242,237,0.7)}

.footer-bottom{display:flex;justify-content:center;align-items:center;font-size:0.7rem;color:rgba(245,242,237,0.35);letter-spacing:0.08em;padding-top:1rem}
.footer-bottom em{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:0.9rem;color:rgba(245,242,237,0.5)}
.reveal{opacity:0;transform:translateY(40px);transition:opacity 0.9s cubic-bezier(0.7,0,0.3,1),transform 0.9s cubic-bezier(0.7,0,0.3,1)}
.reveal.on{opacity:1;transform:none}
.reveal-stagger > *{opacity:0;transform:translateY(30px);transition:opacity 0.8s cubic-bezier(0.7,0,0.3,1),transform 0.8s cubic-bezier(0.7,0,0.3,1)}
.reveal-stagger.on > *{opacity:1;transform:none}
.reveal-stagger.on > *:nth-child(1){transition-delay:0s}
.reveal-stagger.on > *:nth-child(2){transition-delay:0.12s}
.reveal-stagger.on > *:nth-child(3){transition-delay:0.24s}
.reveal-stagger.on > *:nth-child(4){transition-delay:0.36s}
.reveal-stagger.on > *:nth-child(5){transition-delay:0.48s}
.reveal-stagger.on > *:nth-child(6){transition-delay:0.6s}

@media (max-width:900px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-left{padding:5rem 2rem 4rem;border-right:none;border-bottom:1px solid var(--line)}
  .hero-numbers{position:relative;bottom:auto;left:auto;right:auto;margin-top:3rem}
  .hero-right{padding:3rem 2rem;min-height:60vh}
  .section{padding:4rem 2rem}
  .upload-inner{padding:4rem 2rem}
  .section-head{grid-template-columns:1fr}
  .section-sub{text-align:left;max-width:none}
  .process-row,.upload-grid,.features-list,.gallery-grid,.review-grid,.pricing-grid,.faq-wrap,.steps-editorial{grid-template-columns:1fr}
  .steps-editorial{gap:2rem}
  .steps-preview{position:relative;top:0}
  .footer-top{gap:2rem}
  .footer-bottom{flex-direction:column;gap:1rem;text-align:center}
  .dashboard-inner{padding:5rem 1.5rem 3rem}
  .dash-header{flex-direction:column;align-items:flex-start;gap:1rem}
  .dash-identity{grid-template-columns:auto 1fr;gap:2rem;row-gap:1.5rem}
  .dash-identity-badge{border:none;border-top:1px solid rgba(196,165,118,0.1);padding:1rem 0;grid-column:1/-1}
  .dash-identity-balance{text-align:left;grid-column:1/-1;border-top:1px solid rgba(196,165,118,0.1);padding-top:1rem}
  .dash-body{gap:0}
  .dash-section--wide{padding:1.5rem 0 2rem}
  .dash-section--account{padding:1.5rem 0 0}
  .dash-thumb{width:100px;height:75px}
  .pcard,.feat{border-right:none!important;border-bottom:1px solid var(--line)!important}
  .pcard:last-child,.feat:last-child{border-bottom:none!important}
  .topbar{padding:0 1.5rem}
  .nav-links{gap:0.6rem}
  .nav-links li:not(:last-child):not(.nav-li-theme):not(.nav-li-login){display:none}
  .nav-login{padding:0.45rem 0.9rem!important;font-size:0.73rem}
  footer{grid-template-columns:1fr;text-align:center}
  .foot-links{flex-wrap:wrap;justify-content:center}
  *{cursor:auto!important}
  #cursor{display:none}
}

/* ===== THEME TOGGLE BUTTON ===== */
.theme-toggle{background:transparent;border:none;display:flex;align-items:center;gap:0.45rem;cursor:pointer;padding:0.2rem 0;outline:none}
.tt-sun,.tt-moon{font-size:0.72rem;line-height:1;transition:opacity 0.35s,color 0.35s}
.tt-sun{color:var(--gold);opacity:1}
.tt-moon{color:rgba(248,236,206,0.4);opacity:0.4}
.topbar.light .tt-sun{color:var(--accent);opacity:1}
.topbar.light .tt-moon{color:var(--muted);opacity:0.45}
.tt-track{width:36px;height:20px;border:1px solid rgba(232,225,200,0.28);border-radius:10px;position:relative;transition:border-color 0.35s;flex-shrink:0}
.topbar.light .tt-track{border-color:var(--line2)}
.tt-thumb{position:absolute;top:3px;left:3px;width:12px;height:12px;border-radius:50%;background:rgba(232,225,200,0.85);transition:transform 0.35s cubic-bezier(0.7,0,0.3,1),background 0.35s}
.topbar.light .tt-thumb{background:var(--ink)}
body.dark .tt-thumb{transform:translateX(16px);background:var(--gold)}
body.dark .tt-sun{opacity:0.35}
body.dark .tt-moon{opacity:1;color:var(--gold)}
body.dark .topbar .tt-track,body.dark .topbar.light .tt-track{border-color:rgba(237,226,196,0.25)}
body.dark .topbar .tt-thumb,body.dark .topbar.light .tt-thumb{background:var(--gold)}

/* ===== DARK THEME ===== */
body.dark{background:#1c1710;color:#ede2c4;transition:background 0.4s,color 0.4s}

/* Topbar stays dark in dark mode */
body.dark .topbar,
body.dark .topbar.light{background:rgba(18,14,9,0.96)!important;border-bottom-color:rgba(237,226,196,0.07)!important}
body.dark .topbar .logo,
body.dark .topbar.light .logo{color:var(--cream)!important}
body.dark .topbar .nav-links a,
body.dark .topbar.light .nav-links a{color:rgba(248,236,206,0.5)!important}
body.dark .topbar .nav-links a:hover,
body.dark .topbar.light .nav-links a:hover{color:var(--cream)!important}
body.dark .topbar .nav-login,
body.dark .topbar.light .nav-login{border-color:rgba(232,225,200,0.2)!important;color:var(--cream)!important}
body.dark .nav-dropdown{background:#231d12;border-color:rgba(237,226,196,0.1);box-shadow:0 20px 40px -10px rgba(0,0,0,0.5)}
body.dark .nav-dropdown a{color:rgba(237,226,196,0.7)}
body.dark .nav-dropdown a:hover{background:rgba(237,226,196,0.06);color:var(--cream)}
body.dark .nav-dd-sep{background:rgba(237,226,196,0.08)}
body.dark .nav-avatar{border-color:rgba(237,226,196,0.2);color:var(--cream)}
body.dark .nav-avatar-letter{background:rgba(237,226,196,0.1);color:var(--cream)}

/* Sections */
body.dark .section{background:#1c1710}
body.dark .section-label{color:rgba(237,226,196,0.35)}
body.dark .section-title{color:#ede2c4}
body.dark .section-sub{color:rgba(237,226,196,0.5)}

/* Process */
body.dark .process-item{border-color:rgba(237,226,196,0.08)!important}
body.dark .proc-num{color:rgba(237,226,196,0.07)}
body.dark .proc-t{color:#ede2c4}
body.dark .proc-d{color:rgba(237,226,196,0.5)}

/* Upload */
body.dark .upload-section{background:#1a1410;border-color:rgba(237,226,196,0.07)!important}
body.dark .upload-section::before,body.dark .upload-section::after{display:none}
body.dark .upload-inner{border-color:rgba(237,226,196,0.06)!important}
body.dark .upload-copy p{color:rgba(237,226,196,0.55)}
body.dark .fmini{color:rgba(237,226,196,0.55)}
body.dark .dz{border-color:rgba(237,226,196,0.15);background:rgba(237,226,196,0.02)}
body.dark .dz h3{color:#ede2c4}
body.dark .dz p{color:rgba(237,226,196,0.4)}
body.dark .dz-icon{border-color:rgba(237,226,196,0.15);color:rgba(237,226,196,0.35)}
body.dark .dz-main{color:#ede2c4}
body.dark .dz-sub{color:rgba(237,226,196,0.45)}
body.dark .proc-bar-bg{background:rgba(237,226,196,0.08)}

/* Features */
body.dark .features-list{border-color:rgba(237,226,196,0.08)}
body.dark .feat{border-color:rgba(237,226,196,0.08)!important}
body.dark .feat h3{color:#ede2c4}
body.dark .feat p{color:rgba(237,226,196,0.5)}
body.dark .feat:hover{background:rgba(237,226,196,0.04)}

/* Steps editorial */
body.dark .steps-editorial{background:#1c1710}
body.dark .estep-label{color:rgba(237,226,196,0.35)}
body.dark .estep-title{color:#ede2c4}
body.dark .estep-desc{color:rgba(237,226,196,0.5)}
body.dark .ephoto{border-color:rgba(237,226,196,0.12)!important}
body.dark .ephoto.active{border-color:var(--accent)!important}
body.dark .emode-title{color:#ede2c4}
body.dark .emode-desc{color:rgba(237,226,196,0.45)}
body.dark .sp-counter{color:rgba(237,226,196,0.4)}
body.dark .sp-counter em{color:var(--accent-soft)}
body.dark .sp-hint{color:rgba(237,226,196,0.35)}

/* Reviews */
body.dark .review{border-color:rgba(237,226,196,0.08);background:#211b11}
body.dark .review:hover{background:rgba(237,226,196,0.05)}
body.dark .review q{color:rgba(237,226,196,0.85)}
body.dark .review-text{color:rgba(237,226,196,0.7)}
body.dark .review-name{color:#ede2c4}
body.dark .review-meta{color:rgba(237,226,196,0.4)}
body.dark .review-city{color:rgba(237,226,196,0.4)}
body.dark .review-who{border-color:rgba(237,226,196,0.08)}
body.dark .review-av{background:rgba(237,226,196,0.06);border-color:rgba(237,226,196,0.1)}

/* Pricing */
body.dark .tier{background:#211b11;border-color:rgba(237,226,196,0.08)!important}
body.dark .tier:hover{transform:translateY(-6px);box-shadow:0 30px 60px -20px rgba(0,0,0,0.4)}
body.dark .tier-name{color:rgba(237,226,196,0.45)}
body.dark .tier-price{color:#ede2c4}
body.dark .tier-price em{color:var(--accent-soft)}
body.dark .tier-credits{color:rgba(237,226,196,0.35);border-color:rgba(237,226,196,0.08)}
body.dark .tier-desc{color:rgba(237,226,196,0.5)}
body.dark .tier-list li{color:rgba(237,226,196,0.6)}
body.dark .tier-btn{border-color:rgba(237,226,196,0.2);color:#ede2c4;background:transparent}
body.dark .tier-btn:hover{background:#ede2c4;color:var(--ink)}
body.dark .tier.featured{background:var(--accent);border-color:var(--accent)!important}
body.dark .tier.featured .tier-name{color:rgba(255,255,255,0.7)}
body.dark .tier.featured .tier-btn{background:rgba(255,255,255,0.15);border-color:transparent;color:white}
body.dark .tier.featured .tier-btn:hover{background:white;color:var(--accent)}
body.dark .pricing-note{color:rgba(237,226,196,0.4)}

/* FAQ */
body.dark .faq-item{background:#211b11;border-color:rgba(237,226,196,0.08)}
body.dark .faq-item:hover{border-color:rgba(237,226,196,0.18)}
body.dark .faq-intro p{color:rgba(237,226,196,0.5)}
body.dark .faq-q{color:#ede2c4}
body.dark .faq-arr{border-color:rgba(237,226,196,0.15);color:rgba(237,226,196,0.4)}
body.dark .faq-a-inner{color:rgba(237,226,196,0.55)}

/* Dashboard */
body.dark .dashboard{background:#1c1710;color:#ede2c4}
body.dark .dash-header{border-color:rgba(237,226,196,0.1)}
body.dark .dash-crumb{color:rgba(237,226,196,0.45)}
body.dark .dash-close{border-color:rgba(237,226,196,0.15);color:rgba(237,226,196,0.5)}
body.dark .dash-close:hover{background:#ede2c4;color:var(--ink);border-color:#ede2c4}
body.dark .dash-identity{border-color:rgba(237,226,196,0.08)}
body.dark .dash-identity-label{color:rgba(237,226,196,0.4)}
body.dark .dash-identity-name{color:#ede2c4}
body.dark .dash-identity-email{color:rgba(237,226,196,0.4)}
body.dark .dash-identity-badge{border-color:rgba(237,226,196,0.1)}
body.dark .dash-pro-sub{color:rgba(237,226,196,0.4)}
body.dark .dash-balance-n{color:#ede2c4}
body.dark .dash-balance-label{color:rgba(237,226,196,0.45)}
body.dark .dash-section--wide{border-color:rgba(237,226,196,0.08)}
body.dark .dash-acc-sep{border-color:rgba(237,226,196,0.08)}
body.dark .dash-thumb{border-color:rgba(237,226,196,0.1)}
body.dark .dash-thumb:hover{border-color:var(--accent)}
body.dark .dash-section-title{color:#ede2c4;border-color:rgba(237,226,196,0.1)}
body.dark .dash-new-project{background:var(--accent);color:var(--paper);box-shadow:0 8px 24px -6px rgba(184,72,42,0.35)}
body.dark .dash-new-project::before{background:#ede2c4}
body.dark .dash-new-project:hover{color:var(--ink)}
body.dark .dash-empty-note{color:rgba(237,226,196,0.35)}
body.dark .dash-all-link{color:rgba(237,226,196,0.45)}
body.dark .dash-row{border-color:rgba(237,226,196,0.08)}
body.dark .dash-row-label{color:rgba(237,226,196,0.5)}
body.dark .dash-row-value{color:rgba(237,226,196,0.75)}
body.dark .dash-row-action{border-color:rgba(237,226,196,0.15);color:rgba(237,226,196,0.5)}
body.dark .dash-row-action:hover{border-color:#ede2c4;color:#ede2c4}
body.dark .dash-logout{color:rgba(237,226,196,0.35)}

/* Modal */
body.dark .modal{background:#231d12;border-color:rgba(237,226,196,0.1)}
body.dark .modal-close{border-color:rgba(237,226,196,0.15);color:#ede2c4}
body.dark .modal h2{color:#ede2c4}
body.dark .modal-sub{color:rgba(237,226,196,0.55)}
body.dark .modal-mark{border-color:var(--accent);color:var(--accent-soft)}
body.dark .login-btn{background:#ede2c4;color:var(--ink)}
body.dark .login-mini{border-color:rgba(237,226,196,0.15);color:#ede2c4}

/* Scrollbar */
body.dark ::-webkit-scrollbar-track{background:#1c1710}
body.dark ::-webkit-scrollbar-thumb{background:rgba(237,226,196,0.15)}

/* ===== PROJECT PAGE ===== */
.proj-page{position:fixed;inset:0;background:var(--cream);z-index:250;overflow-y:auto;opacity:0;visibility:hidden;transition:opacity 0.45s,visibility 0.45s}
.proj-page.open{opacity:1;visibility:visible}
.proj-page-inner{max-width:1160px;margin:0 auto;padding:2rem 3rem 5rem}

.proj-header{display:flex;align-items:center;justify-content:space-between;padding:1.4rem 0 2.2rem;border-bottom:1px solid var(--line);margin-bottom:3rem}
.proj-back{background:transparent;border:1px solid var(--line);padding:0.55rem 1.4rem;font-size:0.7rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);cursor:pointer;font-family:'Manrope',sans-serif;transition:all 0.3s}
.proj-back:hover{border-color:var(--ink);color:var(--ink)}
.proj-header-title{font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:300;font-style:italic;letter-spacing:0.2em;color:var(--ink2)}

.proj-layout{display:grid;grid-template-columns:400px 1fr;gap:2rem;align-items:start}
.proj-left{display:flex;flex-direction:column;gap:2rem}

.proj-card{background:var(--paper);border:1px solid var(--line);padding:2.5rem 2.8rem;position:relative;overflow:hidden}
.proj-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform 0.55s cubic-bezier(0.7,0,0.3,1)}
.proj-card:hover::before{transform:scaleX(1)}
.proj-card-top{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:1.8rem;padding-bottom:1.4rem;border-bottom:1px solid var(--line)}
.proj-card-h{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:400;color:var(--ink);letter-spacing:-0.01em;line-height:1}
.proj-card-n{font-family:'Cormorant Garamond',serif;font-size:4.5rem;font-weight:300;font-style:italic;color:rgba(20,16,12,0.09);line-height:0.85;flex-shrink:0}

.proj-thumbs{display:flex;flex-wrap:wrap;gap:0.75rem;min-height:84px;margin-bottom:1.2rem}
.proj-add-btn{width:84px;height:84px;border:1.5px dashed rgba(20,16,12,0.2);background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0.3rem;cursor:pointer;font-size:0.65rem;letter-spacing:0.08em;color:var(--muted);transition:all 0.3s;font-family:'Manrope',sans-serif}
.proj-add-btn:hover{border-color:var(--accent);color:var(--accent)}
.proj-add-plus{font-size:1.8rem;font-weight:200;line-height:1;color:var(--accent)}
.proj-thumb-wrap{position:relative;width:84px;height:84px;flex-shrink:0}
.proj-thumb-wrap img{width:100%;height:100%;object-fit:cover;display:block;border:1px solid var(--line)}
.proj-thumb-num{position:absolute;bottom:0;right:0;width:18px;height:18px;background:var(--ink);color:var(--paper);font-size:0.58rem;display:flex;align-items:center;justify-content:center;font-weight:600}
.proj-file-info{font-size:0.78rem;color:var(--muted);font-weight:300;margin-bottom:0.4rem;letter-spacing:0.02em}
.proj-file-count{display:flex;align-items:center;gap:0.5rem;font-size:0.78rem;color:var(--muted)}
.proj-dot{opacity:0.35}
.proj-clear-btn{background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:0.78rem;font-family:'Manrope',sans-serif;text-decoration:underline;text-underline-offset:3px;transition:color 0.2s;padding:0}
.proj-clear-btn:hover{color:var(--accent)}

.proj-mode-label{font-size:0.65rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem;font-weight:500}
.proj-modes{display:flex;border:1px solid var(--line);margin-bottom:1.8rem}
.proj-mode-btn{flex:1;padding:0.75rem 0.5rem;background:transparent;border:none;border-right:1px solid var(--line);font-size:0.73rem;font-family:'Manrope',sans-serif;color:var(--muted);cursor:pointer;transition:all 0.2s;letter-spacing:0.04em;white-space:nowrap}
.proj-mode-btn:last-child{border-right:none}
.proj-mode-btn.active{background:var(--ink);color:var(--paper)}
.proj-mode-btn:not(.active):hover{background:var(--pale);color:var(--ink)}
.proj-mode-info{background:var(--warm);padding:1.2rem 1.5rem;margin-bottom:2rem;border-left:2px solid var(--accent)}
.proj-mode-info-label{font-size:0.6rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--accent);margin-bottom:0.5rem;font-weight:500}
.proj-mode-info p{font-size:0.88rem;color:var(--ink2);line-height:1.75;font-weight:300}
.proj-start-btn{width:100%;padding:1.1rem;background:var(--ink);color:var(--paper);border:none;font-family:'Manrope',sans-serif;font-size:0.75rem;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;cursor:pointer;transition:all 0.3s}
.proj-start-btn:hover:not(:disabled){background:var(--accent)}
.proj-start-btn:disabled{background:rgba(20,16,12,0.15);color:var(--muted);cursor:not-allowed}

.proj-results-card{min-height:480px;display:flex;flex-direction:column}
.proj-results-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.2rem;padding:3rem 2rem}
.proj-results-empty::before{content:'✦';font-family:'Cormorant Garamond',serif;font-size:1.8rem;color:var(--accent);opacity:0.25;display:block}
.proj-results-empty p{font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-style:italic;font-weight:300;color:rgba(20,16,12,0.3);text-align:center;line-height:1.6}
.proj-results-processing{flex:1;display:none;flex-direction:column;align-items:center;justify-content:center;gap:1.4rem}
.proj-sparkle{font-size:2.2rem;color:var(--gold);animation:proj-sparkle 1.6s ease-in-out infinite}
@keyframes proj-sparkle{0%,100%{opacity:0.35;transform:scale(0.85) rotate(0deg)}50%{opacity:1;transform:scale(1.15) rotate(15deg)}}
.proj-gen-text{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-style:italic;font-weight:300;color:var(--ink2)}
.proj-progress-track{width:200px;height:2px;background:var(--pale);overflow:hidden}
.proj-progress-fill{height:100%;background:var(--accent);width:0%;transition:width 0.25s}
.proj-progress-row{display:flex;gap:1.5rem;font-size:0.72rem;color:var(--muted);letter-spacing:0.08em}
.proj-results-grid{display:none;flex-direction:column;gap:1.4rem}
.proj-result-item{border:1px solid var(--line);overflow:hidden;border-radius:8px}
.proj-result-actions{display:flex;gap:0.5rem;padding:0.8rem}
.proj-result-btn{flex:1;padding:0.65rem 0.4rem;background:transparent;border:1px solid var(--line2);font-size:0.65rem;letter-spacing:0.08em;text-transform:uppercase;cursor:pointer;font-family:'Manrope',sans-serif;color:var(--ink);transition:all 0.2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-decoration:none;display:flex;align-items:center;justify-content:center}
.proj-result-btn:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.proj-result-btn.save{background:var(--accent);border-color:var(--accent);color:white}
.proj-result-btn.save:hover{background:var(--ink);border-color:var(--ink)}
/* comparison slider */
.compare-wrap{position:relative;overflow:hidden;cursor:col-resize;user-select:none;touch-action:pan-y;background:var(--ink)}
.compare-sizer{width:100%;display:block;visibility:hidden;pointer-events:none}
.compare-before,.compare-after{position:absolute;inset:0}
.compare-before img,.compare-after img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;-webkit-user-drag:none}
.compare-after{clip-path:inset(0 0 0 50%)}
.compare-line{position:absolute;top:0;bottom:0;left:50%;width:2px;background:rgba(255,255,255,0.9);transform:translateX(-50%);pointer-events:none;box-shadow:0 0 10px rgba(0,0,0,0.35)}
.compare-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:42px;height:42px;background:rgba(20,16,12,0.7);border-radius:50%;display:flex;align-items:center;justify-content:center;pointer-events:none;box-shadow:0 2px 12px rgba(0,0,0,0.3);backdrop-filter:blur(6px)}
.compare-lbl{position:absolute;top:12px;padding:5px 14px;background:rgba(20,16,12,0.55);color:rgba(255,255,255,0.95);border-radius:20px;font-size:0.7rem;letter-spacing:0.12em;text-transform:uppercase;font-family:'Manrope',sans-serif;pointer-events:none;backdrop-filter:blur(6px)}
.compare-lbl--before{left:14px}
.compare-lbl--after{right:14px}

/* SHARE POPUP */
#share-popup{background:var(--cream);border:1px solid var(--line2);box-shadow:0 8px 32px rgba(20,16,12,0.18);z-index:9990;min-width:180px;padding:0.5rem 0;display:flex;flex-direction:column}
#share-popup a{display:flex;align-items:center;gap:0.7rem;padding:0.65rem 1.1rem;font-size:0.8rem;letter-spacing:0.04em;font-family:'Manrope',sans-serif;color:var(--ink);text-decoration:none;transition:background 0.15s}
#share-popup a:hover{background:var(--warm)}
#share-popup svg{flex-shrink:0;opacity:0.75}
body.dark #share-popup{background:#1c1710;border-color:rgba(237,226,196,0.15)}
body.dark #share-popup a{color:#ede2c4}
body.dark #share-popup a:hover{background:rgba(237,226,196,0.08)}

/* dark mode project page */
body.dark .proj-page{background:#1c1710}
body.dark .proj-header{border-color:rgba(237,226,196,0.08)}
body.dark .proj-back{border-color:rgba(237,226,196,0.15);color:rgba(237,226,196,0.4)}
body.dark .proj-back:hover{border-color:#ede2c4;color:#ede2c4}
body.dark .proj-header-title{color:rgba(237,226,196,0.45)}
body.dark .proj-card{background:#211b11;border-color:rgba(237,226,196,0.08)}
body.dark .proj-card-top{border-color:rgba(237,226,196,0.08)}
body.dark .proj-card-h{color:#ede2c4}
body.dark .proj-card-n{color:rgba(237,226,196,0.06)}
body.dark .proj-add-btn{border-color:rgba(237,226,196,0.18);color:rgba(237,226,196,0.35)}
body.dark .proj-add-btn:hover{border-color:var(--accent-soft);color:var(--accent-soft)}
body.dark .proj-file-info,body.dark .proj-file-count{color:rgba(237,226,196,0.35)}
body.dark .proj-modes{border-color:rgba(237,226,196,0.1)}
body.dark .proj-mode-btn{border-color:rgba(237,226,196,0.1);color:rgba(237,226,196,0.4)}
body.dark .proj-mode-btn.active{background:#ede2c4;color:var(--ink)}
body.dark .proj-mode-btn:not(.active):hover{background:rgba(237,226,196,0.05);color:#ede2c4}
body.dark .proj-mode-info{background:rgba(237,226,196,0.04)}
body.dark .proj-mode-info p{color:rgba(237,226,196,0.5)}
body.dark .proj-start-btn{background:#ede2c4;color:var(--ink)}
body.dark .proj-start-btn:hover:not(:disabled){background:var(--accent);color:white}
body.dark .proj-results-empty p{color:rgba(237,226,196,0.25)}
body.dark .proj-gen-text{color:rgba(237,226,196,0.6)}
body.dark .proj-progress-track{background:rgba(237,226,196,0.08)}
body.dark .proj-result-item{border-color:rgba(237,226,196,0.1)}
body.dark .proj-result-actions{background:#211b11}
body.dark .proj-result-btn{border-color:rgba(237,226,196,0.15);color:#ede2c4}
body.dark .proj-result-btn:hover{background:#ede2c4;color:var(--ink);border-color:#ede2c4}

/* ===== ARCHIVE PAGE ===== */
.arch-page{position:fixed;inset:0;background:var(--cream);z-index:260;overflow-y:auto;opacity:0;visibility:hidden;transition:opacity 0.45s,visibility 0.45s}
.arch-page.open{opacity:1;visibility:visible}
.arch-page-inner{max-width:1160px;margin:0 auto;padding:2rem 3rem 5rem}
.arch-head{display:flex;align-items:flex-end;justify-content:space-between;margin:2.5rem 0 2rem;padding-bottom:1.2rem;border-bottom:1px solid var(--line)}
.arch-title{font-family:'Cormorant Garamond',serif;font-size:2.8rem;font-weight:300;color:var(--ink);line-height:1;letter-spacing:-0.02em}
.arch-title em{font-style:italic;color:var(--accent)}
.arch-count{font-size:0.8rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(20,16,12,0.45);margin-top:0.5rem;display:block}
.arch-new-btn{font-size:0.82rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent);text-decoration:none;border:1px solid rgba(184,72,42,0.4);padding:0.55rem 1.1rem;transition:all 0.3s;flex-shrink:0}
.arch-new-btn:hover{background:var(--accent);color:white;border-color:var(--accent)}
.arch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.4rem}
.arch-item{border:1px solid var(--line);overflow:hidden}
.arch-item img{width:100%;display:block;aspect-ratio:4/3;object-fit:cover}
.arch-item-actions{display:flex;gap:0.5rem;padding:0.8rem}
.arch-btn{flex:1;padding:0.6rem 0.4rem;background:transparent;border:1px solid var(--line2);font-size:0.65rem;letter-spacing:0.08em;text-transform:uppercase;cursor:pointer;font-family:'Manrope',sans-serif;color:var(--ink);transition:all 0.2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-decoration:none;text-align:center;display:block}
.arch-btn:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.arch-btn-save{background:var(--accent);border-color:var(--accent);color:white}
.arch-btn-save:hover{background:var(--ink);border-color:var(--ink)}
.arch-empty{grid-column:1/-1;text-align:center;padding:6rem 2rem;font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-style:italic;font-weight:300;color:rgba(20,16,12,0.25);line-height:1.6}
.arch-empty::before{content:'✦';display:block;font-size:1.6rem;color:var(--accent);opacity:0.2;margin-bottom:1.2rem}
body.dark .arch-page{background:#1c1710}
body.dark .arch-head{border-color:rgba(237,226,196,0.08)}
body.dark .arch-title{color:#ede2c4}
body.dark .arch-count{color:rgba(237,226,196,0.3)}
body.dark .arch-new-btn{color:var(--accent);border-color:rgba(184,72,42,0.35)}
body.dark .arch-item{border-color:rgba(237,226,196,0.1)}
body.dark .arch-item-actions{background:#211b11}
body.dark .arch-btn{border-color:rgba(237,226,196,0.15);color:#ede2c4}
body.dark .arch-btn:hover{background:#ede2c4;color:var(--ink);border-color:#ede2c4}
body.dark .arch-empty{color:rgba(237,226,196,0.15)}

/* ===== HISTORY MODAL ===== */
.hist-modal{position:fixed;inset:0;background:rgba(20,16,12,0.65);backdrop-filter:blur(10px);z-index:600;display:flex;align-items:center;justify-content:center;padding:2rem;opacity:0;visibility:hidden;transition:opacity 0.35s,visibility 0.35s}
.hist-modal.open{opacity:1;visibility:visible}
.hist-inner{background:var(--cream);max-width:500px;width:100%;padding:3rem 2.8rem 2.5rem;position:relative;max-height:80vh;display:flex;flex-direction:column}
.hist-close{position:absolute;top:1.2rem;right:1.4rem;background:transparent;border:none;font-size:1.1rem;cursor:pointer;color:var(--ink);opacity:0.5;transition:opacity 0.2s;line-height:1;font-family:'Manrope',sans-serif}
.hist-close:hover{opacity:1}
.hist-tag{font-size:0.75rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--accent);margin-bottom:0.8rem}
.hist-title{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:300;color:var(--ink);line-height:1.1;margin-bottom:1.8rem;flex-shrink:0}
.hist-title em{font-style:italic;color:var(--accent)}
.hist-list{overflow-y:auto;flex:1}
.hist-empty{color:rgba(20,16,12,0.45);font-size:0.95rem;text-align:center;padding:2.5rem 0;font-style:italic}
.hist-item{display:flex;align-items:center;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--line)}
.hist-item:last-child{border-bottom:none}
.hist-item-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.95rem;font-weight:700;flex-shrink:0;font-family:'Manrope',sans-serif}
.hist-item-icon.plus{background:rgba(50,168,83,0.12);color:#2a9a4a}
.hist-item-icon.minus{background:rgba(184,72,42,0.1);color:var(--accent)}
.hist-item-info{flex:1;min-width:0}
.hist-item-label{font-size:0.9rem;color:var(--ink);font-weight:500}
.hist-item-date{font-size:0.75rem;color:rgba(20,16,12,0.45);margin-top:0.15rem;letter-spacing:0.02em}
.hist-item-amount{font-size:1rem;font-weight:600;flex-shrink:0;font-family:'Manrope',sans-serif}
.hist-item-amount.plus{color:#2a9a4a}
.hist-item-amount.minus{color:var(--accent)}
.hist-item-bal{font-size:0.78rem;color:rgba(20,16,12,0.4);flex-shrink:0;min-width:48px;text-align:right;letter-spacing:0.02em}
body.dark .hist-inner{background:#1c1710}
body.dark .hist-title{color:#ede2c4}
body.dark .hist-close{color:#ede2c4}
body.dark .hist-tag{color:var(--accent)}
body.dark .hist-empty{color:rgba(237,226,196,0.3)}
body.dark .hist-item{border-color:rgba(237,226,196,0.08)}
body.dark .hist-item-label{color:#ede2c4}
body.dark .hist-item-date{color:rgba(237,226,196,0.35)}
body.dark .hist-item-bal{color:rgba(237,226,196,0.3)}

/* ===== TOPUP MODAL ===== */
.topup-modal{position:fixed;inset:0;background:rgba(20,16,12,0.65);backdrop-filter:blur(10px);z-index:600;display:flex;align-items:center;justify-content:center;padding:2rem;opacity:0;visibility:hidden;transition:opacity 0.35s,visibility 0.35s}
.topup-modal.open{opacity:1;visibility:visible}
.topup-inner{background:var(--paper);max-width:820px;width:100%;padding:2.8rem;position:relative;max-height:90vh;overflow-y:auto;border:1px solid var(--line)}
.topup-close{position:absolute;top:1.2rem;right:1.2rem;width:32px;height:32px;background:transparent;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:0.85rem;color:var(--ink);transition:all 0.3s}
.topup-close:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.topup-tag{display:inline-block;background:var(--warm);color:var(--accent);font-size:0.65rem;letter-spacing:0.2em;text-transform:uppercase;padding:0.35rem 0.8rem;margin-bottom:1rem;font-weight:500}
.topup-title{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:300;margin-bottom:0.6rem;letter-spacing:-0.01em;line-height:1.1}
.topup-sub{font-size:0.88rem;color:var(--ink2);line-height:1.7;margin-bottom:2.2rem;font-weight:300;max-width:480px}
.topup-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.topup-tier{background:var(--cream);border:1px solid var(--line);padding:1.8rem 1.5rem;position:relative;display:flex;flex-direction:column;transition:transform 0.3s}
.topup-tier:hover{transform:translateY(-4px)}
.topup-tier.featured{background:var(--ink);border-color:var(--ink)}
.topup-tier-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:white;font-size:0.58rem;letter-spacing:0.2em;text-transform:uppercase;padding:0.3rem 0.9rem;font-weight:500;font-family:'Manrope',sans-serif;white-space:nowrap}
.topup-tier-name{font-size:0.7rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem}
.topup-tier.featured .topup-tier-name{color:var(--accent-soft)}
.topup-tier-price{font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:300;line-height:1;margin-bottom:0.3rem;color:var(--ink)}
.topup-tier-price em{font-style:italic;color:var(--accent);font-size:2rem}
.topup-tier.featured .topup-tier-price{color:var(--paper)}
.topup-tier-credits{font-size:0.83rem;color:var(--muted);padding-bottom:1rem;margin-bottom:1rem;border-bottom:1px solid var(--line)}
.topup-tier.featured .topup-tier-credits{border-color:rgba(245,242,237,0.15);color:rgba(245,242,237,0.5)}
.topup-tier-list{list-style:none;flex:1;margin-bottom:1.5rem}
.topup-tier-list li{font-size:0.85rem;color:var(--ink2);padding:0.4rem 0;display:flex;align-items:center;gap:0.5rem;font-weight:300}
.topup-tier-list li::before{content:'';width:5px;height:5px;background:var(--accent);border-radius:50%;flex-shrink:0}
.topup-tier.featured .topup-tier-list li{color:rgba(245,242,237,0.7)}
.topup-tier.featured .topup-tier-list li::before{background:var(--accent-soft)}
.topup-tier-btn{width:100%;padding:0.85rem;background:transparent;border:1px solid var(--line2);color:var(--ink);font-family:'Manrope',sans-serif;font-size:0.75rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;cursor:pointer;transition:all 0.3s}
.topup-tier-btn:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.topup-tier.featured .topup-tier-btn{background:var(--accent);border-color:var(--accent);color:white}
.topup-tier.featured .topup-tier-btn:hover{background:var(--accent2);border-color:var(--accent2)}
body.dark .topup-inner{background:#231d12;border-color:rgba(237,226,196,0.1)}
body.dark .topup-title{color:#ede2c4}
body.dark .topup-sub{color:rgba(237,226,196,0.5)}
body.dark .topup-close{border-color:rgba(237,226,196,0.15);color:#ede2c4}
body.dark .topup-tier{background:#1c1710;border-color:rgba(237,226,196,0.08)}
body.dark .topup-tier.featured{background:var(--accent)}
body.dark .topup-tier-price{color:#ede2c4}
body.dark .topup-tier-list li{color:rgba(237,226,196,0.6)}

/* ===== FIRST RESULT MODAL ===== */
.fr-modal{position:fixed;inset:0;background:rgba(20,16,12,0.65);backdrop-filter:blur(14px);z-index:700;display:flex;align-items:center;justify-content:center;padding:2rem;opacity:0;visibility:hidden;transition:opacity 0.4s,visibility 0.4s}
.fr-modal.open{opacity:1;visibility:visible}
.fr-inner{background:var(--paper);max-width:720px;width:100%;position:relative;border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:row;min-height:420px;max-height:88vh}
.fr-close{position:absolute;top:1rem;right:1rem;width:30px;height:30px;background:rgba(253,246,227,0.9);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:0.8rem;color:var(--ink);z-index:2;transition:all 0.25s}
.fr-close:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.fr-img-wrap{width:300px;flex-shrink:0;overflow:hidden;background:var(--pale);position:relative}
.fr-img-wrap::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,transparent 70%,var(--paper));pointer-events:none}
.fr-img-wrap img{width:100%;height:100%;object-fit:cover;display:block}
.fr-body{flex:1;padding:2.8rem 2.5rem;display:flex;flex-direction:column;justify-content:center;min-width:0}
.fr-tag{display:inline-block;background:var(--warm);color:var(--accent);font-size:0.6rem;letter-spacing:0.25em;text-transform:uppercase;padding:0.3rem 0.8rem;margin-bottom:1.4rem;font-weight:500;font-family:'Manrope',sans-serif}
.fr-title{font-family:'Cormorant Garamond',serif;font-size:2.8rem;font-weight:400;color:var(--ink);line-height:1.05;margin-bottom:1rem;letter-spacing:-0.02em}
.fr-spark{color:var(--gold);font-style:normal}
.fr-sub{font-size:0.9rem;color:var(--ink2);line-height:1.75;font-weight:300;margin-bottom:2.2rem;max-width:280px}
.fr-btns{display:flex;flex-direction:column;gap:0.65rem}
.fr-btn-primary{width:100%;padding:1rem 1.2rem;background:var(--accent);color:white;border:none;font-family:'Manrope',sans-serif;font-size:0.73rem;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;cursor:pointer;transition:background 0.3s;text-align:center}
.fr-btn-primary:hover{background:var(--ink)}
.fr-btn-sec{width:100%;padding:1rem 1.2rem;background:transparent;color:var(--muted);border:1px solid var(--line);font-family:'Manrope',sans-serif;font-size:0.73rem;font-weight:400;letter-spacing:0.18em;text-transform:uppercase;cursor:pointer;transition:all 0.3s;text-align:center}
.fr-btn-sec:hover{border-color:var(--ink);color:var(--ink)}
body.dark .fr-inner{background:#231d12;border-color:rgba(237,226,196,0.1)}
body.dark .fr-img-wrap::after{background:linear-gradient(to right,transparent 70%,#231d12)}
body.dark .fr-close{background:rgba(35,29,18,0.9);border-color:rgba(237,226,196,0.2);color:#ede2c4}
body.dark .fr-title{color:#ede2c4}
body.dark .fr-sub{color:rgba(237,226,196,0.5)}
body.dark .fr-btn-sec{border-color:rgba(237,226,196,0.15);color:rgba(237,226,196,0.45)}

/* ===== WELCOME MODAL ===== */
.wlc-modal{position:fixed;inset:0;background:rgba(20,16,12,0.6);backdrop-filter:blur(14px);z-index:800;display:flex;align-items:center;justify-content:center;padding:2rem;opacity:0;visibility:hidden;transition:opacity 0.4s,visibility 0.4s}
.wlc-modal.open{opacity:1;visibility:visible}
.wlc-inner{background:var(--cream);max-width:460px;width:100%;padding:3.2rem 2.8rem 2.8rem;position:relative;border:1px solid var(--line);text-align:center;transform:translateY(24px) scale(0.97);transition:transform 0.45s cubic-bezier(0.7,0,0.3,1)}
.wlc-modal.open .wlc-inner{transform:none}
.wlc-close{position:absolute;top:1rem;right:1rem;width:30px;height:30px;border:1px solid var(--line);background:transparent;color:var(--ink);font-size:0.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.25s}
.wlc-close:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.wlc-icon{font-family:'Cormorant Garamond',serif;font-size:2rem;color:var(--gold);margin-bottom:1.2rem;line-height:1}
.wlc-tag{display:inline-block;background:var(--warm);color:var(--accent);font-size:0.62rem;letter-spacing:0.25em;text-transform:uppercase;padding:0.32rem 0.85rem;margin-bottom:1.4rem;font-weight:500;font-family:'Manrope',sans-serif}
.wlc-title{font-family:'Cormorant Garamond',serif;font-size:2.6rem;font-weight:400;color:var(--ink);line-height:1.1;margin-bottom:1rem;letter-spacing:-0.02em}
.wlc-title em{font-style:italic;color:var(--accent)}
.wlc-sub{font-size:0.95rem;color:var(--ink2);line-height:1.8;font-weight:300;margin-bottom:2.2rem;max-width:340px;margin-left:auto;margin-right:auto}
.wlc-btn{width:100%;padding:1.05rem 1.5rem;background:var(--ink);color:var(--paper);border:none;font-family:'Manrope',sans-serif;font-size:0.78rem;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;cursor:pointer;transition:background 0.3s}
.wlc-btn:hover{background:var(--accent)}
body.dark .wlc-inner{background:#231d12;border-color:rgba(237,226,196,0.1)}
body.dark .wlc-title{color:#ede2c4}
body.dark .wlc-sub{color:rgba(237,226,196,0.5)}
body.dark .wlc-close{border-color:rgba(237,226,196,0.15);color:#ede2c4}
@media(max-width:480px){.wlc-inner{padding:2.5rem 1.6rem 2.2rem}.wlc-title{font-size:2rem}}

/* ===== MOBILE 768px ===== */
@media (max-width:768px){
  /* Prevent global overflow */
  body{overflow-x:hidden}

  /* Nav */
  .topbar{padding:0 1.2rem;height:58px}
  .nav-links{gap:0.7rem}
  .logo{font-size:1.2rem}

  /* Hero */
  .hero-left{padding:4.5rem 1.5rem 3rem}
  .hero-h1{font-size:clamp(2.6rem,8vw,3.8rem)}
  .hero-desc{font-size:1rem;margin-bottom:2rem}
  .hero-actions{flex-direction:column;align-items:flex-start;gap:1rem}
  .hero-note{font-size:0.82rem;max-width:100%}
  .hero-numbers{gap:1.5rem;flex-wrap:wrap;padding-top:1.5rem;margin-top:2rem}
  .hnum-n{font-size:2rem}
  .hnum-l{font-size:0.7rem}
  .hero-right{min-height:50vw;padding:2rem 1.5rem}
  .ba-frame{max-width:100%}

  /* Sections */
  .section{padding:3.5rem 1.5rem}
  .section-title{font-size:clamp(2.2rem,6vw,2.8rem)}
  .section-head{margin-bottom:3rem}
  .upload-inner{padding:3.5rem 1.5rem}

  /* Gallery — 2 cols on tablet */
  .gallery-grid{grid-template-columns:repeat(2,1fr);gap:1rem}

  /* Project page */
  .proj-layout{grid-template-columns:1fr}
  .proj-page-inner{padding:1.5rem 1.2rem 4rem}
  .proj-card{padding:2rem 1.8rem}
  .proj-results-card{min-height:320px}

  /* Topup modal */
  .topup-tiers{grid-template-columns:1fr;gap:1rem}
  .topup-inner{padding:2rem 1.5rem}

  /* First result modal — stack vertically */
  .fr-inner{flex-direction:column;min-height:auto;max-height:92vh;overflow-y:auto}
  .fr-img-wrap{width:100%;height:200px;flex-shrink:0}
  .fr-img-wrap::after{background:linear-gradient(to bottom,transparent 70%,var(--paper))}
  body.dark .fr-img-wrap::after{background:linear-gradient(to bottom,transparent 70%,#231d12)}
  .fr-body{padding:1.8rem 1.8rem 2rem}
  .fr-title{font-size:2.2rem}

  /* Dashboard */
  .dashboard-inner{padding:4rem 1.2rem 3rem}
  .dash-identity{grid-template-columns:auto 1fr}
  .dash-monogram{font-size:5.5rem;width:70px}
  .dash-identity-name{font-size:2.2rem}

  /* CTA */
  .cta-block{padding:6rem 1.5rem}

  /* Footer */
  .footer-big{padding:4rem 1.5rem 1.5rem}
  .footer-brand .foot-logo-big{font-size:2.2rem}

  /* Pricing tiers in topup stacked OK above, public pricing page too */
  .pricing-grid{grid-template-columns:1fr}
}

/* ===== MOBILE 480px ===== */
@media (max-width:480px){
  /* Topbar */
  .topbar{padding:0 1rem;height:54px}
  .logo{font-size:1.1rem;letter-spacing:0.1em}
  .nav-cta{padding:0.5rem 1rem;font-size:0.72rem}

  /* Hero */
  .hero-left{padding:3.8rem 1.2rem 2.5rem}
  .hero-issue{display:none}
  .hero-h1{font-size:clamp(2rem,10vw,2.8rem);margin-bottom:1.5rem}
  .hero-desc{font-size:0.95rem;margin-bottom:1.8rem}
  .btn-main{padding:0.95rem 2rem;font-size:0.8rem}
  .hero-numbers{gap:1rem;margin-top:1.5rem;padding-top:1.2rem;justify-content:flex-start}
  .hnum-n{font-size:1.75rem}
  .hnum-item{flex:1 1 calc(33% - 0.7rem);min-width:90px}
  .hero-right{padding:1.5rem 1rem;min-height:45vw}

  /* Sections */
  .section{padding:3rem 1rem}
  .section-title{font-size:clamp(2rem,8vw,2.4rem)}
  .section-head{margin-bottom:2.5rem}
  .upload-inner{padding:3rem 1rem}

  /* Gallery — 1 col on phones */
  .gallery-grid{grid-template-columns:1fr}

  /* Features */
  .features-list{grid-template-columns:1fr}
  .feat{padding:2.2rem 1.8rem 2.8rem}
  .feat-label{font-size:4rem}

  /* Steps editorial */
  .estep-title{font-size:1.65rem}
  .sp-frame{aspect-ratio:3/4}

  /* Reviews */
  .review-grid{grid-template-columns:1fr}

  /* Project page */
  .proj-page-inner{padding:1rem 0.9rem 3rem}
  .proj-card{padding:1.6rem 1.3rem}
  .proj-card-n{font-size:3rem}
  .proj-card-h{font-size:1.5rem}
  .proj-thumbs{min-height:72px}
  .proj-add-btn,.proj-thumb-wrap{width:72px;height:72px}

  /* Topup modal */
  .topup-inner{padding:1.5rem 1rem}
  .topup-title{font-size:1.9rem}
  .topup-tiers{grid-template-columns:1fr}

  /* First result modal */
  .fr-inner{max-height:95vh}
  .fr-img-wrap{height:170px}
  .fr-body{padding:1.5rem 1.4rem 1.8rem}
  .fr-title{font-size:2rem;margin-bottom:0.7rem}
  .fr-sub{font-size:0.84rem;margin-bottom:1.6rem;max-width:100%}

  /* FAQ */
  .faq-wrap{gap:2rem}
  .faq-q{font-size:0.95rem;padding:1.2rem 1.3rem}

  /* CTA */
  .cta-block{padding:4.5rem 1.2rem}

  /* Footer */
  .footer-big{padding:3rem 1.2rem 1.2rem}
  .footer-brand .foot-logo-big{font-size:1.9rem}
  .footer-tag{font-size:1.15rem}
  .footer-links-row{gap:0.4rem 1.5rem}
  footer{padding:2rem 1.2rem;gap:1.2rem}

  /* Dashboard */
  .dashboard-inner{padding:3.5rem 1rem 2.5rem}
  .dash-balance-n{font-size:3.5rem}
  .dash-section-title{font-size:2rem}
  .dash-identity-name{font-size:1.9rem}
  .dash-monogram{font-size:4.5rem;width:60px}
}
