.friends-page{--fp-page-bg:#0b0a0a;--fp-text:#ffffffeb;--fp-text-soft:#ffffffb8;--fp-text-muted:#ffffff8c;--fp-accent-title:#f5f5f5;--fp-line:#ffffff1f;--fp-hero-bg:#0b0a0a;--fp-hero-title:#f7f7f5;--fp-hero-subtitle:#ffffffd1;--fp-tag-fg:#ffffffeb;--fp-tag-bg:#ffffff14;--fp-tag-border:#ffffff57;--fp-friends-surface:#0a0a0a;--fp-friends-h2:#f5f5f2;--fp-friends-sub:#ffffffd1;--fp-friend-card-bg:#ffffff0a;--fp-friend-card-border:#ffffff1a;--fp-friend-card-hover-border:#ffffff47;--fp-friend-card-shadow:0 8px 32px #00000073;--fp-friend-name:#fff;--fp-friend-unit:#fff;--fp-friend-desc:#ffffffd6;--fp-friend-cap-border:#8ecae6;--fp-friend-cap-text:#fffc;--fp-friend-photo-bg:#141414;--fp-placeholder-fg:#ffffff1f;--fp-placeholder-bg:linear-gradient(145deg,#1a1a1a 0%,#0f0f0f 100%);--fp-memorial-bg:#060606;--fp-memorial-h2:#fff;--fp-memorial-sub:#ffffffa3;--fp-memorial-cross:#ffffff9e;--fp-hero-fallen-bg:#0f0f0f;--fp-hero-fallen-border:#ffffff14;--fp-hero-fallen-border-hover:#ffffff1f;--fp-hero-fallen-photo:#000;--fp-hero-fallen-name:#fff;--fp-hero-fallen-years:#ffffffc2;--fp-hero-fallen-unit:#ffffff94;--fp-hero-fallen-story:#ffffffe6;--fp-hero-fallen-placeholder-fg:#ffffff2e;--fp-hero-fallen-placeholder-bg:#000;--fp-gallery-surface:#0c0c0c;--fp-gallery-h2:#f2f0ed;--fp-gallery-sub:#ffffffc7;--fp-gallery-item-bg:#ffffff0a;--fp-gallery-item-border:#ffffff1a;--fp-gallery-item-shadow:0 6px 24px #0006;--fp-gallery-cap:#ffffffc7;--fp-gallery-img-bg:#161616;--fp-gallery-ph-fg:#ffffff1a;--fp-gallery-ph-bg:linear-gradient(135deg,#1c1c1c 0%,#121212 100%);background-color:var(--fp-page-bg);color:var(--fp-text)}:root[data-theme=light] .friends-page{--fp-page-bg:var(--surface-base);--fp-text:var(--ink-strong);--fp-text-soft:var(--ink-soft);--fp-text-muted:var(--ink-muted);--fp-accent-title:var(--ink-strong);--fp-line:#0b0a0a1f;--fp-hero-bg:var(--surface-muted);--fp-hero-title:var(--brand-red,#8b0000);--fp-hero-subtitle:#0b0a0ad1;--fp-tag-fg:#0b0a0ae6;--fp-tag-bg:#0b0a0a14;--fp-tag-border:#0b0a0a4d;--fp-friends-surface:var(--surface-base);--fp-friends-h2:var(--ink-strong);--fp-friends-sub:#0b0a0ad1;--fp-friend-card-bg:#fff;--fp-friend-card-border:#0b0a0a1a;--fp-friend-card-hover-border:#0b0a0a29;--fp-friend-card-shadow:0 8px 28px #0b0a0a14;--fp-friend-name:var(--ink-strong);--fp-friend-unit:#8b0000;--fp-friend-desc:#0b0a0ae0;--fp-friend-cap-border:#8ecae6;--fp-friend-cap-text:#0b0a0ad1;--fp-friend-photo-bg:#e8e8e8;--fp-placeholder-fg:#0b0a0a24;--fp-placeholder-bg:linear-gradient(135deg,#e4e4e4 0%,#f0f0f0 100%);--fp-memorial-bg:var(--surface-base);--fp-memorial-h2:var(--ink-strong);--fp-memorial-sub:#0b0a0ad1;--fp-memorial-cross:#000;--fp-hero-fallen-bg:#fff;--fp-hero-fallen-border:#0b0a0a1f;--fp-hero-fallen-border-hover:#0b0a0a2e;--fp-hero-fallen-photo:#edf2f4;--fp-hero-fallen-name:var(--ink-strong);--fp-hero-fallen-years:#0b0a0aeb;--fp-hero-fallen-unit:var(--ink-soft);--fp-hero-fallen-story:#0b0a0aeb;--fp-hero-fallen-placeholder-fg:#0b0a0a24;--fp-hero-fallen-placeholder-bg:#edf2f4;--fp-gallery-surface:var(--surface-soft);--fp-gallery-h2:var(--ink-strong);--fp-gallery-sub:#0b0a0ad1;--fp-gallery-item-bg:#fff;--fp-gallery-item-border:#0b0a0a1a;--fp-gallery-item-shadow:0 6px 24px #0b0a0a14;--fp-gallery-cap:#0b0a0ad1;--fp-gallery-img-bg:#ddd;--fp-gallery-ph-fg:#0b0a0a1f;--fp-gallery-ph-bg:linear-gradient(135deg,#ccc 0%,#e5e5e5 100%);background-color:var(--fp-page-bg);color:var(--fp-text)}.friends-page .friends-hero,.friends-page .friends-section,.friends-page .memorial-section,.friends-page .gallery-section{position:relative}.friends-page .friends-hero,.friends-page .friends-section{border-bottom:none}.friends-page .memorial-section{border-bottom:1px solid var(--fp-line)}.friends-hero{background:var(--fp-hero-bg);text-align:center;background-image:none;width:100%;padding:100px 0 64px}.friends-hero__title{font-family:var(--font-tektur),sans-serif;color:var(--fp-hero-title);letter-spacing:.04em;max-width:920px;margin-bottom:20px;margin-left:auto;margin-right:auto;font-size:clamp(2.5rem,5vw,4rem);font-weight:900;line-height:1.1}.friends-hero__subtitle{font-family:var(--font-inter),sans-serif;color:var(--fp-hero-subtitle);max-width:660px;margin:0 auto 32px;font-size:1.125rem;line-height:1.7}.friends-hero__partners{flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;display:flex}.friends-hero__partner-tag{font-family:var(--font-tektur),sans-serif;color:var(--fp-tag-fg);background:var(--fp-tag-bg);border:1px solid var(--fp-tag-border);border-radius:0;padding:7px 20px;font-size:.9375rem;font-weight:400;display:inline-block}.friends-section{background-color:var(--fp-friends-surface);width:100%;padding:80px 0 88px}.friends-section__title{font-family:var(--font-tektur),sans-serif;color:var(--fp-friends-h2);letter-spacing:.02em;margin-bottom:12px;font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:900}.friends-section__title:after{content:none}.friends-section__subtitle{font-family:var(--font-inter),sans-serif;color:var(--fp-friends-sub);max-width:640px;margin-bottom:48px;font-size:1rem;line-height:1.7}.friends-grid{grid-template-columns:repeat(3,1fr);gap:32px;display:grid}.friend-card{--friend-card-cut:10px;background:var(--fp-friend-card-border);clip-path:polygon(var(--friend-card-cut)0%,calc(100% - var(--friend-card-cut))0%,100% var(--friend-card-cut),100% calc(100% - var(--friend-card-cut)),calc(100% - var(--friend-card-cut))100%,var(--friend-card-cut)100%,0 calc(100% - var(--friend-card-cut)),0 var(--friend-card-cut));isolation:isolate;border:none;border-radius:0;flex-direction:column;transition:transform .25s,box-shadow .25s,background-color .2s;display:flex;position:relative;overflow:hidden}.friend-card:before{content:"";background:var(--fp-friend-card-bg);z-index:0;clip-path:polygon(calc(var(--friend-card-cut) - 1px)0%,calc(100% - (var(--friend-card-cut) - 1px))0%,100% calc(var(--friend-card-cut) - 1px),100% calc(100% - (var(--friend-card-cut) - 1px)),calc(100% - (var(--friend-card-cut) - 1px))100%,calc(var(--friend-card-cut) - 1px)100%,0 calc(100% - (var(--friend-card-cut) - 1px)),0 calc(var(--friend-card-cut) - 1px));position:absolute;inset:1px}.friend-card>*{z-index:1;position:relative}.friend-card:hover{box-shadow:var(--fp-friend-card-shadow);background:var(--fp-friend-card-hover-border);transform:none}.friend-card__photo{aspect-ratio:4/3;background:var(--fp-friend-photo-bg);width:100%;overflow:hidden}.friend-card__photo img{object-fit:cover;width:100%;height:100%;transition:transform .4s;display:block}.friend-card:hover .friend-card__photo img{transform:none}.friend-card__body{flex-direction:column;flex:1;gap:12px;padding:20px;transition:box-shadow .25s;display:flex;position:relative;overflow:hidden}.friend-card__body>*{z-index:1;position:relative}:root:not([data-theme=light]) .friend-card__body{background:#000}:root:not([data-theme=light]) .friend-card__body:before{content:"";opacity:0;pointer-events:none;background:linear-gradient(#121212 0%,#050505 62%,#000 100%);transition:opacity .25s;position:absolute;inset:0}:root:not([data-theme=light]) .friend-card:hover{box-shadow:none;background:var(--fp-friend-card-border);transform:none}:root:not([data-theme=light]) .friend-card:hover .friend-card__photo img{transform:none}:root:not([data-theme=light]) .friend-card:hover .friend-card__body{box-shadow:inset 0 1px #daeaf133,inset 0 0 0 1px #daeaf114}:root:not([data-theme=light]) .friend-card:hover .friend-card__body:before{opacity:1}.friend-card__header{flex-direction:column;gap:4px;display:flex}.friend-card__name{font-family:var(--font-tektur),sans-serif;color:var(--fp-friend-name);font-size:1.125rem;font-weight:600;line-height:1.3}.friend-card__unit{font-family:var(--font-inter),sans-serif;color:var(--fp-friend-unit);font-size:.875rem;font-weight:500}.friend-card__description{font-family:var(--font-inter),sans-serif;color:var(--fp-friend-desc);font-size:.875rem;line-height:1.65}:root[data-theme=light] .friend-card__description{color:#111}:root:not([data-theme=light]) .friend-card__description{color:#f2f2f2}.friend-card__caption{--friend-caption-accent:var(--fp-friend-cap-border);font-family:var(--font-tektur),sans-serif;color:#2e93d6;margin:0;padding-left:14px;font-size:.8125rem;font-style:normal;font-weight:500;line-height:1.6;position:relative}.friend-card__caption:before{content:"";background:var(--friend-caption-accent);clip-path:polygon(100% 0,100% 100%,0 calc(100% - 4px),0 4px);width:3px;height:100%;position:absolute;top:0;left:0}:root[data-theme=light] .friend-card__caption{color:#8b0000;--friend-caption-accent:#8b0000}:root:not([data-theme=light]) .friend-card__caption{color:#fff;--friend-caption-accent:#fff}.photo-placeholder{background:var(--fp-placeholder-bg);width:100%;height:100%;color:var(--fp-placeholder-fg);justify-content:center;align-items:center;display:flex}.photo-placeholder svg{width:56px;height:56px}.memorial-section{background:var(--fp-memorial-bg);width:100%;color:var(--fp-text);padding:88px 0 96px}.memorial-section__header{text-align:center;max-width:640px;margin:0 auto 56px}.memorial-section__icon{color:var(--fp-memorial-cross);justify-content:center;margin-bottom:20px;display:flex}.memorial-section__cross{opacity:.82;filter:none;width:30px;height:30px;display:block}:root[data-theme=light] .memorial-section__cross{filter:none;opacity:1}.memorial-section__title{font-family:var(--font-tektur),sans-serif;color:var(--fp-memorial-h2);letter-spacing:.02em;margin-bottom:12px;font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:900}.memorial-section__title:after{content:"";background:#ffffff2e;border-radius:0;width:48px;height:1px;margin:16px auto 0;display:block}.memorial-section__subtitle{font-family:var(--font-inter),sans-serif;color:var(--fp-memorial-sub);margin:0 auto;font-size:1rem;line-height:1.75}.memorial-grid{grid-template-columns:repeat(3,1fr);gap:32px;display:grid}.hero-card{background:var(--fp-hero-fallen-bg);border:1px solid var(--fp-hero-fallen-border);border-radius:0;flex-direction:column;transition:border-color .2s;display:flex;overflow:hidden}.hero-card:hover{border-color:var(--fp-hero-fallen-border-hover)}.hero-card__photo{aspect-ratio:4/3;background:var(--fp-hero-fallen-photo);width:100%;overflow:hidden}.hero-card__photo img{object-fit:cover;filter:grayscale();width:100%;height:100%;transition:none;display:block}.hero-card__photo-placeholder{background:var(--fp-hero-fallen-placeholder-bg);width:100%;height:100%;color:var(--fp-hero-fallen-placeholder-fg);justify-content:center;align-items:center;display:flex}.hero-card__photo-placeholder svg{width:48px;height:48px}.hero-card__body{flex-direction:column;flex:1;gap:6px;padding:20px;display:flex}.hero-card__name{font-family:var(--font-tektur),sans-serif;color:var(--fp-hero-fallen-name);font-size:1.0625rem;font-weight:700;line-height:1.3}.hero-card__years{font-family:var(--font-inter),sans-serif;color:var(--fp-hero-fallen-years);letter-spacing:.04em;font-size:.8125rem;font-weight:500}.hero-card__unit{font-family:var(--font-inter),sans-serif;color:var(--fp-hero-fallen-unit);margin-bottom:6px;font-size:.875rem;font-weight:500}.hero-card__story{font-family:var(--font-inter),sans-serif;color:var(--fp-hero-fallen-story);font-size:.8125rem;line-height:1.65}.gallery-section{background-color:var(--fp-gallery-surface);width:100%;padding:56px 0 96px}.gallery-section__title{font-family:var(--font-tektur),sans-serif;color:var(--fp-gallery-h2);letter-spacing:.02em;margin-bottom:12px;font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:900}.gallery-section__title:after{content:none}.gallery-section__subtitle{font-family:var(--font-inter),sans-serif;color:var(--fp-gallery-sub);max-width:580px;margin-bottom:48px;font-size:1rem;line-height:1.7}.gallery-grid{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}.gallery-item{background:var(--fp-gallery-item-bg);border:1px solid var(--fp-gallery-item-border);border-radius:0;flex-direction:column;transition:transform .25s,box-shadow .25s,border-color .2s;display:flex;overflow:hidden}.gallery-item:hover{box-shadow:var(--fp-gallery-item-shadow);border-color:var(--fp-friend-card-hover-border);transform:translateY(-3px)}.gallery-item__image{aspect-ratio:1;background:var(--fp-gallery-img-bg);width:100%;overflow:hidden}.gallery-item__zoom-btn{cursor:zoom-in;background:0 0;border:none;width:100%;height:100%;padding:0}.gallery-item__image img{object-fit:cover;width:100%;height:100%;transition:transform .4s;display:block}.gallery-item:hover .gallery-item__image img{transform:scale(1.05)}.gallery-lightbox{z-index:1200;background:#000000db;justify-content:center;align-items:center;padding:28px;display:flex;position:fixed;inset:0}.gallery-lightbox__image{object-fit:contain;width:auto;max-width:min(92vw,1400px);height:auto;max-height:90vh}.gallery-lightbox__close{color:#fff;cursor:pointer;background:#00000059;border:1px solid #ffffff4d;border-radius:999px;width:38px;height:38px;font-size:1.5rem;line-height:1;position:absolute;top:16px;right:18px}.gallery-item__placeholder{background:var(--fp-gallery-ph-bg);width:100%;height:100%;color:var(--fp-gallery-ph-fg);justify-content:center;align-items:center;display:flex}.gallery-item__placeholder svg{width:40px;height:40px}.gallery-item__caption{font-family:var(--font-inter),sans-serif;color:var(--fp-gallery-cap);padding:12px 14px;font-size:.8125rem;line-height:1.55}@media (max-width:1100px){.friends-grid,.memorial-grid{grid-template-columns:repeat(2,1fr);gap:24px}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:16px}}@media (max-width:768px){.friends-hero{padding:80px 0 48px}.friends-section{padding:56px 0 64px}.friends-grid{grid-template-columns:repeat(2,1fr);gap:20px}.memorial-section{padding:60px 0 72px}.memorial-grid{grid-template-columns:repeat(2,1fr);gap:20px}.gallery-section{padding:56px 0 72px}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:14px}}@media (max-width:480px){.friends-hero{padding:64px 0 40px}.friends-hero__title{font-size:2rem}.friends-hero__subtitle{font-size:.9375rem}.friends-section{padding:40px 0 48px}.friends-section__title:after,.gallery-section__title:after{margin-top:10px}.friends-grid{grid-template-columns:1fr;gap:16px}.memorial-section{padding:48px 0 56px}.memorial-grid{grid-template-columns:1fr;gap:16px}.gallery-section{padding:40px 0 56px}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:12px}.gallery-item__caption{padding:10px 12px;font-size:.75rem}}
