:root{--bg:#faf8f5;--card:#fff;--ink:#2b2b2b;--muted:#8a8278;--accent:#b08968;--line:#e7e1d8}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink)}
a{color:var(--accent);text-decoration:none}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.brand{font-weight:700;font-size:18px}
.brand a{color:var(--ink)}
nav a{margin-left:16px;font-size:14px}
.container{max-width:1200px;margin:0 auto;padding:20px}
.foot{text-align:center;color:var(--muted);padding:34px 20px;display:flex;flex-direction:column;align-items:center;gap:8px}
.footbrand{font-family:'Playfair Display',Georgia,serif;font-size:22px;color:var(--ink);letter-spacing:.5px;line-height:1}
.footbrand .brand-love{color:var(--accent);font-style:italic}
.martamark{height:64px;width:auto;margin-top:4px}
.meheader{display:flex;align-items:center;gap:16px;margin-bottom:6px;flex-wrap:wrap}
.mefaces{display:flex}
.mefaces img{width:54px;height:54px;border-radius:50%;object-fit:cover;border:2px solid #fff;box-shadow:0 1px 5px rgba(0,0,0,.18);margin-left:-12px}
.mefaces img:first-child{margin-left:0}
.metext h1{margin:0}

/* ===================== LANDING LoveGallery ===================== */
body.lp{background:#fbf9f5}
.lp-top{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 28px;background:rgba(251,249,245,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);flex-wrap:wrap}
.lp-brand a{font-family:'Playfair Display',Georgia,serif;font-size:26px;color:var(--ink);letter-spacing:.3px}
.brand-love{color:var(--accent);font-style:italic}
.lp-nav{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.lp-nav>a{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:600;color:var(--ink)}
.lp-langs{display:flex;gap:8px;font-size:13px}
.lp-langs a{color:var(--muted);padding:2px 4px}
.lp-langs a.on{color:var(--accent);font-weight:700;border-bottom:2px solid var(--accent)}
.lp-hero{padding:90px 24px 100px;text-align:center;background:linear-gradient(rgba(250,247,242,.72),rgba(247,241,232,.86)),#efe6d6 url('/static/landing-hero.jpg') center/cover no-repeat}
.lp-hero-in{max-width:780px;margin:0 auto}
.lp-hero h1{font-family:'Playfair Display',Georgia,serif;font-weight:700;font-size:46px;line-height:1.12;margin:0 0 18px;color:#2b2b2b}
.lp-hero p{font-size:20px;line-height:1.6;color:#5a5249;margin:0 auto 28px;max-width:620px}
.lp-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn.ghost{background:transparent;color:var(--accent);border:1px solid var(--accent)}
.lp-sec{max-width:1040px;margin:0 auto;padding:64px 24px}
.lp-sec>h2{font-family:'Playfair Display',Georgia,serif;font-weight:600;font-size:33px;text-align:center;margin:0 0 36px}
.lp-alt{max-width:none;background:#f5efe6}
.lp-alt>h2,.lp-alt>.lp-feats{max-width:1040px;margin-left:auto;margin-right:auto}
.lp-steps{display:flex;flex-direction:column;gap:22px;max-width:760px;margin:0 auto}
.lp-step{display:flex;gap:18px;align-items:flex-start}
.lp-num{flex:0 0 auto;width:44px;height:44px;border-radius:50%;background:var(--accent);color:#fff;font-family:'Playfair Display',serif;font-size:20px;display:flex;align-items:center;justify-content:center}
.lp-step h3{margin:4px 0 4px;font-size:20px}
.lp-step p{margin:0;color:#5a5249;line-height:1.55}
.lp-feats{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}
.lp-feat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 24px}
.lp-feat h3{margin:0 0 6px;font-size:19px;color:var(--accent)}
.lp-feat p{margin:0;color:#5a5249;line-height:1.55}
.lp-lead{text-align:center;color:#5a5249;margin:-22px auto 26px;max-width:560px}
.lp-form{max-width:520px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.lp-form label{display:flex;flex-direction:column;gap:6px;font-size:14px;color:#5a5249;font-weight:600}
.lp-form input,.lp-form textarea{padding:11px 12px;border:1px solid var(--line);border-radius:9px;font:inherit;background:#fff}
.lp-form input:focus,.lp-form textarea:focus{outline:none;border-color:var(--accent)}
.lp-form .btn{align-self:flex-start}
.lp-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.lp-priv{font-size:12px;margin:2px 0 0}
.lp-ok{background:#eaf6ec;border:1px solid #9ccfa3;color:#1f6b2c;border-radius:10px;padding:12px 16px;max-width:520px;margin:0 auto 18px;text-align:center}
.lp-bad{background:#fbecec;border:1px solid #e0a3a3;color:#9a2b2b;border-radius:10px;padding:12px 16px;max-width:520px;margin:0 auto 18px;text-align:center}
.lp-band{background:linear-gradient(135deg,#b08968,#a9824f);color:#fff;text-align:center;padding:54px 24px}
.lp-band-big{font-family:'Playfair Display',Georgia,serif;font-size:32px;font-weight:600;margin:0 0 10px}
.lp-band-sub{font-size:17px;margin:0 auto 22px;max-width:560px;opacity:.95}
.lp-band .btn{background:#fff;color:#8a6a44}
.lp-access{min-height:62vh;display:flex;align-items:center;justify-content:center;padding:40px 20px}
.lp-card{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 12px 40px rgba(80,60,40,.12);padding:34px 34px;max-width:420px;width:100%;text-align:center}
.lp-card h1{font-family:'Playfair Display',Georgia,serif;font-weight:600;margin:0 0 6px}
.lp-card .lp-form{margin-top:18px}
.lp-card .lp-form .btn{align-self:stretch;text-align:center}
@media(max-width:560px){.lp-hero h1{font-size:34px}.lp-hero{padding:60px 20px 70px}.lp-top{padding:12px 16px}}
h1{font-weight:600}
.muted{color:var(--muted)}
.stats{display:flex;gap:20px;margin:10px 0 20px;flex-wrap:wrap}
.stat{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:10px 16px}
.stat b{font-size:22px;display:block}

/* rejilla de personas */
.people{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}
.person{background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden;text-align:center}
.person .face{width:100%;aspect-ratio:1;object-fit:cover;background:#eee;display:block}
.person .body{padding:8px}
.person input[type=text]{width:100%;border:1px solid var(--line);border-radius:8px;padding:6px;font-size:14px;text-align:center}
.person .count{font-size:12px;color:var(--muted);margin:4px 0}
.person{position:relative}
.person .named{outline:3px solid var(--accent)}
.person .pick{position:absolute;top:6px;left:6px;z-index:2;background:rgba(255,255,255,.85);border-radius:6px;padding:2px 4px;line-height:0}
.person .pick input{width:20px;height:20px;cursor:pointer}
.mergebar{position:fixed;bottom:0;left:0;right:0;background:var(--card);border-top:1px solid var(--line);box-shadow:0 -4px 16px rgba(0,0,0,.08);padding:12px 20px;display:flex;gap:14px;align-items:center;justify-content:center;z-index:20;flex-wrap:wrap}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-top:16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:10px}
.facestrip{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.facestrip img{width:44px;height:44px;border-radius:8px;object-fit:cover}
.facestrip .more{font-size:13px;color:var(--muted);padding:0 4px}
.person.cand{cursor:pointer}
.person.cand .cbox:checked ~ .face{outline:3px solid var(--accent)}
/* muro público, etiquetas, comentarios, avisos */
.photo-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:16px}
.badge-pub{display:inline-block;margin-top:10px;color:#0a7d33;font-weight:600}
.tags{margin-top:8px}
.tag{display:inline-block;background:var(--accent);color:#fff;border-radius:999px;padding:2px 10px;font-size:13px;margin:2px 4px 2px 0}
.pubcell{margin:0}
.pubcell figcaption{margin-top:4px;line-height:1.4}
.comments{margin-top:24px;max-width:680px}
.cmt{border:1px solid var(--line);border-radius:10px;padding:10px 12px;margin:10px 0;background:var(--card)}
.cmt.reply{margin:8px 0 0 24px;background:transparent;border-style:dashed}
.cmt-head{font-size:14px}
.cmt-body{margin-top:4px;white-space:pre-wrap}
.replybox{margin-top:8px}
.replybox summary{cursor:pointer;color:var(--accent);font-size:14px}
.comments textarea,.newcmt textarea{width:100%;padding:8px;border:1px solid var(--line);border-radius:8px;box-sizing:border-box;margin:6px 0;font:inherit}
.newcmt{margin-top:18px;border-top:1px solid var(--line);padding-top:14px}
.avisobar{display:block;background:#fff7e6;border:1px solid #f0c36d;color:#7a5b00;border-radius:10px;padding:10px 14px;margin-bottom:16px;text-decoration:none;font-weight:600}
.notes{display:flex;flex-direction:column;gap:8px;max-width:680px}
.note{display:flex;gap:12px;align-items:center;border:1px solid var(--line);border-radius:10px;padding:8px 10px;text-decoration:none;color:inherit;background:var(--card)}
.note.unread{border-color:var(--accent);background:#f3f8ff}
.note img{width:52px;height:52px;border-radius:8px;object-fit:cover;flex:0 0 auto}
.note-txt{font-size:14px}

/* ===================== TEMAS POR EVENTO (4 paletas, fondo siempre claro) ===================== */
/* Estructura común; los colores y tipografías vienen de las variables de cada tema. */
body[class*="theme-"]{background:var(--page)}
body[class*="theme-"]::before{content:"";position:fixed;inset:0;z-index:-2;background:var(--hero) center/cover no-repeat}
body[class*="theme-"]::after{content:"";position:fixed;inset:0;z-index:-1;background:linear-gradient(var(--veil1),var(--veil2))}
body[class*="theme-"] .topbar{background:var(--bar);backdrop-filter:blur(6px);border-bottom:1px solid var(--accent)}
body[class*="theme-"] .brand a,body[class*="theme-"] h1,body[class*="theme-"] h2,body[class*="theme-"] h3{font-family:var(--headfont)}
body[class*="theme-"] .brand{font-size:23px;letter-spacing:.3px}
body[class*="theme-"] nav a{font-family:var(--navfont);font-size:16px;font-weight:600}
body[class*="theme-"] .container{position:relative;background:var(--panel);backdrop-filter:blur(3px);border-radius:14px;box-shadow:0 12px 44px rgba(60,50,40,.18);padding:34px 38px 30px;margin:26px auto;border:1px solid var(--accent);outline:1px solid var(--accent);outline-offset:5px}
body[class*="theme-"] .container::before{content:"";display:block;width:120px;height:0;border-top:1.6px solid var(--accent);opacity:.6;margin:0 auto 18px}
body[class*="theme-"] h1{font-weight:600;font-size:34px;margin:.1em 0 .3em}
body[class*="theme-"] .grid img{border:2px solid #fff;box-shadow:0 3px 12px rgba(60,50,40,.14)}
@media(max-width:600px){body[class*="theme-"] .container{padding:22px 18px;outline-offset:3px;margin:14px}}

/* Boda · elegante (dorado) */
.theme-wedding{--accent:#a9824f;--line:#e3d4bf;--page:#faf7f2;--veil1:rgba(250,247,242,.82);--veil2:rgba(248,243,236,.90);--bar:rgba(255,253,250,.80);--panel:rgba(255,255,255,.82);--headfont:'Playfair Display',Georgia,serif;--navfont:'Cormorant Garamond',serif}
.theme-wedding .container::before{width:auto;height:24px;border:0;opacity:1;margin:-8px auto 18px;background:no-repeat center/auto 100% url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='24' viewBox='0 0 240 24'%3E%3Cg stroke='%23a9824f' stroke-width='1.3' fill='%23a9824f'%3E%3Cline x1='12' y1='12' x2='96' y2='12' stroke-linecap='round'/%3E%3Cline x1='144' y1='12' x2='228' y2='12' stroke-linecap='round'/%3E%3Ccircle cx='104' cy='12' r='2.2' stroke='none'/%3E%3Ccircle cx='136' cy='12' r='2.2' stroke='none'/%3E%3Cpath d='M120 2 C113 7,113 17,120 22 C127 17,127 7,120 2 Z' stroke='none'/%3E%3Cpath d='M120 6 C117 9,117 15,120 18 C123 15,123 9,120 6 Z' fill='%23fff'/%3E%3C/g%3E%3C/svg%3E")}

/* Cumpleaños · festivo (coral) */
.theme-festive{--accent:#e0553b;--line:#f3d3c8;--page:#fffaf7;--veil1:rgba(255,251,248,.86);--veil2:rgba(255,244,236,.92);--bar:rgba(255,252,250,.82);--panel:rgba(255,255,255,.86);--headfont:'Poppins',system-ui,sans-serif;--navfont:'Poppins',system-ui,sans-serif}

/* Bautizo · pastel (azul suave) */
.theme-pastel{--accent:#4a7aab;--line:#d6e4ef;--page:#f6fbfd;--veil1:rgba(247,251,253,.86);--veil2:rgba(238,246,251,.92);--bar:rgba(250,253,255,.82);--panel:rgba(255,255,255,.86);--headfont:'Quicksand',system-ui,sans-serif;--navfont:'Quicksand',system-ui,sans-serif}

/* Clásico · neutro (burdeos) */
.theme-classic{--accent:#7d2e3c;--line:#e2d8d2;--page:#faf8f6;--veil1:rgba(250,248,246,.85);--veil2:rgba(245,240,236,.92);--bar:rgba(252,250,249,.82);--panel:rgba(255,255,255,.85);--headfont:'Cormorant Garamond',Georgia,serif;--navfont:'Montserrat',system-ui,sans-serif}

/* selector de estilo (admin) */
.themecard{align-items:stretch}
.swatch{border-radius:10px;padding:16px 14px;display:flex;align-items:center;gap:10px;min-height:54px}
.swatch .dot{width:18px;height:18px;border-radius:50%;flex:0 0 auto}
.btn{display:inline-block;background:var(--accent);color:#fff;border:none;border-radius:8px;padding:8px 14px;font-size:14px;cursor:pointer}
.btn.sm{padding:4px 8px;font-size:12px}
.btn.ghost{background:transparent;color:var(--muted);border:1px solid var(--line)}

/* rejilla de fotos */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px}
.grid a{display:block;aspect-ratio:3/2;border-radius:8px;overflow:hidden;background:#eee}
.grid img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}
.grid img:hover{transform:scale(1.04)}

/* foto individual */
.viewer{text-align:center}
.viewer img{max-width:100%;max-height:80vh;border-radius:10px}

/* login */
.card{max-width:360px;margin:40px auto;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:24px}
.card input{width:100%;padding:10px;margin:6px 0;border:1px solid var(--line);border-radius:8px}
.error{color:#b00020;font-size:14px}
.linkbox{background:#f3eee7;border:1px dashed var(--accent);border-radius:8px;padding:8px;font-family:monospace;font-size:13px;word-break:break-all}
form.inline{display:inline}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
