.frp{width:100%;max-width:1520px;margin:0 auto;padding:0 4px}.frp,.frp__layout{min-height:calc(100vh - 72px)}.frp__layout{display:grid;grid-template-columns:360px 1fr;gap:0}.frp__sidebar{position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto;background:var(--bg-primary,#fff);border-right:1px solid var(--color-divider,#ced0d4);padding:16px 8px 16px 16px;scrollbar-width:thin;scrollbar-color:transparent transparent}.frp__sidebar:hover{scrollbar-color:rgba(0,0,0,.2) transparent}.frp__sidebar::-webkit-scrollbar{width:6px}.frp__sidebar::-webkit-scrollbar-thumb{background:transparent;border-radius:3px}.frp__sidebar:hover::-webkit-scrollbar-thumb{background:rgba(0,0,0,.2)}.frp__sidebar__header{display:flex;align-items:center;justify-content:space-between;padding:0 8px 12px;border-bottom:1px solid transparent}.frp__sidebar__title{font-size:24px;font-weight:700;color:var(--color-text,#050505);margin:0;line-height:1.2}.frp__sidebar__settings{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--bg-tertiary,#e4e6eb);border:none;cursor:pointer;color:var(--color-text,#050505);transition:background .15s}.frp__sidebar__settings:hover{background:var(--color-hover,#d8dadf)}.frp__sidebar__nav{display:flex;flex-direction:column;gap:2px;margin-top:8px}.frp__sidebar__item{display:flex;align-items:center;gap:12px;padding:8px;border-radius:8px;border:none;background:none;cursor:pointer;width:100%;text-align:left;font-size:15px;font-weight:500;color:var(--color-text,#050505);transition:background .15s;position:relative}.frp__sidebar__item:hover{background:var(--color-hover,#f0f0f0)}.frp__sidebar__item--active{background:var(--color-primary,#1b74e4);color:#fff}.frp__sidebar__item--active:hover{background:var(--color-primary,#1b74e4);filter:brightness(1.1)}.frp__sidebar__item--active .frp__sidebar__icon{background:hsla(0,0%,100%,.2);color:#fff}.frp__sidebar__icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;min-width:36px;border-radius:50%;background:var(--bg-tertiary,#e4e6eb);color:var(--color-text,#050505);transition:background .15s,transform .15s}.frp__sidebar__item:hover .frp__sidebar__icon{transform:scale(1.05)}.frp__sidebar__label{flex:1;line-height:1.3}.frp__chevron{opacity:.5;margin-left:auto;transition:transform .15s}.frp__sidebar__item--active .frp__chevron{opacity:1}.frp__content{padding:20px 24px 40px;background:var(--bg-secondary,#f0f2f5);min-height:calc(100vh - 56px)}.frp__section{margin-bottom:24px}.frp__section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding:0 4px}.frp__section__title{font-size:20px;font-weight:700;color:var(--color-text,#050505);margin:0;padding-left:12px;border-left:3px solid var(--color-primary,#1b74e4)}.frp__section__seeall{font-size:14px;font-weight:500;color:var(--color-primary,#1b74e4);text-decoration:none;transition:opacity .15s;position:relative}.frp__section__seeall:after{content:" \2192";opacity:0;transition:opacity .2s;margin-left:2px}.frp__section__seeall:hover:after{opacity:1}.frp__section__seeall:hover{opacity:.85}.frp__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.frp__card{background:var(--bg-card,#fff);border-radius:10px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.frp__card:hover{box-shadow:0 4px 12px rgba(0,0,0,.1),0 2px 4px rgba(0,0,0,.06);transform:translateY(-2px)}.frp__card__img{width:100%;aspect-ratio:1;-o-object-fit:cover;object-fit:cover;display:block;background:var(--bg-tertiary,#e4e6eb);cursor:pointer}.frp__card__body{padding:10px 12px 12px;display:flex;flex-direction:column;gap:4px;flex:1}.frp__card__name{font-size:15px;font-weight:600;color:var(--color-text,#050505);text-decoration:none;display:block;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.frp__card__name:hover{text-decoration:underline}.frp__card__mutual{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--color-secondary-text,#65676b);line-height:1.4}.frp__card__actions{display:flex;flex-direction:column;gap:8px;margin-top:8px}.frp__btn{display:block;width:100%;padding:8px 12px;border-radius:6px;border:none;font-size:14px;font-weight:600;cursor:pointer;text-align:center;text-decoration:none;transition:filter .15s,transform .15s,background .15s;line-height:1.3}.frp__btn:active{transform:scale(.97)}.frp__btn--confirm{background:var(--color-primary,#1b74e4);color:#fff;box-shadow:0 1px 4px rgba(27,116,228,.25)}.frp__btn--confirm:hover{filter:brightness(1.08)}.frp__btn--delete{background:var(--color-btn-secondary,#e4e6eb);color:var(--color-text,#050505)}.frp__btn--delete:hover{background:#d8dadf}.frp__btn--secondary{background:var(--color-btn-secondary,#e4e6eb);color:var(--color-text,#050505)}.frp__btn--secondary:hover{background:#d8dadf}.frp__search{display:flex;align-items:center;gap:8px;background:var(--color-search-bg,#f0f2f5);border-radius:20px;padding:8px 16px;border:1.5px solid transparent;transition:border-color .2s,background .15s;max-width:280px;color:var(--color-secondary-text,#65676b)}.frp__search:focus-within{border-color:var(--color-primary,#1b74e4);background:var(--bg-primary,#fff)}.frp__search__input{border:none;background:transparent;outline:none;font-size:14px;color:var(--color-text,#050505);width:100%}.frp__search__input::-moz-placeholder{color:var(--color-secondary-text,#65676b)}.frp__search__input::placeholder{color:var(--color-secondary-text,#65676b)}.frp__empty{grid-column:1/-1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 20px;color:var(--color-secondary-text,#65676b);text-align:center}.frp__empty svg{width:48px;height:48px;opacity:.4}.frp__empty p{font-size:15px;font-weight:500;margin:0}.frp__empty__sub{font-size:13px;color:var(--color-secondary-text,#65676b);max-width:300px}.frp__empty__emoji{font-size:48px;line-height:1}.frp__empty--birthday{background:linear-gradient(135deg,rgba(255,152,49,.04),rgba(27,116,228,.04));border-radius:12px;padding:48px 20px}.frp__empty--custom{background:linear-gradient(135deg,rgba(200,64,233,.04),rgba(27,116,228,.04));border-radius:12px;padding:48px 20px}.frp__card--skeleton{pointer-events:none}.frp__skeleton{background:var(--color-skeleton,#e4e6eb);border-radius:4px}.frp__card--skeleton .frp__card__img,.frp__skeleton{animation:frp-shimmer 1.5s ease-in-out infinite}.frp__skeleton--name{height:16px;width:75%}.frp__skeleton--mutual{height:12px;width:55%;margin-top:2px}.frp__skeleton--btn{height:36px;width:100%;border-radius:6px;margin-top:4px}@keyframes frp-shimmer{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}@media (max-width:1024px){.frp__layout{grid-template-columns:300px 1fr}.frp__grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}@media (max-width:768px){.frp{padding:0}.frp__layout{grid-template-columns:1fr}.frp__sidebar{position:relative;top:0;height:auto;border-right:none;border-bottom:1px solid var(--color-divider,#ced0d4);padding:12px;overflow-x:auto;overflow-y:visible}.frp__sidebar__header{padding:0 4px 8px}.frp__sidebar__title{font-size:20px}.frp__sidebar__nav{flex-direction:row;gap:4px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.frp__sidebar__item{flex-shrink:0;padding:8px 16px;border-radius:20px;gap:8px;font-size:14px;white-space:nowrap}.frp__sidebar__item--active{background:var(--color-primary,#1b74e4)}.frp__sidebar__icon{width:28px;height:28px;min-width:28px}.frp__sidebar__icon svg{width:16px;height:16px}.frp__chevron{display:none}.frp__content{padding:16px 12px 32px}.frp__grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}.frp__section__title{font-size:17px}.frp__section__header{flex-wrap:wrap;gap:8px}.frp__search{max-width:100%;width:100%}}@media (max-width:425px){.frp__grid{grid-template-columns:repeat(2,1fr);gap:8px}.frp__card__body{padding:8px 10px 10px}.frp__btn,.frp__card__name{font-size:13px}.frp__btn{padding:6px 10px}}.dark .frp__sidebar,:root[data-theme=dark] .frp__sidebar,[data-theme=dark] .frp__sidebar{background:var(--bg-primary,#18191a);border-right-color:var(--color-divider,#3e4042)}.dark .frp__sidebar__title,:root[data-theme=dark] .frp__sidebar__title,[data-theme=dark] .frp__sidebar__title{color:var(--color-text,#e4e6eb)}.dark .frp__sidebar__settings,:root[data-theme=dark] .frp__sidebar__settings,[data-theme=dark] .frp__sidebar__settings{background:var(--bg-tertiary,#3a3b3c);color:var(--color-text,#e4e6eb)}.dark .frp__sidebar__settings:hover,:root[data-theme=dark] .frp__sidebar__settings:hover,[data-theme=dark] .frp__sidebar__settings:hover{background:#4e4f50}.dark .frp__sidebar__item,:root[data-theme=dark] .frp__sidebar__item,[data-theme=dark] .frp__sidebar__item{color:var(--color-text,#e4e6eb)}.dark .frp__sidebar__item:hover,:root[data-theme=dark] .frp__sidebar__item:hover,[data-theme=dark] .frp__sidebar__item:hover{background:var(--color-hover,#3a3b3c)}.dark .frp__sidebar__item--active,:root[data-theme=dark] .frp__sidebar__item--active,[data-theme=dark] .frp__sidebar__item--active{background:var(--color-primary,#2d88ff);color:#fff}.dark .frp__sidebar__item--active:hover,:root[data-theme=dark] .frp__sidebar__item--active:hover,[data-theme=dark] .frp__sidebar__item--active:hover{background:var(--color-primary,#2d88ff)}.dark .frp__sidebar__icon,:root[data-theme=dark] .frp__sidebar__icon,[data-theme=dark] .frp__sidebar__icon{background:var(--bg-tertiary,#3a3b3c);color:var(--color-text,#e4e6eb)}.dark .frp__content,:root[data-theme=dark] .frp__content,[data-theme=dark] .frp__content{background:var(--bg-secondary,#18191a)}.dark .frp__section__title,:root[data-theme=dark] .frp__section__title,[data-theme=dark] .frp__section__title{color:var(--color-text,#e4e6eb);border-left-color:var(--color-primary,#2d88ff)}.dark .frp__section__seeall,:root[data-theme=dark] .frp__section__seeall,[data-theme=dark] .frp__section__seeall{color:var(--color-primary,#2d88ff)}.dark .frp__card,:root[data-theme=dark] .frp__card,[data-theme=dark] .frp__card{background:var(--bg-card,#242526);box-shadow:none;border:1px solid var(--color-divider,#3e4042)}.dark .frp__card:hover,:root[data-theme=dark] .frp__card:hover,[data-theme=dark] .frp__card:hover{box-shadow:0 4px 12px rgba(0,0,0,.3);border-color:rgba(45,136,255,.3)}.dark .frp__card__name,:root[data-theme=dark] .frp__card__name,[data-theme=dark] .frp__card__name{color:var(--color-text,#e4e6eb)}.dark .frp__card__mutual,:root[data-theme=dark] .frp__card__mutual,[data-theme=dark] .frp__card__mutual{color:var(--color-secondary-text,#b0b3b8)}.dark .frp__card__img,:root[data-theme=dark] .frp__card__img,[data-theme=dark] .frp__card__img{background:var(--bg-tertiary,#3a3b3c)}.dark .frp__btn--confirm,:root[data-theme=dark] .frp__btn--confirm,[data-theme=dark] .frp__btn--confirm{background:var(--color-primary,#2d88ff);box-shadow:0 1px 4px rgba(45,136,255,.25)}.dark .frp__btn--delete,:root[data-theme=dark] .frp__btn--delete,[data-theme=dark] .frp__btn--delete{background:var(--color-btn-secondary,#3a3b3c);color:var(--color-text,#e4e6eb)}.dark .frp__btn--delete:hover,:root[data-theme=dark] .frp__btn--delete:hover,[data-theme=dark] .frp__btn--delete:hover{background:#4e4f50}.dark .frp__btn--secondary,:root[data-theme=dark] .frp__btn--secondary,[data-theme=dark] .frp__btn--secondary{background:var(--color-btn-secondary,#3a3b3c);color:var(--color-text,#e4e6eb)}.dark .frp__btn--secondary:hover,:root[data-theme=dark] .frp__btn--secondary:hover,[data-theme=dark] .frp__btn--secondary:hover{background:#4e4f50}.dark .frp__search,:root[data-theme=dark] .frp__search,[data-theme=dark] .frp__search{background:var(--color-search-bg,#3a3b3c);color:var(--color-secondary-text,#b0b3b8)}.dark .frp__search:focus-within,:root[data-theme=dark] .frp__search:focus-within,[data-theme=dark] .frp__search:focus-within{border-color:var(--color-primary,#2d88ff);background:var(--bg-card,#242526)}.dark .frp__search__input,:root[data-theme=dark] .frp__search__input,[data-theme=dark] .frp__search__input{color:var(--color-text,#e4e6eb)}.dark .frp__search__input::-moz-placeholder,:root[data-theme=dark] .frp__search__input::-moz-placeholder,[data-theme=dark] .frp__search__input::-moz-placeholder{color:var(--color-secondary-text,#b0b3b8)}.dark .frp__search__input::placeholder,:root[data-theme=dark] .frp__search__input::placeholder,[data-theme=dark] .frp__search__input::placeholder{color:var(--color-secondary-text,#b0b3b8)}.dark .frp__empty,.dark .frp__empty__sub,:root[data-theme=dark] .frp__empty,:root[data-theme=dark] .frp__empty__sub,[data-theme=dark] .frp__empty,[data-theme=dark] .frp__empty__sub{color:var(--color-secondary-text,#b0b3b8)}.dark .frp__skeleton,:root[data-theme=dark] .frp__skeleton,[data-theme=dark] .frp__skeleton{background:var(--color-skeleton,#3a3b3c)}.dark .frp__sidebar::-webkit-scrollbar-thumb,:root[data-theme=dark] .frp__sidebar::-webkit-scrollbar-thumb,[data-theme=dark] .frp__sidebar::-webkit-scrollbar-thumb{background:transparent}.dark .frp__sidebar:hover::-webkit-scrollbar-thumb,:root[data-theme=dark] .frp__sidebar:hover::-webkit-scrollbar-thumb,[data-theme=dark] .frp__sidebar:hover::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.2)}@media (max-width:768px){.dark .frp__sidebar,:root[data-theme=dark] .frp__sidebar,[data-theme=dark] .frp__sidebar{border-bottom-color:var(--color-divider,#3e4042)}}.frp__section+.frp__section:before{content:"";display:block;height:1px;margin:0 4px 24px;background:linear-gradient(90deg,transparent,var(--color-divider,#ced0d4) 30%,var(--color-divider,#ced0d4) 70%,transparent)}.dark .frp__section+.frp__section:before,:root[data-theme=dark] .frp__section+.frp__section:before,[data-theme=dark] .frp__section+.frp__section:before{background:linear-gradient(90deg,transparent,var(--color-divider,#3e4042) 30%,var(--color-divider,#3e4042) 70%,transparent)}.dark .frp__empty--birthday,:root[data-theme=dark] .frp__empty--birthday,[data-theme=dark] .frp__empty--birthday{background:linear-gradient(135deg,rgba(255,152,49,.06),rgba(45,136,255,.06))}.dark .frp__empty--custom,:root[data-theme=dark] .frp__empty--custom,[data-theme=dark] .frp__empty--custom{background:linear-gradient(135deg,rgba(200,64,233,.06),rgba(45,136,255,.06))}