@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-duration:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-cyan-600:oklch(60.9% .126 221.723);--color-cyan-700:oklch(52% .105 223.128);--color-gray-700:oklch(37.3% .034 259.733);--color-gray-800:oklch(27.8% .033 256.848);--color-gray-900:oklch(21% .034 264.665);--color-white:#fff;--spacing:.25rem;--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--radius-lg:.5rem;--ease-in-out:cubic-bezier(.4,0,.2,1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.fixed{position:fixed}.top-0{top:calc(var(--spacing)*0)}.left-0{left:calc(var(--spacing)*0)}.z-50{z-index:50}.mb-2{margin-bottom:calc(var(--spacing)*2)}.ml-4{margin-left:calc(var(--spacing)*4)}.block{display:block}.flex{display:flex}.h-10{height:calc(var(--spacing)*10)}.h-full{height:100%}.w-80{width:calc(var(--spacing)*80)}.flex-1{flex:1}.-translate-x-full{--tw-translate-x:-100%;translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-0{--tw-translate-x:calc(var(--spacing)*0);translate:var(--tw-translate-x)var(--tw-translate-y)}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-3{gap:calc(var(--spacing)*3)}.overflow-y-auto{overflow-y:auto}.rounded-lg{border-radius:var(--radius-lg)}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-gray-700{border-color:var(--color-gray-700)}.bg-cyan-600{background-color:var(--color-cyan-600)}.bg-gray-800{background-color:var(--color-gray-800)}.bg-gray-900{background-color:var(--color-gray-900)}.p-2{padding:calc(var(--spacing)*2)}.p-3{padding:calc(var(--spacing)*3)}.p-4{padding:calc(var(--spacing)*4)}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-white{color:var(--color-white)}.italic{font-style:italic}.shadow-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a),0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-300{--tw-duration:.3s;transition-duration:.3s}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}@media(hover:hover){.hover\:bg-cyan-700:hover{background-color:var(--color-cyan-700)}.hover\:bg-gray-700:hover{background-color:var(--color-gray-700)}.hover\:bg-gray-800:hover{background-color:var(--color-gray-800)}}}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#ede9fe,#f5f3ff,#e0e7ff);min-height:100vh;margin:0;font-family:Nunito,sans-serif}@keyframes float{0%,to{transform:translateY(0)rotate(-4deg)}50%{transform:translateY(-18px)rotate(4deg)}}@keyframes heartOpen{0%{transform:scale(1)rotate(0)}40%{transform:scale(1.5)rotate(12deg)}70%{transform:scale(.9)rotate(-6deg)}to{transform:scale(.75)rotate(-3deg)}}@keyframes noteReveal{0%{opacity:0;transform:translateY(10px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 #7c3aed66}50%{box-shadow:0 0 0 12px #7c3aed00}}@keyframes bgFloat{0%{opacity:.08;transform:translateY(0)rotate(0)scale(1)}50%{opacity:.12;transform:translateY(-30px)rotate(15deg)scale(1.1)}to{opacity:.08;transform:translateY(0)rotate(0)scale(1)}}.login-page{justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.floating-hearts{pointer-events:none;position:absolute;inset:0}.bg-heart{color:#7c3aed;font-size:4rem;animation:6s ease-in-out infinite bgFloat;position:absolute}.bg-heart:first-child{font-size:3rem;animation-delay:0s;top:5%;left:8%}.bg-heart:nth-child(2){font-size:5rem;animation-delay:.8s;top:15%;left:85%}.bg-heart:nth-child(3){font-size:2.5rem;animation-delay:1.6s;top:40%;left:5%}.bg-heart:nth-child(4){font-size:3.5rem;animation-delay:2.4s;top:70%;left:90%}.bg-heart:nth-child(5){font-size:4.5rem;animation-delay:3.2s;top:80%;left:20%}.bg-heart:nth-child(6){font-size:2rem;animation-delay:4s;top:55%;left:75%}.bg-heart:nth-child(7){font-size:1.5rem;animation-delay:4.8s;top:25%;left:50%}.bg-heart:nth-child(8){font-size:3rem;animation-delay:5.6s;top:90%;left:55%}.login-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);text-align:center;z-index:10;background:#ffffffd9;border:2px solid #7c3aed33;border-radius:2rem;width:calc(100% - 2rem);max-width:420px;padding:3rem 2.5rem;position:relative;box-shadow:0 20px 60px #7c3aed1f,0 4px 20px #0000000d}.login-logo{filter:drop-shadow(0 2px 8px #7c3aed4d);margin-bottom:.75rem;font-size:4rem}.login-title{color:#5b21b6;margin:0 0 .4rem;font-family:Fjalla One,sans-serif;font-size:2.25rem}.login-subtitle{color:#8b5cf6;margin:0 0 2rem;font-size:1.05rem;font-style:italic}.login-form{flex-direction:column;gap:1rem;display:flex}.login-input{text-align:center;color:#1f2937;background:#fff;border:2px solid #ddd6fe;border-radius:999px;outline:none;padding:.85rem 1.25rem;font-family:Nunito,sans-serif;font-size:1rem;font-weight:500;transition:border-color .2s,box-shadow .2s}.login-input:focus{border-color:#7c3aed;box-shadow:0 0 0 4px #7c3aed1f}.login-input::placeholder{color:#c4b5fd}.login-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#7c3aed,#a78bfa);border:none;border-radius:999px;padding:.85rem 2rem;font-family:Nunito,sans-serif;font-size:1.1rem;font-weight:700;transition:transform .15s,box-shadow .15s,opacity .15s;box-shadow:0 4px 16px #7c3aed59}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #7c3aed66}.login-btn:disabled{opacity:.55;cursor:not-allowed}.login-error{color:#5b21b6;background:#f5f3ff;border:1px solid #ddd6fe;border-radius:.75rem;margin:0;padding:.5rem 1rem;font-size:.9rem}.dashboard-page{flex-direction:column;min-height:100vh;display:flex}.dashboard-header{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:20;background:#ffffffb3;border-bottom:1px solid #7c3aed26;padding:1.25rem 1.5rem;position:sticky;top:0}.dashboard-header-inner{justify-content:space-between;align-items:center;gap:1rem;max-width:1100px;margin:0 auto;display:flex}.dashboard-greeting{align-items:center;gap:.75rem;display:flex}.dashboard-logo{filter:drop-shadow(0 2px 6px #7c3aed4d);font-size:2.25rem}.dashboard-title{color:#5b21b6;margin:0 0 .1rem;font-family:Fjalla One,sans-serif;font-size:1.6rem}.dashboard-subtitle{color:#7c3aed;margin:0;font-size:.9rem}.dashboard-logout{color:#7c3aed;cursor:pointer;background:0 0;border:2px solid #ddd6fe;border-radius:999px;padding:.4rem 1rem;font-family:Nunito,sans-serif;font-size:.875rem;font-weight:600;transition:background .2s,color .2s}.dashboard-logout:hover{color:#fff;background:#7c3aed;border-color:#7c3aed}.dashboard-main{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:3rem 1.5rem}.hearts-grid{flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:2.5rem;display:flex}.dashboard-empty{text-align:center;padding:6rem 2rem}.dashboard-empty-icon{margin-bottom:1.5rem;font-size:5rem}.dashboard-empty-text{color:#8b5cf6;font-size:1.2rem;font-style:italic}.heart-note-wrapper{top:var(--y-offset,0px);flex-direction:column;align-items:center;gap:1rem;display:flex;position:relative}.heart-btn{cursor:pointer;background:0 0;border:none;padding:.5rem;transition:transform .3s cubic-bezier(.34,1.56,.64,1);position:relative}.heart-btn:hover{transform:scale(1.08)}.heart-btn-fresh{animation:3s ease-in-out infinite float;animation-delay:var(--delay,0s);color:#7c3aed;filter:drop-shadow(0 4px 12px #7c3aed66)}.heart-btn-fresh:hover{filter:drop-shadow(0 6px 18px #7c3aed8c)}.heart-btn-opening{color:#7c3aed;animation:.5s cubic-bezier(.34,1.56,.64,1) forwards heartOpen!important}.heart-btn-opened{color:#c4b5fd;opacity:.7;transform:scale(.75)rotate(-3deg)}.heart-svg{width:80px;height:80px;display:block}.heart-pulse{pointer-events:none;border-radius:50%;animation:2s ease-in-out infinite pulse-glow;position:absolute;inset:0}.note-overlay{z-index:99;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);cursor:pointer;background:#5b21b61f;justify-content:center;align-items:center;animation:.25s both noteReveal;display:flex;position:fixed;inset:0}.note-card{z-index:100;text-align:center;cursor:default;background:#fffffffa;border:2px solid #ddd6fe;border-radius:1.75rem;width:min(600px,88vw);max-height:75vh;padding:2.5rem 3rem;animation:.35s cubic-bezier(.34,1.56,.64,1) both noteReveal;position:relative;overflow-y:auto;box-shadow:0 32px 80px #7c3aed2e,0 8px 24px #00000014}.note-card-title{color:#5b21b6;margin:0 0 1.25rem;font-family:Fjalla One,sans-serif;font-size:1.5rem}.note-card-content{color:#374151;white-space:pre-wrap;text-align:left;margin:0 0 1.75rem;font-size:1.05rem;line-height:1.75}.note-card-close{color:#c4b5fd;cursor:pointer;margin:0;font-size:.8rem;font-style:italic;transition:color .15s}.note-card-close:hover{color:#7c3aed}.note-card-content-html p{margin:0 0 .75rem}.note-card-content-html p:last-child{margin:0}.note-card-content-html ul,.note-card-content-html ol{margin:0 0 .75rem;padding-left:1.5rem}.note-card-content-html li{margin-bottom:.25rem}.note-card-content-html strong{font-weight:700}.note-card-content-html em{font-style:italic}.note-card-content-html s{text-decoration:line-through}.note-card-content-html h1,.note-card-content-html h2,.note-card-content-html h3{color:#5b21b6;margin:0 0 .5rem;font-family:Fjalla One,sans-serif}.note-card-content-html blockquote{color:#6b7280;border-left:3px solid #ddd6fe;margin:0 0 .75rem;padding-left:1rem}.rte-wrapper{background:#fff;border:2px solid #ede9fe;border-radius:.75rem;overflow:hidden}.rte-toolbar{background:#faf5ff;border-bottom:1.5px solid #ede9fe;flex-wrap:wrap;align-items:center;gap:.25rem;padding:.5rem .75rem;display:flex}.rte-btn{color:#7c3aed;cursor:pointer;background:#fff;border:1.5px solid #ddd6fe;border-radius:.4rem;padding:.2rem .6rem;font-family:Nunito,sans-serif;font-size:.8rem;font-weight:700;line-height:1.4;transition:background .15s,border-color .15s}.rte-btn:hover{background:#ede9fe;border-color:#7c3aed}.rte-btn-active{color:#fff;background:#7c3aed;border-color:#7c3aed}.rte-divider{background:#e9d5ff;flex-shrink:0;width:1px;height:18px;margin:0 .25rem}.rte-editor{color:#1f2937;outline:none;min-height:130px;padding:.85rem 1rem;font-family:Nunito,sans-serif;font-size:.95rem;line-height:1.65}.rte-editor p{margin:0 0 .5rem}.rte-editor p:last-child{margin:0}.rte-editor ul,.rte-editor ol{margin:0 0 .5rem;padding-left:1.5rem}.rte-editor strong{font-weight:700}.rte-editor em{font-style:italic}.rte-editor s{text-decoration:line-through}.rte-editor blockquote{color:#6b7280;border-left:3px solid #ddd6fe;margin:0 0 .5rem;padding-left:1rem}.admin-edit-overlay{z-index:200;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);cursor:pointer;background:#5b21b61f;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.admin-edit-modal{cursor:default;background:#fff;border-radius:1.5rem;width:min(640px,92vw);max-height:88vh;padding:2rem 2.25rem;overflow-y:auto;box-shadow:0 24px 80px #7c3aed2e}.admin-edit-actions{align-items:center;gap:.75rem;display:flex}.admin-page{background:#f5f3ff;min-height:100vh}.admin-header{background:#fff;border-bottom:2px solid #ede9fe;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex}.admin-header-left{align-items:center;gap:.75rem;display:flex}.admin-logo{font-size:1.75rem}.admin-title{color:#5b21b6;margin:0;font-family:Fjalla One,sans-serif;font-size:1.3rem}.admin-logout-btn{color:#7c3aed;cursor:pointer;background:0 0;border:2px solid #ddd6fe;border-radius:999px;padding:.35rem 1rem;font-family:Nunito,sans-serif;font-size:.875rem;font-weight:600;transition:background .2s,color .2s}.admin-logout-btn:hover{color:#fff;background:#7c3aed;border-color:#7c3aed}.admin-tabs{background:#fff;border-bottom:2px solid #ede9fe;padding:0 2rem;display:flex}.admin-tab{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;padding:.75rem 1.5rem;font-family:Nunito,sans-serif;font-size:.95rem;font-weight:600;transition:color .2s,border-color .2s}.admin-tab:hover{color:#7c3aed}.admin-tab-active{color:#5b21b6;border-bottom-color:#7c3aed}.admin-main{max-width:1000px;margin:0 auto;padding:2rem 1.5rem}.admin-section{flex-direction:column;gap:1.5rem;display:flex}.admin-card{background:#fff;border:1px solid #ede9fe;border-radius:1.25rem;padding:1.75rem 2rem;box-shadow:0 2px 12px #7c3aed0f}.admin-card-title{color:#5b21b6;margin:0 0 1.25rem;font-family:Fjalla One,sans-serif;font-size:1.1rem}.admin-form{flex-direction:column;gap:.75rem;display:flex}.admin-input{color:#1f2937;box-sizing:border-box;background:#f5f3ff;border:2px solid #ede9fe;border-radius:.75rem;outline:none;width:100%;padding:.7rem 1rem;font-family:Nunito,sans-serif;font-size:.95rem;font-weight:500;transition:border-color .2s}.admin-input:focus{border-color:#7c3aed}.admin-select{cursor:pointer}.admin-textarea{resize:vertical;border-radius:.75rem;min-height:100px}.admin-btn-primary{color:#fff;cursor:pointer;background:linear-gradient(135deg,#7c3aed,#a78bfa);border:none;border-radius:999px;align-self:flex-start;padding:.7rem 1.5rem;font-family:Nunito,sans-serif;font-size:.95rem;font-weight:700;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 12px #7c3aed4d}.admin-btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 18px #7c3aed66}.admin-btn-secondary{color:#7c3aed;cursor:pointer;background:#ede9fe;border:1px solid #ddd6fe;border-radius:999px;padding:.3rem .75rem;font-family:Nunito,sans-serif;font-size:.8rem;font-weight:600;transition:background .15s}.admin-btn-secondary:hover{background:#ddd6fe}.admin-btn-danger{color:#dc2626;cursor:pointer;background:#fef2f2;border:1px solid #fca5a5;border-radius:999px;padding:.3rem .75rem;font-family:Nunito,sans-serif;font-size:.8rem;font-weight:600;transition:background .15s}.admin-btn-danger:hover{background:#fee2e2}.admin-success{color:#059669;background:#d1fae5;border:1px solid #a7f3d0;border-radius:.5rem;margin:0;padding:.4rem .75rem;font-size:.875rem}.admin-table{border-collapse:collapse;width:100%;font-size:.9rem}.admin-table th{text-align:left;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #ede9fe;padding:.6rem .75rem;font-size:.8rem;font-weight:600}.admin-table td{color:#374151;vertical-align:middle;border-bottom:1px solid #f5f3ff;padding:.75rem}.admin-table tr:last-child td{border-bottom:none}.admin-code{color:#7c3aed;background:#f5f3ff;border:1px solid #e9d5ff;border-radius:.4rem;padding:.15rem .5rem;font-family:monospace;font-size:.85rem}.admin-muted{color:#9ca3af;font-size:.85rem}.admin-actions{align-items:center;gap:.5rem;display:flex}.admin-empty{color:#9ca3af;text-align:center;padding:2rem 0;font-style:italic}.admin-badge-unopened{color:#c2410c;background:#fff7ed;border:1px solid #fed7aa;border-radius:999px;padding:.2rem .6rem;font-size:.8rem;font-weight:600}.admin-badge-opened{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:999px;padding:.2rem .6rem;font-size:.8rem;font-weight:600}.heart-inner{display:block;position:relative}.heart-label-overlay{color:#fff;text-align:center;pointer-events:none;-webkit-line-clamp:3;line-clamp:3;word-break:break-word;text-shadow:0 1px 4px #5b21b680;letter-spacing:.03em;-webkit-user-select:none;user-select:none;-webkit-box-orient:vertical;max-width:75%;font-family:Fjalla One,sans-serif;line-height:1.25;display:-webkit-box;position:absolute;top:52%;left:50%;overflow:hidden;transform:translate(-50%,-50%)}.read-fab-root{z-index:50;flex-direction:column;align-items:flex-start;gap:.6rem;display:flex;position:fixed;bottom:1.5rem;left:1.5rem}.read-fab{cursor:pointer;background:linear-gradient(135deg,#7c3aed,#a78bfa);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;transition:transform .2s,box-shadow .2s;display:flex;position:relative;box-shadow:0 4px 16px #7c3aed66}.read-fab:hover{transform:scale(1.08);box-shadow:0 6px 22px #7c3aed80}.read-fab-active{background:linear-gradient(135deg,#5b21b6,#7c3aed);transform:scale(1.04)}.read-fab-icon{color:#fff;font-size:1.25rem;line-height:1}.read-fab-badge{color:#7c3aed;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-family:Nunito,sans-serif;font-size:.7rem;font-weight:800;display:flex;position:absolute;top:-4px;right:-4px;box-shadow:0 1px 4px #7c3aed40}.read-panel{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffffff5;border:1.5px solid #ddd6fe;border-radius:1.25rem;width:300px;max-height:380px;padding:1rem 1.1rem;animation:.22s cubic-bezier(.34,1.56,.64,1) both noteReveal;overflow-y:auto;box-shadow:0 8px 32px #7c3aed26}.read-panel-heading{color:#5b21b6;letter-spacing:.02em;margin:0 0 .75rem;font-family:Fjalla One,sans-serif;font-size:.95rem}.read-notes-list{flex-direction:column;gap:.5rem;display:flex}.read-note-item{cursor:pointer;text-align:left;background:#ffffffbf;border:1.5px solid #ddd6fe;border-radius:1rem;width:100%;padding:.85rem 1.1rem;font-family:Nunito,sans-serif;transition:background .15s,border-color .15s}.read-note-item:hover,.read-note-item-open{background:#fffffff2;border-color:#7c3aed}.read-note-row{align-items:center;gap:.6rem;display:flex}.read-note-heart{color:#7c3aed;flex-shrink:0;font-size:.9rem}.read-note-title-text{color:#374151;flex:1;font-size:.95rem;font-weight:600}.read-note-chevron{color:#a78bfa;flex-shrink:0;font-size:.6rem}.read-note-content{color:#4b5563;white-space:pre-wrap;border-left:2px solid #ddd6fe;margin:.85rem 0 0 1.5rem;padding-left:.85rem;font-size:.9rem;line-height:1.7}@media(max-width:640px){.login-card{border-radius:1.5rem;padding:2rem 1.5rem}.login-title{font-size:1.75rem}.dashboard-header{padding:1rem}.dashboard-header-inner{flex-wrap:wrap;gap:.6rem}.dashboard-title{font-size:1.3rem}.dashboard-subtitle{font-size:.8rem}.dashboard-main{padding:2rem 1rem}.hearts-grid{gap:1.75rem}.admin-header{padding:.875rem 1rem}.admin-tabs{padding:0 1rem}.admin-main,.admin-card{padding:1.25rem 1rem}.admin-card:has(.admin-table){overflow-x:auto}.admin-table{min-width:480px}.admin-title{font-size:1rem}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
