:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#162033;background:#f2f5f9;line-height:1.5}*{box-sizing:border-box}body{margin:0;min-width:320px;background:#f2f5f9}button{min-height:2.45rem;border:0;border-radius:12px;background:#173b73;color:#fff;padding:.55rem .95rem;font-weight:700;cursor:pointer;box-shadow:0 8px 18px #173b7324;transition:transform .12s ease,background .12s ease,box-shadow .12s ease}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #173b732e}button:disabled{cursor:not-allowed;opacity:.55}button.secondary{background:#eef2f8;color:#173b73;box-shadow:none}button.danger{background:#9b1c31;box-shadow:none}button.danger:hover:not(:disabled){background:#841629}main{width:min(1180px,calc(100% - 2rem));margin:0 auto;padding:2rem 0 4rem}.hero{position:relative;isolation:isolate;overflow:hidden;display:flex;justify-content:space-between;align-items:center;gap:1.25rem;min-height:210px;width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);margin-top:-2rem;padding-block:2rem;padding-inline:max(2rem,calc((100vw - 1180px)/2 + 1rem));border:0;border-radius:0;background:#102f5f;color:#fff;box-shadow:0 18px 34px #141f3033}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-3;background-image:url(/assets/american-flag-wave-M_tQIEYf.png);background-size:cover;background-position:center 46%;opacity:.86;filter:saturate(.98) contrast(1.04)}.hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-2;background:linear-gradient(90deg,#030c1ef0,#061430e8 42%,#061430cc 70%,#2d0810bd)}.hero>*{position:relative;z-index:1}.hero h1{margin:.1rem 0 .45rem;font-size:clamp(2rem,5.8vw,4rem);line-height:.95;letter-spacing:-.05em;color:#fff;text-shadow:0 3px 12px rgba(0,0,0,.55)}.hero p{max-width:760px;margin:0;color:#f3f6fb;font-size:.98rem;text-shadow:0 2px 8px rgba(0,0,0,.4)}.eyebrow{margin:0;font-size:.75rem;text-transform:uppercase;letter-spacing:.16em;font-weight:800;color:#8b1e2c}.hero .eyebrow{color:#ffe08a;text-shadow:0 2px 8px rgba(0,0,0,.48)}.authBox{position:absolute;top:1.1rem;right:max(1.25rem,calc((100vw - 1180px)/2 + 1rem));z-index:2;min-width:0;display:flex;flex-direction:row;gap:.65rem;justify-content:flex-end;align-items:center;padding:0;border:0;border-radius:0;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}.authBox strong{max-width:220px;overflow:hidden;text-align:right;color:#fff;font-size:.92rem;line-height:1;white-space:nowrap;text-overflow:ellipsis;text-shadow:0 2px 8px rgba(0,0,0,.55)}.authBox button{min-height:2rem;border-radius:999px;background:#fffffff0;color:#173b73;padding:.4rem .85rem;box-shadow:none;font-size:.88rem}.authBox button:hover:not(:disabled){background:#fff;box-shadow:none}.card,.messageStack{margin-top:1.25rem}.card{background:#fff;border:1px solid #e1e7f0;border-radius:22px;padding:1.4rem;box-shadow:0 12px 30px #141f3014}.formCard{border-top:5px solid #8b1e2c}.sectionHeader{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.sectionHeader h2{margin:.2rem 0 0}.messageStack{display:grid;gap:.75rem}.message{display:flex;align-items:center;justify-content:space-between;gap:1rem;border-radius:16px;padding:.85rem 1rem;font-weight:700}.message span{flex:1}.error{background:#ffe7e7;color:#8b1e2c}.success{background:#e6f8ed;color:#116637}.messageClose{min-height:1.9rem;width:1.9rem;flex:0 0 auto;border-radius:999px;padding:0;background:#ffffffb8;color:currentColor;box-shadow:none;font-size:1.25rem;line-height:1}.messageClose:hover:not(:disabled){background:#fffffff2;box-shadow:none}.emptyState{margin-top:1rem;padding:1rem;border-radius:16px;background:#f7f9fc;color:#53627a}.guestNotice{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#fbfcff}.guestNotice h2{margin:0 0 .3rem}.guestNotice p{margin:0;color:#53627a}.searchBar{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:.75rem;margin-top:1rem}.honoreeResults{display:grid;gap:1rem;margin-top:1.25rem}.honoreeCard{display:grid;grid-template-columns:96px minmax(0,1fr);gap:1rem;align-items:start;border:1px solid #e3e9f2;border-radius:18px;padding:1rem;background:#fbfcff}.honoreeCard img,.honoreePlaceholder{width:96px;height:96px;border-radius:16px;object-fit:cover;background:#e7ecf5}.honoreePlaceholder{display:flex;align-items:center;justify-content:center;color:#53627a;font-size:.85rem;font-weight:700}.honoreeTitleRow{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.honoreeTitleRow h3{margin:0}.detailGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;margin:1rem 0}.detailGrid dt{font-size:.75rem;color:#53627a;text-transform:uppercase;letter-spacing:.08em;font-weight:800}.detailGrid dd{margin:.15rem 0 0;font-weight:700}.cardActions{display:flex;align-items:center;justify-content:space-between;gap:.9rem;flex-wrap:wrap;margin-top:.75rem}.honoreeActionButtons{display:flex;align-items:center;justify-content:flex-end;gap:.65rem;margin-left:auto;flex-wrap:wrap}.honoreeActionButtons button{white-space:nowrap}.compactButton{padding-inline:1rem;box-shadow:none}.textLink{color:#173b73;font-weight:800}.gridForm{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}label{display:flex;flex-direction:column;gap:.4rem;font-weight:700}input,select,textarea{width:100%;border:1px solid #ccd6e4;border-radius:14px;padding:.7rem .8rem;background:#fbfcff;color:#162033}textarea{resize:vertical}input:focus,select:focus,textarea:focus{outline:3px solid rgba(23,59,115,.16);border-color:#173b73}input[type=checkbox]{width:18px;height:18px;accent-color:#173b73}.wide{grid-column:1 / -1}.checkRow{flex-direction:row;align-items:center}.checkRow input{width:auto}.actions{display:flex;justify-content:flex-end;gap:.75rem}.tableWrap{overflow-x:auto;border:1px solid #e5ebf4;border-radius:18px;background:#fff}table{width:100%;min-width:740px;border-collapse:collapse}th,td{text-align:left;padding:.9rem;border-bottom:1px solid #e5ebf4;vertical-align:middle}th{background:#f7f9fc;color:#53627a;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em}tr:last-child td{border-bottom:0}td span{color:#6b778d;font-size:.9rem}.rowActions{text-align:right}.status{display:inline-block;border-radius:999px;padding:.25rem .65rem;font-size:.78rem;font-weight:800;background:#e7ecf5;color:#173b73}.status-submitted{background:#fff3d6;color:#7a4c00}.status-approved{background:#e6f8ed;color:#116637}.status-rejected,.status-cancelled{background:#ffe7e7;color:#8b1e2c}.adminCard{border-top:4px solid #173b73;padding:1.5rem}.adminCard .sectionHeader{align-items:center;margin-bottom:1rem}.adminCard .sectionHeader h2{font-size:1.65rem}.adminCard .tableWrap{border:1px solid #e4ebf5;border-radius:18px;overflow:hidden;background:#fff;box-shadow:none}.adminCard table{min-width:860px;border-collapse:separate;border-spacing:0}.adminCard th{padding:.75rem 1rem;background:#f7f9fc;color:#4e5f7a;font-size:.72rem;letter-spacing:.13em;white-space:nowrap}.adminCard td{padding:1rem;border-bottom:1px solid #eef2f7}.adminCard tr:last-child td{border-bottom:0}.adminCard td strong{font-size:1rem}.adminCard td span{color:#60708a}.adminCard .rowActions{width:220px}.adminCard .stackedActions{display:flex;flex-direction:column;align-items:stretch;gap:.45rem}.adminCard .stackedActions button{width:100%;min-height:2.35rem;padding:.55rem .9rem;font-size:.9rem}.adminCard>p{margin:.75rem 0 0;padding:.95rem 1rem;border:1px dashed #d8e1ee;border-radius:14px;background:#fafcff;color:#60708a}.printHeader{margin-top:1.75rem;padding-top:1.25rem;border-top:1px solid #edf1f7}.printHeader .actions,.printActions{display:flex;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.6rem}.printHeader .actions button,.printActions button{white-space:nowrap}.searchCard{padding:1.25rem 1.4rem}.searchHeader{margin-bottom:.85rem}.helperText{margin:.35rem 0 0;color:#53627a}.searchCard .searchBar{align-items:center}.countBadge{display:inline-flex;align-items:center;justify-content:center;min-width:1.8rem;height:1.8rem;margin-left:.6rem;padding:0 .55rem;border-radius:999px;background:#eef2f8;color:#173b73;font-size:.9rem;font-weight:800;vertical-align:middle}.adminStats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;margin:.75rem 0 1.2rem}.statCard{border:1px solid #e4ebf5;border-radius:16px;padding:.8rem 1rem;background:#fbfcff}.statCard strong{display:block;color:#173b73;font-size:1.45rem;line-height:1}.statCard span{display:block;margin-top:.25rem;color:#60708a;font-size:.86rem;font-weight:700}.selectedCount{min-height:2.45rem;display:inline-flex;align-items:center;padding:0 .75rem;border:1px solid #dbe4f0;border-radius:12px;background:#f8fafd;color:#173b73;font-weight:800;white-space:nowrap}.tableSelectAll{display:inline-flex;flex-direction:row;align-items:center;gap:.45rem;font-size:.78rem;color:#173b73;font-weight:800;letter-spacing:0;text-transform:none;white-space:nowrap}.tableSelectAll input{width:18px;height:18px}.printActions button:disabled{background:#eef2f8;color:#8a9ab3;opacity:1;box-shadow:none}.adminAccessPanel{margin:1.2rem 0 1.4rem;padding:1rem;border:1px solid #e4ebf5;border-radius:18px;background:#fbfcff}.adminSubHeader{margin-bottom:.8rem}.adminSubHeader h3{margin:.2rem 0 0;font-size:1.15rem}.adminUserSearch{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.75rem;margin-top:.9rem}.adminUserResults{display:grid;gap:.7rem;margin-top:.9rem}.adminUserCard{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem;border:1px solid #e5ebf4;border-radius:14px;background:#fff}.adminUserCard strong{display:block}.adminUserCard span:not(.status){display:block;color:#60708a;font-size:.9rem}.adminUserActions{display:flex;align-items:center;justify-content:flex-end;gap:.65rem;flex-wrap:wrap}.ownershipCard .sectionHeader{align-items:flex-start}.ownedFlagGrid{display:grid;gap:.9rem}.ownedFlagCard{display:grid;grid-template-columns:78px minmax(0,1.4fr) minmax(220px,.8fr) auto;align-items:center;gap:1rem;border:1px solid #e4ebf5;border-radius:18px;padding:1rem;background:#fbfcff}.ownedFlagImage{width:78px;height:78px;border-radius:16px;object-fit:cover;background:#e7ecf5}.ownedFlagImagePlaceholder{display:flex;align-items:center;justify-content:center;color:#53627a;font-size:.78rem;font-weight:800;text-align:center}.ownedFlagCard h3{margin:.2rem 0;font-size:1.22rem;line-height:1.2}.ownedFlagCard p{margin:0;color:#60708a}.ownedFlagMeta{display:flex;flex-direction:column;align-items:flex-start;gap:.35rem}.ownedFlagMeta span:not(.status){color:#60708a;font-size:.9rem}.ownedFlagActions{display:flex;justify-content:flex-end}@media(max-width:900px){.adminCard{padding:1.1rem}.adminStats,.adminUserSearch{grid-template-columns:1fr}.adminUserCard{align-items:flex-start;flex-direction:column}.adminUserActions{justify-content:flex-start}.adminCard .sectionHeader,.printHeader{align-items:flex-start}.adminCard .rowActions{width:180px}.adminCard .stackedActions button{font-size:.85rem}.ownedFlagCard{grid-template-columns:1fr}.ownedFlagImage{width:96px;height:96px}.ownedFlagActions{justify-content:flex-start}}@media(max-width:760px){.hero,.sectionHeader,.guestNotice{flex-direction:column}.hero{min-height:185px;margin-top:-2rem;padding-block:1.35rem;padding-inline:1rem}.hero:after{right:-150px;bottom:-150px}.hero:after{right:.75rem;max-width:240px;font-size:1.15rem;opacity:.85}.authBox{position:static;align-self:flex-start;justify-content:flex-start;flex-wrap:wrap;margin-top:.85rem}.authBox strong{max-width:180px;text-align:left}.gridForm{grid-template-columns:1fr}.actions{justify-content:flex-start;flex-wrap:wrap}.searchBar,.honoreeCard,.detailGrid{grid-template-columns:1fr}}.cardActions button.secondary{background:#edf2f8;color:#1f3b5f}@media(max-width:700px){.honoreeActionButtons{width:100%;justify-content:flex-start;margin-left:0}}.searchHeader>button{white-space:nowrap}.requiredFieldsNote{margin:0 0 1rem;color:#53627a;font-size:.95rem}.fieldLabelText{display:inline-flex;align-items:center;gap:.25rem}.requiredMark{color:#b31942;font-weight:900}.honoreePhotoPreview{width:150px;max-width:100%;height:120px;object-fit:cover;border-radius:16px;border:1px solid #dbe5f2;background:#f3f6fb;box-shadow:0 8px 22px #0f234114}@media(max-width:760px){main{width:min(100% - 1rem,1180px);padding-top:1rem}.hero{min-height:230px;display:block;padding:4.75rem 1rem 1.65rem;margin-top:-1rem}.hero:before{background-size:cover;background-position:center top;opacity:.92}.hero:after{background:linear-gradient(180deg,#030c1ef5,#061430e0 42%,#061430b3 72%,#2d0810b8)}.authBox{top:.85rem;left:1rem;right:1rem;justify-content:space-between;gap:.75rem}.authBox strong{max-width:calc(100vw - 9.5rem);text-align:left}.hero h1{max-width:16rem;font-size:clamp(2rem,11vw,3.25rem)}.hero p{max-width:34rem}}@media(max-width:430px){.hero{min-height:245px;padding-top:4.5rem}.authBox{align-items:flex-start}.authBox strong{max-width:11.5rem;white-space:normal;line-height:1.1}.authBox button{flex:0 0 auto}}@media(max-width:760px){main{width:100%;padding-top:0}.hero{width:100%;margin:0;min-height:260px;display:grid;grid-template-columns:1fr;align-content:end;justify-content:start;align-items:end;gap:.85rem;padding:1.25rem 1rem 1rem;overflow:hidden}.hero:before{top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center center;opacity:.95;transform:scale(1.04);transform-origin:center}.hero:after{top:0!important;left:0!important;right:auto!important;bottom:auto!important;max-width:none!important;width:auto!important;height:auto!important;font-size:inherit!important;opacity:1;background:linear-gradient(90deg,#030c1eeb,#061430d1 46%,#06143099),linear-gradient(180deg,#00000024,#00000038)}.hero>div:first-child{width:100%;max-width:100%;padding-right:0}.hero h1{font-size:clamp(3rem,16vw,4.4rem);line-height:.9;letter-spacing:-.06em}.hero p{max-width:100%}.authBox{position:relative;top:auto;right:auto;width:100%;align-self:start;display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-top:0}.authBox strong{max-width:calc(100% - 120px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.authBox button{margin-left:auto;white-space:nowrap;border-radius:999px;padding-inline:1rem}main>.card,main>.messageStack{width:calc(100% - 2rem);margin-left:auto;margin-right:auto}}@media(max-width:430px){.hero{min-height:245px;padding-inline:.85rem}.hero h1{font-size:clamp(2.7rem,17vw,3.8rem)}.hero .eyebrow{font-size:.68rem;letter-spacing:.13em}.authBox{font-size:.82rem}.authBox button{min-height:2.25rem;padding:.45rem .85rem}}html{-webkit-text-size-adjust:100%}body{overflow-x:hidden}button,input,select,textarea{font:inherit}input,select,textarea{min-width:0}img{max-width:100%}@media(max-width:900px){body{background:radial-gradient(circle at top left,rgba(38,70,125,.1),transparent 32rem),linear-gradient(180deg,#f7f9fc,#eef3f9)}main,.appShell,.pageShell,.contentShell{width:100%;max-width:100%}main{padding:0 0 1.25rem}.hero{width:100%;margin:0;border-radius:0;min-height:30rem;padding:max(1rem,env(safe-area-inset-top)) 1.5rem 1.35rem;display:flex;flex-direction:column;justify-content:flex-end;gap:1.05rem;box-shadow:none;overflow:hidden}.hero:before{top:0;right:0;bottom:0;left:0;width:auto;height:auto;background-size:cover;background-position:center center;transform:none;opacity:1}.hero:after{top:0!important;left:0!important;width:auto!important;height:auto!important;right:auto!important;bottom:auto!important;max-width:none!important;opacity:1;background:linear-gradient(90deg,#050f239e,#07163257 52%,#0716321a),linear-gradient(180deg,#0208142e,#0208140a 44%,#02081447)}.hero>*{position:relative;z-index:1}.hero>div:first-child{width:min(100%,38rem)}.hero .eyebrow{font-size:clamp(.75rem,2.6vw,.95rem);letter-spacing:.2em;line-height:1.2;text-shadow:0 2px 8px rgba(0,0,0,.45)}.hero h1{max-width:8.5ch;font-size:clamp(4.25rem,16vw,6.75rem);line-height:.86;letter-spacing:-.07em;margin:.25rem 0 .65rem;text-wrap:balance;text-shadow:0 5px 18px rgba(0,0,0,.45)}.hero p{max-width:36rem;font-size:clamp(1.03rem,3.8vw,1.28rem);line-height:1.45;text-shadow:0 3px 12px rgba(0,0,0,.48)}.authBox{position:relative;z-index:2;top:auto;right:auto;display:flex;align-items:center;justify-content:flex-end;gap:.75rem;width:100%;margin-top:.25rem;padding:0;background:transparent;box-shadow:none}.authBox strong,.authBox span{color:#fff;max-width:55%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 2px 8px rgba(0,0,0,.5)}.authBox button{margin-left:auto;min-height:2.85rem;border-radius:999px;padding:.65rem 1.25rem;color:#123463;background:#fffffff0;box-shadow:0 8px 22px #0a183238;white-space:nowrap}main>.card,main>.messageStack,.card,.notice,.error,.ownedFlagCard,.honoreeCard{width:calc(100% - 1.75rem);max-width:46rem;margin-left:auto;margin-right:auto}.card{border-radius:1.45rem;padding:clamp(1.25rem,5vw,2rem);box-shadow:0 14px 34px #1122401a}.card+.card,.card+.messageStack,.messageStack+.card{margin-top:1rem}.card h2{font-size:clamp(1.65rem,7vw,2.35rem);line-height:1.05}.card h3{font-size:clamp(1.25rem,5.8vw,1.75rem);line-height:1.15}.eyebrow{font-size:.78rem;letter-spacing:.18em}.searchBar{display:grid;grid-template-columns:1fr;gap:.85rem;width:100%}.searchBar input,.searchBar button,input[type=search],input[type=text],input[type=email],input[type=tel],select,textarea{width:100%;min-height:3.4rem;border-radius:1rem;font-size:1rem}.searchBar button,button{min-height:3.25rem;touch-action:manipulation}.sectionHeader,.cardHeader,.adminToolbar,.formActions,.buttonRow{display:flex;flex-wrap:wrap;align-items:stretch;gap:.75rem}.sectionHeader>*,.cardHeader>*,.adminToolbar>*,.formActions>*,.buttonRow>*{min-width:0}.sectionHeader button,.cardHeader button,.adminToolbar button,.formActions button,.buttonRow button{flex:1 1 auto}.honoreeResults,.ownedFlagGrid,.adminGrid{display:grid;grid-template-columns:1fr;gap:1rem}.honoreeCard,.ownedFlagCard{border-radius:1.25rem;padding:1rem}.ownedFlagCard{grid-template-columns:5.75rem 1fr;align-items:start}.ownedFlagImage,.ownedFlagImagePlaceholder{width:5.75rem;height:5.75rem;border-radius:1rem}.ownedFlagMeta,.honoreeMeta,.statusRow{display:flex;flex-wrap:wrap;gap:.45rem}.ownedFlagMeta span,.honoreeMeta span,.statusRow span{max-width:100%}table{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}}@media(max-width:560px){.hero{min-height:27.5rem;padding-left:1.15rem;padding-right:1.15rem}.hero:before{background-position:43% center}.hero h1{font-size:clamp(3.9rem,18vw,5.75rem);max-width:7ch}.hero p{font-size:1rem;max-width:22rem}.authBox{justify-content:flex-end}.authBox strong,.authBox span{font-size:.9rem;max-width:48%}.authBox button{min-height:2.65rem;padding:.55rem 1.05rem;font-size:.95rem}main>.card,main>.messageStack,.card,.notice,.error,.ownedFlagCard,.honoreeCard{width:calc(100% - 1.25rem)}.card{padding:1.15rem;border-radius:1.3rem}.searchBar input,.searchBar button,input[type=search],input[type=text],input[type=email],input[type=tel],select,textarea{min-height:3.25rem;border-radius:.9rem}.ownedFlagCard{grid-template-columns:1fr}.ownedFlagImage,.ownedFlagImagePlaceholder{width:100%;height:auto;min-height:10rem;max-height:16rem;object-fit:cover}.formGrid,.twoColumn,.threeColumn{grid-template-columns:1fr!important}}@media(max-width:390px){.hero{min-height:25.5rem;padding-left:1rem;padding-right:1rem}.hero h1{font-size:clamp(3.25rem,17.5vw,4.7rem)}.hero p{font-size:.96rem}.card{padding:1rem}.card h2{font-size:1.55rem}}
