:root{--cream: #f6efe5;--surface: #fffdf9;--border: #ece0d2;--text-main: #5a4a43;--text-soft: #9a8d84;--text-faint: #b3a496;--accent: #c2899a;--accent-hover: #b6798c;--lavender: #9a82c4;--violet: #b48fc4;--font-serif: "Cormorant Garamond", Georgia, serif;--font-script: "Caveat", cursive;--font-sans: "Mulish", system-ui, sans-serif;--radius-sm: 14px;--radius-md: 20px;--radius-lg: 26px;--shadow: 0 18px 36px -28px rgba(120, 96, 90, .5);--shadow-hover: 0 24px 48px -20px rgba(120, 96, 90, .35);--shadow-modal: 0 32px 64px -16px rgba(90, 74, 67, .22);--sidebar-w: 218px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-sans);background:var(--cream);color:var(--text-main);-webkit-font-smoothing:antialiased}@keyframes petalFloat{0%{transform:translateY(110vh) rotate(0);opacity:0}10%{opacity:1}90%{opacity:.8}to{transform:translateY(-12vh) rotate(360deg);opacity:0}}.petal{position:fixed;border-radius:60% 40% 70% 30%/50% 60% 40% 50%;animation:petalFloat linear infinite;pointer-events:none;z-index:0;bottom:-10vh}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(120% 120% at 30% 20%,#f7f0e8,#f2ebe6 38%,#ece6f0);overflow:hidden;position:relative}.login-card{position:relative;z-index:1;background:#fffdf9b8;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid var(--border);border-radius:var(--radius-lg);padding:52px 48px 44px;width:100%;max-width:400px;text-align:center;box-shadow:var(--shadow-modal)}.login-logo{font-family:var(--font-script);font-size:60px;color:var(--accent);line-height:1;margin-bottom:16px;display:inline-block}.login-tagline{font-family:var(--font-serif);font-style:italic;font-size:18px;color:var(--text-soft);line-height:1.6;margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:12px}.login-input{width:100%;padding:13px 18px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-family:var(--font-sans);font-size:15px;color:var(--text-main);outline:none;transition:border-color .2s}.login-input:focus{border-color:var(--accent)}.login-input::placeholder{color:var(--text-faint)}.login-btn{padding:13px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font-sans);font-size:15px;font-weight:500;cursor:pointer;transition:background .2s}.login-btn:hover{background:var(--accent-hover)}.login-hint{margin-top:14px;font-size:13px;color:var(--text-faint);font-style:italic}.login-error{margin-top:12px;font-family:var(--font-script);font-size:17px;color:var(--accent)}.app-layout{display:flex;min-height:100vh}.app-main{flex:1;padding:52px 56px;min-width:0;overflow-x:hidden}.sidebar{width:var(--sidebar-w);min-height:100vh;background:linear-gradient(180deg,#fbf6ee,#f7f0e6);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:36px 0 28px;position:sticky;top:0;height:100vh;flex-shrink:0}.sidebar-logo{font-family:var(--font-script);font-size:30px;color:var(--accent);padding:0 28px;margin-bottom:36px}.sidebar-nav{display:flex;flex-direction:column;flex:1;gap:2px}.sidebar-item{display:flex;align-items:center;gap:8px;padding:10px 28px;font-family:var(--font-sans);font-size:14px;font-weight:400;color:var(--text-soft);text-decoration:none;border-radius:0;transition:background .15s,color .15s}.sidebar-item:hover{background:#f0e7d9;color:var(--text-main)}.sidebar-item.active{color:var(--text-main);font-weight:600}.sidebar-dot{color:var(--accent);font-size:8px;opacity:0;transition:opacity .15s}.sidebar-item.active .sidebar-dot{opacity:1}.sidebar-footer{padding:0 28px;display:flex;flex-direction:column;gap:14px}.sidebar-tagline{font-family:var(--font-serif);font-style:italic;font-size:13px;color:var(--text-faint)}.sidebar-logout{background:none;border:none;font-family:var(--font-sans);font-size:13px;color:var(--text-soft);cursor:pointer;text-align:left;padding:0;transition:color .15s}.sidebar-logout:hover{color:var(--accent)}.section-header{margin-bottom:40px}.section-pre{display:block;font-family:var(--font-script);font-size:18px;color:var(--accent);margin-bottom:4px}.section-title{font-family:var(--font-serif);font-size:48px;font-weight:500;color:var(--text-main);line-height:1.1;margin-bottom:10px}.section-sub{font-size:15px;color:var(--text-soft);font-weight:300}.recuerdo-card{background:#fffef9;padding:10px 10px 0;box-shadow:0 2px 4px #0000001a,0 6px 18px #50371e24;transform:rotate(var(--rot, -1deg));cursor:pointer;position:relative;border-radius:2px;display:flex;flex-direction:column}.recuerdo-card:before,.recuerdo-card:after{content:"";position:absolute;width:18px;height:18px;border:2px solid rgba(194,137,154,.5);z-index:1}.recuerdo-card:before{top:6px;left:6px;border-right:none;border-bottom:none}.recuerdo-card:after{top:6px;right:6px;border-left:none;border-bottom:none}.recuerdo-card-photo{overflow:hidden;border-radius:1px}.recuerdo-card-body{padding:12px 6px 18px}.recuerdo-date{display:block;font-family:var(--font-script);font-size:15px;color:var(--accent);margin-bottom:6px}.recuerdo-title{font-family:var(--font-serif);font-size:24px;font-weight:500;color:var(--text-main);margin-bottom:8px;line-height:1.2}.recuerdo-desc{font-size:14px;color:var(--text-soft);line-height:1.55;font-weight:300}.placeholder{width:100%;position:relative;overflow:hidden}.placeholder-tag{font-family:ui-monospace,monospace;font-size:11px;color:var(--text-soft);background:#ffffff8c;padding:4px 10px;border-radius:6px;letter-spacing:.02em}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#3c281485;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.recuerdo-spread{display:flex;width:100%;max-width:820px;max-height:88vh;border-radius:6px 10px 10px 6px;overflow:hidden;box-shadow:0 8px 24px #0003,0 28px 72px #00000047}.recuerdo-spread-left{flex:1.1;background:radial-gradient(ellipse at 20% 80%,rgba(220,205,180,.45) 0%,transparent 55%),#ede5d5;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:36px 28px 24px;gap:14px}.recuerdo-spread-frame{width:100%;max-width:320px;aspect-ratio:4/3;background:#fff;padding:8px;box-shadow:0 4px 16px #00000029;border-radius:2px;overflow:hidden;position:relative}.recuerdo-spread-date{font-family:var(--font-script);font-size:17px;color:var(--text-soft);text-align:center}.spread-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffffd1;border:none;border-radius:50%;width:30px;height:30px;font-size:18px;color:var(--text-main);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;transition:background .15s}.spread-nav:hover{background:#fff}.spread-nav--prev{left:6px}.spread-nav--next{right:6px}.spread-counter{position:absolute;bottom:6px;left:50%;transform:translate(-50%);font-size:11px;font-family:ui-monospace,monospace;color:var(--text-soft);background:#ffffffb3;padding:2px 7px;border-radius:8px}.recuerdo-spread-spine{width:16px;flex-shrink:0;background:linear-gradient(90deg,#c0a880,#d4bc98 50%,#c0a880);box-shadow:inset -3px 0 6px #0000001a,inset 3px 0 6px #ffffff14}.recuerdo-spread-right{flex:1;background:radial-gradient(ellipse at 80% 20%,rgba(252,238,210,.6) 0%,transparent 50%),#fefaf3;padding:44px 40px 36px;position:relative;display:flex;flex-direction:column;justify-content:center;gap:14px;overflow-y:auto}.recuerdo-spread-title{font-family:var(--font-serif);font-size:30px;font-weight:500;font-style:italic;color:var(--text-main);line-height:1.2}.recuerdo-spread-text{font-size:15px;font-weight:300;color:var(--text-soft);line-height:1.8}.spread-etiqueta{font-family:ui-monospace,monospace;font-size:11px;color:var(--text-faint);letter-spacing:.06em}.spread-corazon{font-family:var(--font-script);font-size:26px;color:var(--accent)}@media (max-width: 640px){.recuerdo-spread{flex-direction:column;max-height:95vh;overflow-y:auto;border-radius:10px}.recuerdo-spread-spine{width:100%;height:14px;background:linear-gradient(180deg,#c0a880,#d4bc98 50%,#c0a880)}.recuerdo-spread-left{padding:24px 20px 12px}.recuerdo-spread-right{padding:20px 24px 28px}}.album{display:flex;gap:0;background:#e8ddd0;border-radius:6px 12px 12px 6px;box-shadow:0 4px 12px #50371e24,0 16px 48px -8px #50371e2e,inset -3px 0 8px #0000000f;min-height:400px;overflow:hidden}.album-spine{width:36px;flex-shrink:0;background:linear-gradient(180deg,#c4a882,#b09060 40%,#c4a882);display:flex;align-items:center;justify-content:center;box-shadow:inset -4px 0 10px #00000026,inset 3px 0 6px #ffffff1a;border-radius:6px 0 0 6px}.album-spine-text{writing-mode:vertical-rl;transform:rotate(180deg);font-family:var(--font-script);font-size:13px;color:#fffaf0bf;letter-spacing:.08em;white-space:nowrap}.album-pages{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:36px;padding:40px 44px;background:radial-gradient(ellipse at 10% 90%,rgba(220,205,180,.4) 0%,transparent 50%),radial-gradient(ellipse at 90% 10%,rgba(230,215,190,.3) 0%,transparent 50%),#f4ede0}.foto-print{display:flex;flex-direction:column;background:#fffef9;padding:10px 10px 30px;box-shadow:0 2px 4px #0000001a,0 6px 18px #50371e24;transform:rotate(var(--rot, -1deg));cursor:pointer;position:relative;transition:box-shadow .25s;border-radius:2px}.foto-print:hover{box-shadow:0 8px 24px #00000029,0 16px 40px #50371e2e}.foto-print:before,.foto-print:after{content:"";position:absolute;width:18px;height:18px;border:2px solid rgba(194,137,154,.5);z-index:1}.foto-print:before{top:6px;left:6px;border-right:none;border-bottom:none}.foto-print:after{bottom:26px;right:6px;border-left:none;border-top:none}.foto-print-img{overflow:hidden;border-radius:1px}.foto-print-cap{font-family:var(--font-script);font-size:15px;color:var(--text-soft);text-align:center;margin-top:10px;line-height:1.2}.spread-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#3c28148c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.spread{display:flex;width:100%;max-width:860px;max-height:90vh;border-radius:6px 10px 10px 6px;overflow:hidden;box-shadow:0 4px 12px #0003,0 24px 64px #0000004d}.spread-left{flex:1.1;background:radial-gradient(ellipse at 20% 80%,rgba(220,205,180,.5) 0%,transparent 55%),#f0e8d8;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 32px 28px;gap:16px}.spread-photo-frame{width:100%;max-width:340px;aspect-ratio:4/3;background:#fff;padding:8px;box-shadow:0 4px 16px #00000029;border-radius:2px;overflow:hidden}.spread-foto-cap{font-family:var(--font-script);font-size:17px;color:var(--text-soft);text-align:center}.spread-spine{width:18px;flex-shrink:0;background:linear-gradient(90deg,#bfa880,#d4bc98 40%,#c8ae84 70%,#bfa880);box-shadow:inset -3px 0 6px #0000001f,inset 3px 0 6px #ffffff14}.spread-right{flex:1;background:radial-gradient(ellipse at 80% 20%,rgba(252,238,210,.6) 0%,transparent 50%),#fefaf3;padding:44px 40px 36px;position:relative;display:flex;flex-direction:column;justify-content:center;gap:16px}.spread-close{position:absolute;top:14px;right:14px;background:none;border:1px solid var(--border);border-radius:50%;width:28px;height:28px;font-size:12px;color:var(--text-soft);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s}.spread-close:hover{color:var(--accent);border-color:var(--accent)}.spread-etiqueta{font-family:ui-monospace,monospace;font-size:11px;color:var(--text-faint);letter-spacing:.06em;text-transform:lowercase}.spread-titulo{font-family:var(--font-serif);font-size:32px;font-weight:500;font-style:italic;color:var(--text-main);line-height:1.2}.spread-desc{font-family:var(--font-sans);font-size:15px;font-weight:300;color:var(--text-soft);line-height:1.75}.spread-corazon{font-family:var(--font-script);font-size:28px;color:var(--accent);margin-top:8px}@media (max-width: 640px){.spread{flex-direction:column;max-height:95vh;overflow-y:auto}.spread-spine{width:100%;height:14px;background:linear-gradient(180deg,#bfa880,#d4bc98 40%,#bfa880)}.spread-left{padding:28px 24px 16px}.spread-right{padding:24px}.album-pages{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:24px;padding:24px}}.poemas-list{max-width:640px}.poema-row{display:flex;align-items:baseline;gap:20px;padding:18px 0;text-decoration:none;color:var(--text-main);transition:transform .2s}.poema-row:hover{transform:translate(6px)}.poema-num{font-family:var(--font-serif);font-style:italic;font-size:17px;color:var(--text-faint);min-width:28px}.poema-title-list{font-family:var(--font-serif);font-size:27px;font-weight:500;flex:1}.poema-year{font-family:var(--font-script);font-size:15px;color:var(--accent)}.poema-divider{border:none;border-top:1px solid var(--border)}.poema-back{display:inline-block;font-size:13px;color:var(--text-soft);text-decoration:none;margin-bottom:32px;transition:color .15s}.poema-back:hover{color:var(--accent)}.carta-wrapper{max-width:720px;margin:0 auto}.carta{position:relative;background:#fefaf3;background-image:radial-gradient(ellipse at 18% 22%,rgba(252,235,205,.75) 0%,transparent 55%),radial-gradient(ellipse at 82% 78%,rgba(238,218,185,.55) 0%,transparent 55%);border-radius:4px;box-shadow:0 1px 3px #64461e17,0 6px 20px #7850281c,0 20px 56px -8px #643c1424,inset 0 1px #fffcf4e6;padding:72px 72px 64px;overflow:visible}.carta-pliegue{position:absolute;left:0;right:0;top:50%;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(160,115,55,.18) 15%,rgba(160,115,55,.22) 50%,rgba(160,115,55,.18) 85%,transparent 100%);pointer-events:none}.carta-sello{position:absolute;top:-16px;left:50%;transform:translate(-50%);width:36px;height:36px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;box-shadow:0 3px 10px #c2899a80;z-index:2}.carta-titulo{font-family:var(--font-serif);font-style:italic;font-size:46px;font-weight:500;color:var(--text-main);text-align:center;margin-bottom:22px;margin-top:8px;line-height:1.2}.carta-linea{height:1px;width:72px;margin:0 auto 40px;background:linear-gradient(90deg,transparent,var(--accent),transparent);transform-origin:left center}.carta-versos{display:flex;flex-direction:column;gap:32px;margin-bottom:44px}.carta-bloque{font-family:var(--font-serif);font-size:26px;line-height:2.1;color:var(--text-main);white-space:pre-line;text-align:center}.carta-firma{font-family:var(--font-script);font-size:24px;color:var(--accent);text-align:center}.calendario-layout{display:grid;grid-template-columns:280px 1fr 1fr;gap:36px;align-items:start}.cal-card{background:var(--surface);border-radius:var(--radius-md);padding:28px;box-shadow:var(--shadow)}.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.cal-month-title{font-family:var(--font-serif);font-size:20px;font-weight:500;color:var(--text-main);text-align:center}.cal-nav-btn{background:none;border:1px solid var(--border);border-radius:8px;width:30px;height:30px;font-size:18px;color:var(--text-soft);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s}.cal-nav-btn:hover{color:var(--accent);border-color:var(--accent)}.cal-grid-header{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:8px}.cal-day-label{font-size:11px;font-weight:600;color:var(--text-faint);text-align:center;letter-spacing:.05em}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-cell{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:13px;font-weight:300;color:var(--text-soft);border-radius:8px;position:relative;gap:2px}.cal-cell.has-event{background:#c2899a1a;color:var(--accent);font-weight:500}.cal-dot{font-size:6px;color:var(--accent);line-height:1}.eventos-columna{display:flex;flex-direction:column}.eventos-title{font-family:var(--font-serif);font-size:20px;font-weight:500;color:var(--text-main);margin-bottom:18px}.proximas-title{color:var(--lavender)}.eventos-empty{font-family:var(--font-script);font-size:16px;color:var(--text-faint)}.eventos-list{display:flex;flex-direction:column;gap:20px}.evento-item{display:flex;align-items:flex-start;gap:20px;padding-bottom:20px;border-bottom:1px solid var(--border)}.evento-item:last-child{border-bottom:none}.evento-date{display:flex;flex-direction:column;align-items:center;min-width:40px}.evento-day{font-family:var(--font-serif);font-size:32px;font-weight:500;color:var(--accent);line-height:1}.evento-month{font-size:11px;font-weight:600;color:var(--text-faint);letter-spacing:.06em;text-transform:uppercase}.evento-year{font-size:10px;color:var(--text-faint);font-weight:300}.evento-info{display:flex;flex-direction:column;gap:4px;padding-top:4px}.evento-label{font-size:15px;font-weight:500;color:var(--text-main)}.evento-note{font-family:var(--font-script);font-size:16px;color:var(--text-soft)}@media (max-width: 768px){.sidebar{width:100%;height:auto;min-height:unset;flex-direction:row;align-items:center;padding:12px 20px;position:fixed;top:0;left:0;right:0;z-index:50;border-right:none;border-bottom:1px solid var(--border)}.sidebar-logo{margin-bottom:0;font-size:22px}.sidebar-nav{flex-direction:row;flex:unset;gap:0}.sidebar-item{padding:8px 12px;font-size:13px}.sidebar-footer{display:none}.app-main{padding:88px 20px 40px}.section-title{font-size:36px}.calendario-layout{grid-template-columns:1fr;gap:28px}}@media (prefers-reduced-motion: reduce){.petal{animation:none}*{transition-duration:.01ms!important;animation-duration:.01ms!important}}
