:root{--primary-color: #8B4513;--secondary-color: #D2B48C;--accent-color: #A52A2A;--light-color: #F5F5DC;--dark-color: #3E2723;--text-color: #333;--light-text: #FFF;--shadow: 0 4px 6px rgba(0, 0, 0, .1);--success-color: #28a745;--error-color: #dc3545}*{margin:0;padding:0;box-sizing:border-box;font-family:Microsoft YaHei,Segoe UI,sans-serif}body{background-color:#f9f9f9;color:var(--text-color);line-height:1.6;opacity:0;animation:pageFadeIn .4s ease-out forwards}@keyframes pageFadeIn{0%{opacity:0}to{opacity:1}}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 15px}header{background:linear-gradient(to right,var(--primary-color),var(--accent-color));color:var(--light-text);box-shadow:var(--shadow);position:sticky;top:0;z-index:1000}.navbar{display:flex;justify-content:space-between;align-items:center;padding:15px 0}.logo{display:flex;align-items:center;font-size:1.8rem;font-weight:700}.logo svg{margin-right:10px;width:40px;height:40px;flex-shrink:0}.logo-text{color:var(--light-text);font-size:1.5rem;white-space:nowrap}.logo a{color:var(--light-text);text-decoration:none;display:flex;align-items:center}.nav-links{display:flex;list-style:none}.nav-links li{margin-left:25px}.nav-links a{color:var(--light-text);text-decoration:none;font-size:1.1rem;transition:all .3s ease;padding:5px 10px;border-radius:4px;position:relative;overflow:hidden}.nav-links a:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#ffffff4d;border-radius:50%;transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease}.nav-links a:active:after{width:200px;height:200px}.nav-links a:hover,.nav-links a.active{background-color:#fff3}.auth-buttons{display:flex;align-items:center}.auth-buttons button{background-color:var(--secondary-color);border:none;padding:8px 15px;border-radius:4px;cursor:pointer;margin-left:10px;transition:all .3s ease;color:var(--dark-color);font-weight:700}.auth-buttons button:hover{background-color:var(--light-color)}.user-info{position:relative;display:flex;align-items:center;color:var(--light-text);cursor:pointer;padding:5px 10px;border-radius:4px;transition:all .3s ease}.user-info:hover{background-color:#fff3}.user-info i{margin-right:8px;font-size:1.2rem}.logout-menu{position:absolute;top:100%;right:0;background:#fff;box-shadow:0 2px 10px #0000001a;border-radius:4px;padding:10px;z-index:1000;min-width:100px}.logout-menu a{color:var(--text-color);text-decoration:none;white-space:nowrap;display:block;padding:5px 0}.logout-menu a:hover{color:var(--primary-color)}.main-content{padding:40px 0;min-height:calc(100vh - 200px);opacity:0;animation:contentFadeIn .5s ease-out .2s forwards}@keyframes contentFadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.page-header{text-align:center;margin-top:40px;margin-bottom:30px;opacity:0;animation:headerFadeIn .5s ease-out .3s forwards}@keyframes headerFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-title{font-size:2.2rem;color:var(--dark-color);margin-bottom:10px}.page-subtitle{color:#666;font-size:1.1rem}.followed-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:25px;margin-bottom:40px}.followed-card{background:#fff;border-radius:8px;box-shadow:var(--shadow);overflow:hidden;transition:all .3s ease;position:relative}.followed-card:hover{transform:translateY(-5px);box-shadow:0 10px 20px #00000026}.reminder-badge{position:relative;width:40px;height:40px;border-radius:0 0 0 50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#fff;box-shadow:0 2px 4px #0003;z-index:10}.anniversary-badge{background:linear-gradient(135deg,#ffd700e6,#ffa500e6)}.memorial-badge{background:linear-gradient(135deg,#90ee90e6,#228b22e6)}.badge-container{position:absolute;top:0;right:0;display:flex;flex-direction:row-reverse;align-items:flex-start;z-index:10}.badge-container .reminder-badge{margin-left:0}.reminder-text-container{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:20px;margin-bottom:30px;min-height:60px;transition:all .3s ease}.reminder-text-item{display:flex;align-items:center;padding:8px 0;border-bottom:1px solid #f0f0f0;font-size:.95rem;line-height:1.5}.reminder-text-item:last-child{border-bottom:none}.reminder-text-item .person-name{font-weight:700;color:var(--primary-color);min-width:60px;margin-right:15px}.reminder-text-item .date-info{color:#666;flex:1}.reminder-text-item .days-left{color:#000;font-weight:400;font-family:SimSun,宋体,serif;margin-left:10px}.reminder-text-item.anniversary{background:linear-gradient(to right,rgba(255,215,0,.1),transparent);padding-left:10px;border-radius:4px}.reminder-text-item.memorial{background:linear-gradient(to right,rgba(144,238,144,.1),transparent);padding-left:10px;border-radius:4px}.empty-reminder{color:#999;text-align:center;padding:20px;font-size:.9rem}.followed-header{display:flex;padding:20px;border-bottom:1px solid #eee}.portrait{width:80px;height:80px;border-radius:50%;background-size:cover;background-position:center;margin-right:15px;flex-shrink:0}.followed-info{flex-grow:1}.name{font-size:1.4rem;color:var(--dark-color);margin-bottom:5px}.birthDeath{font-size:.9rem;color:#666;margin-bottom:8px}.followed-body{padding:15px 20px}.followed-details{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:15px}.detail-item{display:flex;flex-direction:column}.detail-label{font-size:.85rem;color:#888;margin-bottom:3px}.detail-value{font-size:.95rem;color:var(--dark-color)}.followed-actions{display:flex;justify-content:space-between;margin-top:15px}.btn{display:inline-block;padding:8px 15px;border:none;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .3s ease;text-decoration:none;text-align:center}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--accent-color)}.btn-outline{background:transparent;border:1px solid #ddd;color:#666}.btn-outline:hover{background:#0000000d}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333}.empty-state{text-align:center;padding:60px 20px;background:#fff;border-radius:8px;box-shadow:var(--shadow)}.empty-icon{font-size:4rem;color:#ddd;margin-bottom:20px}.empty-title{font-size:1.5rem;color:#888;margin-bottom:15px}.empty-text{color:#999;margin-bottom:25px;max-width:500px;margin-left:auto;margin-right:auto}footer{background:var(--dark-color);color:var(--light-text);padding:40px 0 20px}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;margin-bottom:30px}.footer-column h3{margin-bottom:20px;position:relative;padding-bottom:10px}.footer-column h3:after{content:"";position:absolute;bottom:0;left:0;width:40px;height:2px;background:var(--secondary-color)}.footer-links{list-style:none}.footer-links li{margin-bottom:10px}.footer-links a{color:#ccc;text-decoration:none;transition:all .3s ease}.footer-links a:hover{color:var(--secondary-color);padding-left:5px}.copyright{text-align:center;padding-top:20px;border-top:1px solid #444;color:#aaa;font-size:.9rem}.birthDeath-desktop{font-size:.9rem;color:#666;margin:0 0 5px;display:block}.birthDeath-wrapper{display:none;flex-direction:column;gap:1px}.birth-date,.death-date{font-size:.8rem;color:#666;margin:0}@media (max-width: 768px){.navbar{flex-direction:column}.nav-links{margin:15px 0}.user-info{font-size:.9rem;margin:0;padding-right:0;position:relative}.user-info .logout-menu{top:50%;left:100%;right:auto;transform:translateY(-50%);margin-left:5px}.followed-list{grid-template-columns:1fr}.followed-header{flex-direction:row!important;text-align:left!important;align-items:center!important;gap:0!important}.portrait{margin-right:10px!important;margin-bottom:0!important;width:70px!important;height:70px!important;flex-shrink:0!important}.followed-info{flex:1!important;text-align:left!important;min-width:0!important;margin-left:0!important;padding-left:0!important}.followed-info .name{text-align:left;font-size:1.2rem;margin-bottom:5px}.birthDeath-desktop{display:none!important}.birthDeath-wrapper{display:flex!important}.followed-details{display:flex;flex-direction:column;gap:6px}.followed-details .detail-row{display:grid;grid-template-columns:1fr 1fr;gap:6px}.followed-list{gap:15px!important}.followed-card{transform:scale(.95);transform-origin:top center}.portrait{width:65px!important;height:65px!important;margin-right:10px!important}.followed-info .name{font-size:1.2rem!important}.birth-date,.death-date{font-size:.8rem!important}.followed-header{padding:15px!important;gap:0!important}.followed-body{padding:12px 15px!important}}@media (max-width: 576px){.followed-list{gap:12px!important}.followed-card{transform:scale(.9);transform-origin:top center}.portrait{width:60px!important;height:60px!important;margin-right:10px!important}.followed-info{margin-left:0!important;padding-left:0!important}.followed-info .name{font-size:1rem!important}.birth-date,.death-date{font-size:.7rem!important}.followed-details,.followed-details .detail-row{gap:4px!important}.followed-header{padding:12px!important;gap:0!important}.followed-body{padding:10px 12px!important}}.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;z-index:2000;align-items:center;justify-content:center}.modal-content{background:#fff;border-radius:8px;width:90%;max-width:500px;padding:30px;box-shadow:0 5px 15px #0000004d;text-align:center}.modal-title{font-size:1.5rem;margin-bottom:15px;color:var(--dark-color)}.modal-text{margin-bottom:25px;color:#666}.modal-actions{display:flex;justify-content:center;gap:15px}.sms-settings-panel{margin-bottom:30px}.settings-card{background-color:var(--light-color);border-radius:12px;padding:20px 25px;box-shadow:0 4px 15px #f5f5dc80;color:var(--dark-color);border:none}.settings-card h3{color:var(--dark-color);margin:0 0 15px;display:flex;align-items:center;gap:10px;font-size:1.1rem}.settings-content{display:flex;align-items:center;gap:25px;flex-wrap:wrap}.setting-item{display:flex;align-items:center;gap:10px;padding:0;margin:0}.setting-item:not(:last-child):after{content:"|";color:var(--secondary-color);font-size:.9rem}.setting-info{display:flex;flex-direction:column;gap:2px}.setting-info h4{margin:0;color:var(--dark-color);font-size:.95rem;font-weight:600}.setting-info p{margin:0;color:var(--text-color);font-size:.8rem}.switch{position:relative;display:inline-block;width:44px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.3s;border-radius:24px}.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0003}input:checked+.slider{background-color:var(--primary-color)}input:checked+.slider:before{transform:translate(20px)}#smsPhoneNumber{flex:1;min-width:120px;padding:8px 12px;border:2px solid var(--secondary-color);border-radius:6px;background:#fff;color:var(--dark-color);font-size:.9rem;transition:all .3s;font-weight:600}#smsPhoneNumber:focus{outline:none;border-color:var(--primary-color);background:#fff;box-shadow:0 0 0 3px #d2b48c4d}#smsPhoneNumber::placeholder{color:#999}.checkbox-group{display:flex;gap:15px}.checkbox-label{display:flex;align-items:center;gap:6px;cursor:pointer;color:var(--dark-color);font-size:.9rem;font-weight:600;transition:all .3s}.checkbox-label:hover{color:var(--primary-color)}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--primary-color)}@media (max-width: 768px){.settings-content{flex-direction:column;align-items:stretch;gap:15px}.setting-item{justify-content:space-between}.setting-item:not(:last-child):after{display:none}#phoneSetting{flex-direction:column;align-items:stretch;gap:8px}#phoneSetting label{margin-bottom:0}.checkbox-group{justify-content:flex-start}}.reminder-list{display:flex;flex-direction:column;gap:12px}.reminder-item{display:flex;align-items:center;gap:12px;padding:15px 18px;background:#fff;border-radius:8px;border-left:4px solid var(--primary-color);box-shadow:0 2px 6px #00000014;transition:all .3s}.reminder-item:hover{transform:translate(5px);box-shadow:0 4px 12px #0000001f}.reminder-item.anniversary{border-left-color:#ff6b6b}.reminder-item.memorial{border-left-color:#4ecdc4}.reminder-item i{font-size:1.2rem;width:24px;text-align:center}.reminder-item.anniversary i{color:#ff6b6b}.reminder-item.memorial i{color:#4ecdc4}.btn-send-sms{margin-left:auto;padding:8px 16px;font-size:.9rem;background:var(--primary-color);color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .3s;font-weight:600}.btn-send-sms:hover{background:var(--accent-color);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.btn-send-sms:disabled{background:#ccc;color:#666;cursor:not-allowed;transform:none;box-shadow:none}.followed-card .btn-primary{background:transparent;border:1px solid var(--primary-color);color:var(--primary-color)}.followed-card .btn-primary:hover{background:#8b45130d}.followed-card .btn-outline{background:transparent;border:1px solid #ddd;color:#666}.followed-card .btn-outline:hover{background:#0000000d}
