:root{--fvhbc-primary:#76a4c3;--fvhbc-primary-dark:#4f7b9d;--fvhbc-primary-light:#9fbcd2;--fvhbc-pink:#ff2ba6;--text-dark:#000;--text-light:#000;--bg-light:#faf8f3;--card-bg:#fff;--border:#e8e6e0;--pill-bg:#eae8e2;--pill-text:#000}#root{flex-direction:column;width:100%;min-width:100%;max-width:100%;min-height:100vh;margin:0;padding:0;display:flex}*,:before,:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%;font-size:16px}@media (prefers-reduced-motion:no-preference){.app-shell,.top-app-bar,.app-main{transition:padding .3s,margin .3s}}html,body{color:var(--text-dark);background:var(--bg-light);width:100%;min-height:100vh;min-height:-webkit-fill-available;margin:0;padding:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow-x:hidden}img,video,canvas,iframe{max-width:100%;height:auto}@media (orientation:landscape){img,video{object-fit:contain;width:auto;max-height:70vh}}button,input,select,textarea{font-family:inherit}.app-shell{width:100%;max-width:100vw;min-height:100vh;background:var(--card-bg);min-height:-webkit-fill-available;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);flex-direction:column;margin:0;display:flex;position:relative;overflow-x:hidden}.app-header{background:linear-gradient(135deg,var(--fvhbc-primary)0%,var(--fvhbc-primary-light)100%);color:var(--text-light);align-items:center;gap:.5rem;padding:.7rem 1rem;display:flex}.app-header h1{margin:0;font-size:1.15rem;font-weight:600}.back-btn{color:var(--text-light);cursor:pointer;background:0 0;border:none;font-size:1.1rem}.bottom-nav{border-top:1px solid var(--border);background:#f9fafb;justify-content:space-around;padding:.4rem 0;display:flex}.bottom-nav a{color:#4b5563;font-size:.85rem;text-decoration:none}.bottom-nav a:hover{color:var(--fvhbc-primary-dark)}h1{letter-spacing:.01em;margin-top:0;font-size:clamp(1.5rem,4vw,2rem);font-weight:600;line-height:1.2}h2{letter-spacing:.01em;margin-top:0;font-size:clamp(1.3rem,3.5vw,1.75rem);font-weight:600;line-height:1.3}h3{letter-spacing:.01em;margin-top:0;font-size:clamp(1.1rem,3vw,1.4rem);font-weight:600;line-height:1.3}h4{letter-spacing:.01em;margin-top:0;font-size:clamp(1rem,2.5vw,1.2rem);font-weight:600;line-height:1.4}p,span{font-size:clamp(.875rem,2vw,1rem);line-height:1.6}small{font-size:clamp(.75rem,1.8vw,.85rem)}.card-list{width:100%;margin:.5rem 0;padding:0;list-style:none}.card{background:var(--card-bg);border:1px solid var(--border);box-sizing:border-box;border-radius:clamp(.5rem,2vw,.75rem);width:100%;margin-bottom:clamp(.6rem,2vw,.8rem);padding:clamp(.75rem,2vw,1rem)}.card h3,.card h4{margin:0 0 .3rem;font-weight:600}.card p{color:#6b7280;margin:0}.tabs{flex-wrap:wrap;gap:clamp(.3rem,1.5vw,.5rem);width:100%;margin:1rem 0;display:flex}.tab-button{background:var(--pill-bg);min-width:fit-content;color:var(--pill-text);cursor:pointer;touch-action:manipulation;border:none;border-radius:999px;flex:auto;min-height:44px;padding:clamp(.4rem,1.5vw,.5rem) clamp(.5rem,2vw,.6rem);font-size:clamp(.8rem,2vw,.85rem)}.tab-button.active{background:var(--fvhbc-primary);color:#000}.primary-btn{background:var(--fvhbc-primary);color:#000;cursor:pointer;touch-action:manipulation;border:none;border-radius:999px;min-height:44px;padding:clamp(.4rem,1.5vw,.5rem) clamp(.85rem,2.5vw,1.2rem);font-size:clamp(.85rem,2vw,.95rem)}.primary-btn:hover{background:var(--fvhbc-primary-dark)}.text-input,textarea{border:1px solid var(--border);box-sizing:border-box;touch-action:manipulation;background:#fff;border-radius:clamp(.4rem,1.5vw,.5rem);width:100%;min-height:44px;padding:clamp(.5rem,1.5vw,.65rem) clamp(.6rem,2vw,.8rem);font-size:clamp(.9rem,2vw,1rem)}.text-input:focus,textarea:focus{outline:2px solid var(--fvhbc-primary-light);outline-offset:2px}textarea{resize:vertical;min-height:100px}.new-post-form,.new-event-form{margin-bottom:1rem}.new-post-textarea{margin-bottom:.7rem}.calendar-header{justify-content:center;align-items:center;gap:.75rem;margin:.75rem 0 .5rem;display:flex}.calendar-nav-btn{cursor:pointer;background:0 0;border:none;border-radius:999px;padding:.15rem .4rem;font-size:1rem}.calendar-month-label{font-size:.95rem;font-weight:600}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:.25rem;display:grid}.calendar-weekdays{color:#6b7280;text-align:center;margin-bottom:.25rem;font-size:.7rem}.calendar-cell{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:.5rem;flex-direction:column;justify-content:flex-start;align-items:flex-start;min-height:65px;padding:.25rem;display:flex;position:relative;overflow:hidden}.calendar-selected-events{margin-top:1rem}.event-detail-card{background:var(--card-bg);border:1px solid var(--border);border-radius:.75rem;margin-bottom:.75rem;padding:1rem}.event-detail-card h4{color:var(--text-primary);margin:0 0 .5rem;font-size:1rem;font-weight:600}.event-detail-card p{margin:0}.calendar-event-pill--worship,strong.calendar-event-pill--worship,.calendar-event-pill--youth,strong.calendar-event-pill--youth,.calendar-event-pill--men,strong.calendar-event-pill--men,.calendar-event-pill--women,strong.calendar-event-pill--women,.calendar-event-pill--young-adult,strong.calendar-event-pill--young-adult,.calendar-event-pill--men-worship,strong.calendar-event-pill--men-worship,.calendar-event-pill--women-worship,strong.calendar-event-pill--women-worship,.calendar-event-pill--cleaning,strong.calendar-event-pill--cleaning,.calendar-event-pill--snow-removal,strong.calendar-event-pill--snow-removal,.calendar-event-pill--3c,strong.calendar-event-pill--3c,.calendar-event-pill--prayer-requests,strong.calendar-event-pill--prayer-requests,.calendar-event-pill--fvhbc-event,strong.calendar-event-pill--fvhbc-event{background:var(--pill-bg);color:var(--pill-text);font-weight:500}.list{margin:.5rem 0;padding:0;list-style:none}.list li{background:var(--card-bg);border:1px solid var(--border);border-radius:.6rem;margin-bottom:.5rem;padding:.6rem}.admin-panel{padding:1rem}.admin-table-wrapper{margin-top:1rem;overflow-x:auto}.admin-table thead{background-color:#f3f4f6}.admin-group-chip{background-color:#f3f4f6;border-radius:9999px;align-items:center;gap:.25rem;padding:.125rem .5rem;font-size:.75rem;display:inline-flex}body{background:#faf8f3;margin:0;padding:0}.top-app-bar{z-index:40;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-sizing:border-box;width:100%;padding:.35rem clamp(.5rem,2vw,.75rem) .5rem;padding-top:max(.35rem,env(safe-area-inset-top));padding-left:max(clamp(.5rem,2vw,.75rem),env(safe-area-inset-left));padding-right:max(clamp(.5rem,2vw,.75rem),env(safe-area-inset-right));background:linear-gradient(90deg,#47637f 0%,#76a4c3 50%,#39c878 100%);position:sticky;top:0;box-shadow:0 4px 10px #00000017}.top-app-bar-inner{justify-content:space-between;align-items:center;gap:clamp(.5rem,2vw,1.5rem);width:100%;max-width:100%;margin:0 auto;padding:0 clamp(.25rem,1vw,1rem);display:flex}.brand-link{color:inherit;cursor:pointer;text-decoration:none;transition:opacity .2s}.brand-link:hover{opacity:.85}.brand{align-items:center;gap:.5rem;display:flex}.brand-logo-circle{background:radial-gradient(circle at 30% 30%,#ff4ab8,#24e46c);border-radius:9999px;flex-shrink:0;justify-content:center;align-items:center;width:clamp(32px,8vw,40px);height:clamp(32px,8vw,40px);display:flex;overflow:hidden}.brand-logo-img{object-fit:contain;width:110%;height:auto}.brand-text{flex-direction:column;align-items:flex-start;min-width:0;line-height:1.1;display:flex}.brand-title{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:clamp(.95rem,3vw,1.1rem);font-weight:700;overflow:hidden}.brand-subtitle{color:#e6f3ff;white-space:nowrap;font-size:clamp(.65rem,2vw,.75rem)}.top-nav-row{scrollbar-width:none;-webkit-overflow-scrolling:touch;background:#ffffffeb;border-radius:999px;flex-wrap:wrap;justify-content:center;gap:clamp(.25rem,1vw,.75rem);width:100%;max-width:calc(100% - 2rem);margin:.35rem auto 0;padding:clamp(.25rem,1vw,.4rem) clamp(.5rem,2vw,1rem);display:flex;overflow-x:auto}.top-nav-row::-webkit-scrollbar{display:none}.top-nav-link{color:#1f3341;white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;min-height:44px;padding:clamp(.25rem,1vw,.3rem) clamp(.65rem,2vw,.85rem);font-size:clamp(.8rem,2vw,.9rem);font-weight:600;text-decoration:none;transition:background .15s,color .15s;display:inline-flex}.top-nav-link:hover{background:#e4edf7}.top-nav-link-active{color:#10202b;background:#cde7ff}.hamburger-btn{cursor:pointer;background:#ffffffe6;border:none;border-radius:999px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:4px;width:clamp(32px,8vw,40px);min-width:32px;height:clamp(32px,8vw,40px);min-height:32px;padding:0;display:flex}.hamburger-btn span{background:#1f3341;border-radius:999px;width:18px;height:2px;display:block}.profile-icon-link{flex-shrink:0;text-decoration:none;display:block}.profile-icon{cursor:pointer;background:#ffffffe6;border:2px solid #ffffffe6;border-radius:50%;width:clamp(36px,8vw,44px);min-width:36px;height:clamp(36px,8vw,44px);min-height:36px;transition:transform .2s,box-shadow .2s;overflow:hidden}.profile-icon:hover{transform:scale(1.05);box-shadow:0 2px 8px #0003}.profile-icon-img{object-fit:cover;width:100%;height:100%}.profile-icon-placeholder{color:#4f7b9d;background:linear-gradient(135deg,#e0f2fe 0%,#bae6fd 100%);justify-content:center;align-items:center;width:100%;height:100%;font-size:1.2rem;font-weight:600;display:flex}.side-drawer{width:260px;max-width:80%;height:100vh;z-index:50;height:100dvh;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);background:#f9fafb;flex-direction:column;transition:transform .2s ease-out;display:flex;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:2px 0 10px #00000026}.side-drawer-open{transform:translate(0)}.side-drawer-header{color:#fff;background:#47637f;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.side-drawer-title{font-weight:600}.side-drawer-close{color:#fff;cursor:pointer;background:0 0;border:none;font-size:1.4rem}.side-drawer-nav{flex-direction:column;gap:.25rem;padding:.75rem 1rem;display:flex}.side-drawer-nav .top-nav-link{width:100%;display:block}.backdrop{z-index:45;background:#00000040;position:fixed;inset:0}.app-main{box-sizing:border-box;flex:1;width:100%;max-width:100%;margin:.75rem 0 2rem;padding:0 clamp(.75rem,3vw,2rem) 1.5rem;overflow-y:auto}@media (min-width:1024px){.app-main{padding:0 2.5rem 1.5rem}}@media (min-width:768px){.hamburger-btn{display:none}.top-nav-row{margin-top:.5rem}.side-drawer{display:none}.top-app-bar-inner{padding:0 1rem}.app-main{padding:0 2rem 1.5rem}}@media (max-width:767px){.top-app-bar-inner{gap:.5rem;padding:0 .25rem}.brand-title{font-size:clamp(.9rem,4vw,1rem)}.brand-subtitle,.top-nav-row{display:none}.app-main{margin:.5rem 0 1.5rem;padding:0 1rem 1.5rem}}@media (max-width:480px){.app-main{margin:.35rem 0 1rem;padding:0 .75rem 1rem}.brand{gap:.35rem}}@media (max-width:767px) and (orientation:landscape){.top-app-bar{position:sticky;top:0}.brand-logo-circle{width:28px;height:28px}.brand-title{font-size:.85rem}.profile-icon,.hamburger-btn{width:30px;min-width:30px;height:30px;min-height:30px}.app-main{flex-direction:column;max-width:100%;display:flex}.card-list,.home-list{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:.75rem;display:grid}.card,.group-card,.home-card{margin-bottom:0}.calendar-section{max-width:100%!important}.calendar-grid{gap:.4rem!important;max-width:100%!important}.calendar-cell{min-height:45px!important}.admin-table-wrapper{max-height:60vh;overflow-y:auto}}.admin-panel{background:#ffffffe6;border-radius:16px;margin-top:.75rem;padding:1.25rem 1.5rem 1.5rem;box-shadow:0 8px 20px #0f172a14}.admin-table-wrapper{overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.9rem}.admin-table th,.admin-table td{text-align:left;vertical-align:top;border-bottom:1px solid #e5e7eb;padding:.5rem .75rem}.admin-table tbody tr:nth-child(2n){background:#fafafa}.admin-table select{background:#fff;border:1px solid #d1d5db;border-radius:999px;padding:.25rem .5rem;font-size:.85rem}.admin-groups-cell{min-width:220px}.admin-groups-grid{flex-wrap:wrap;gap:.35rem;display:flex}.admin-table td:last-child{white-space:nowrap;color:#6b7280;font-size:.78rem}@media (max-width:640px){.admin-table thead{display:none}.admin-table,.admin-table tbody,.admin-table tr,.admin-table td{width:100%;display:block}.admin-table tr{background:#fff;border:none;border-radius:12px;margin-bottom:.75rem;padding:.5rem .6rem;box-shadow:0 4px 10px #0f172a0f}.admin-table td{border:none;padding:.2rem 0}.admin-table td:before{content:attr(data-label);text-transform:uppercase;letter-spacing:.04em;color:#9ca3af;margin-bottom:.1rem;font-size:.7rem;display:block}}.admin-panel{box-sizing:border-box;background:#fffffff5;border-radius:clamp(12px,3vw,16px);width:100%;margin-top:.75rem;padding:clamp(1rem,3vw,1.5rem);box-shadow:0 8px 20px #0f172a14}.admin-panel h2{margin:0 0 .25rem;font-size:clamp(1.2rem,3.5vw,1.4rem)}.admin-panel p{color:#4b5563;margin:0 0 .75rem;font-size:clamp(.85rem,2vw,.9rem)}.admin-table-wrapper{-webkit-overflow-scrolling:touch;width:100%;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;min-width:600px;font-size:clamp(.8rem,2vw,.9rem)}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid #e5e7eb;padding:clamp(.4rem,1.5vw,.6rem) clamp(.5rem,2vw,.75rem)}.admin-table thead{background:#f3f4f6}.admin-table th{color:#374151;font-weight:600}.admin-row-clickable{cursor:pointer}.admin-row-clickable:hover{background:#f9fafb}.admin-created{white-space:nowrap;color:#6b7280;font-size:.78rem}.admin-manage-btn{cursor:pointer;background:#f9fafb;border:1px solid #d1d5db;border-radius:999px;padding:.25rem .7rem;font-size:.8rem}.admin-manage-btn:hover{background:#e5efff}.admin-back-btn{color:#2563eb;cursor:pointer;background:0 0;border:none;margin-bottom:.5rem;font-size:.85rem}.admin-detail-grid{grid-template-columns:minmax(0,1.1fr) minmax(0,1.2fr);gap:1.25rem;display:grid}.admin-detail-section{background:#f9fafb;border-radius:12px;padding:.9rem 1rem}.admin-detail-section h3{margin-top:0;margin-bottom:.4rem;font-size:1rem}.admin-field{flex-direction:column;gap:.25rem;max-width:220px;margin-top:.8rem;display:flex}.admin-field span{color:#6b7280;font-size:.8rem}.admin-field select{border:1px solid #d1d5db;border-radius:8px;padding:.35rem .5rem;font-size:.9rem}.admin-note{color:#6b7280;margin-top:.75rem;font-size:.8rem}.admin-groups-grid{flex-wrap:wrap;gap:.35rem;margin-top:.5rem;display:flex}.admin-group-chip{background:var(--pill-bg);border:1px solid var(--border);white-space:nowrap;cursor:pointer;border-radius:999px;align-items:center;gap:.25rem;padding:.25rem .55rem;font-size:.78rem;display:inline-flex}.admin-group-chip input[type=checkbox]{width:.8rem;height:.8rem;margin:0}.admin-group-chip span{color:var(--pill-text);font-weight:500}@media (max-width:768px){.admin-detail-grid{grid-template-columns:minmax(0,1fr)}}.group-card{background:linear-gradient(135deg,#fff 0%,#f6f5ff 100%);border:1px solid #0000000d;border-radius:14px;margin-bottom:1rem;padding:1rem 1.25rem;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 12px #0000000f}.group-card h4{color:#1f2937;margin-bottom:.25rem;font-size:1.05rem;font-weight:700}.card-list{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.group-card{box-sizing:border-box;background:linear-gradient(135deg,#fff 0%,#fdf6e3 40%,#fef3c7 100%);border:1px solid #94a3b840;border-radius:clamp(10px,3vw,14px);width:100%;padding:clamp(.75rem,2.5vw,1.15rem);transition:transform .15s,box-shadow .15s,background .15s;box-shadow:0 4px 12px #0f172a14}.group-card:hover{transform:translateY(-2px);box-shadow:0 10px 20px #0f172a29}.group-card h4,.group-card h3{color:#111827;margin:0 0 .2rem;font-size:1.02rem;font-weight:700}.group-card p{color:#4b5563;margin:0;font-size:.88rem}.group-accent-worship{border-left:6px solid #60a5fa}.group-accent-men{border-left:6px solid #34d399}.group-accent-women{border-left:6px solid #f472b6}.group-accent-youth{border-left:6px solid #facc15}.home-section{margin-bottom:1.5rem}.home-list{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.home-card{box-sizing:border-box;background:#fffffff5;border:1px solid #94a3b840;border-radius:clamp(10px,3vw,14px);width:100%;padding:clamp(.75rem,2vw,1rem);box-shadow:0 4px 12px #0f172a14}.home-card-header{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.35rem;display:flex}.home-card-tag{background:var(--pill-bg);color:var(--pill-text);border-radius:999px;align-items:center;padding:.15rem .6rem;font-size:.75rem;font-weight:600;display:inline-flex}.home-card-time{color:#6b7280;font-size:.75rem}.home-card-body p{color:#374151;margin:.1rem 0 0;font-size:.9rem}.calendar-section{max-width:420px;margin:.75rem auto 1.5rem}.calendar-header{justify-content:space-between;align-items:center;max-width:420px;margin:.75rem auto .25rem;display:flex}.calendar-weekdays{color:#6b7280;text-align:center;grid-template-columns:repeat(7,1fr);max-width:420px;margin:0 auto .4rem;font-size:.75rem;display:grid}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:.35rem;max-width:420px;margin:0 auto;display:grid}.calendar-cell{aspect-ratio:1;border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:.5rem;flex-direction:column;justify-content:flex-start;align-items:flex-start;min-height:auto;padding:.2rem .25rem;display:flex;position:relative;overflow:hidden}.calendar-cell.empty{cursor:default;background:0 0;border:none}.calendar-cell.selected{border-color:var(--fvhbc-primary);box-shadow:0 0 0 1px #76a4c359}.calendar-cell.today{border-color:var(--fvhbc-pink);background:#fff1f7}.calendar-day-number{margin-bottom:.1rem;font-size:.8rem;font-weight:600}.calendar-events{flex-direction:column;gap:.1rem;width:100%;display:flex}.calendar-event-pill{white-space:nowrap;text-overflow:ellipsis;border-radius:999px;padding:.05rem .35rem;font-size:.65rem;overflow:hidden}.calendar-event-more{color:#6b7280;font-size:.63rem}.calendar-selected-events{max-width:420px;margin:1rem auto 0}.calendar-section,.calendar-header,.calendar-weekdays,.calendar-grid,.calendar-selected-events{box-sizing:border-box;width:100%;max-width:100%;margin-left:auto;margin-right:auto;padding:0 clamp(.25rem,2vw,.5rem)}@media (min-width:768px) and (max-width:1023px){.calendar-section,.calendar-header,.calendar-weekdays,.calendar-grid,.calendar-selected-events{max-width:90%!important}}@media (min-width:1024px){.calendar-section,.calendar-header,.calendar-weekdays,.calendar-grid,.calendar-selected-events{max-width:800px!important}}.calendar-weekdays{text-align:center;grid-template-columns:repeat(7,1fr);margin-bottom:.4rem;font-size:.75rem;display:grid}.calendar-grid{margin-top:.4rem;grid-template-columns:repeat(7,1fr)!important;gap:.55rem .5rem!important;display:grid!important}.calendar-cell{flex-direction:column;align-items:flex-start;display:flex;border-radius:10px!important;min-height:56px!important;padding:.25rem!important}.calendar-day-number{font-size:.78rem!important}.calendar-event-pill{font-size:.66rem!important}.calendar-grid{box-sizing:border-box;width:100%;max-width:100%;grid-template-columns:repeat(7,1fr)!important;gap:clamp(.35rem,2vw,.75rem)!important;display:grid!important}.calendar-cell{aspect-ratio:1;box-sizing:border-box;font-size:clamp(.7rem,2vw,.85rem);border-radius:clamp(8px,2vw,10px)!important;min-height:clamp(48px,12vw,60px)!important;padding:clamp(.2rem,1vw,.3rem)!important}.field-with-label{flex:1;position:relative}.field-label{color:#9ca3af;pointer-events:none;font-size:.7rem;position:absolute;top:4px;left:10px}.text-input.with-label{padding-top:1.2rem}body,.app-shell,.app-main,h1,h2,h3,h4,p,span,small,.card,.card *,.list li,.list li *,.home-card,.home-card *,.group-card,.group-card *,.admin-panel,.admin-panel *,.calendar-selected-events,.calendar-selected-events *,.calendar-grid,.calendar-grid *,.top-nav-row,.top-nav-row *,.side-drawer,.side-drawer *{color:#000;text-shadow:none}.field-label,.text-input,.text-input *,textarea,textarea *{color:#000!important;text-shadow:none!important}@media (max-width:399px){html{font-size:14px}.calendar-grid{gap:.25rem!important}.calendar-cell{min-height:42px!important;padding:.15rem!important}.calendar-day-number{font-size:.65rem!important}.calendar-event-pill{font-size:.55rem!important}}@media (min-width:400px) and (max-width:599px){html{font-size:15px}}@media (min-width:600px) and (max-width:899px){.app-main{max-width:100%;padding:0 2rem 1.5rem}.card-list,.home-list{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem;display:grid}.card,.group-card,.home-card{margin-bottom:0}}@media (min-width:768px) and (max-width:1024px) and (orientation:portrait){.app-main{max-width:100%;padding:0 2.5rem 1.5rem}.top-nav-row{max-width:calc(100% - 3rem)}.card-list,.home-list{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.25rem}.calendar-section,.calendar-header,.calendar-weekdays,.calendar-grid,.calendar-selected-events{max-width:600px!important}}@media (min-width:900px){.app-main{padding:0 2.5rem 1.5rem}.card-list,.home-list{grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.25rem;display:grid}.card,.group-card,.home-card{margin-bottom:0}}@media (min-width:1200px){html{font-size:17px}.app-main{max-width:100%;padding:0 3rem 2rem}.card-list,.home-list{grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:1.5rem}}@media (min-width:1600px){.app-main{max-width:100%;padding:0 4rem 2rem}.card-list,.home-list{grid-template-columns:repeat(auto-fit,minmax(420px,1fr));gap:2rem;max-width:1800px;margin-left:auto;margin-right:auto}}@media (orientation:landscape) and (max-height:500px){.top-app-bar{padding:.2rem .5rem .3rem}.top-app-bar-inner{padding:0 .25rem}.brand-logo-circle{width:32px;height:32px}.brand-title{font-size:.9rem}.brand-subtitle{display:none}.top-nav-row{margin:.25rem auto 0;padding:.25rem .4rem}.top-nav-link{min-height:36px;padding:.2rem .6rem;font-size:.8rem}.app-main{margin:.35rem 0 .75rem;padding:0 1rem .75rem}.card{margin-bottom:.5rem;padding:.6rem .75rem}h1{font-size:1.3rem}h2{font-size:1.2rem}h3{font-size:1.1rem}h4{font-size:1rem}.profile-icon,.hamburger-btn{width:32px;height:32px}}@media (orientation:landscape) and (min-height:500px) and (max-height:800px){.app-main{padding:0 clamp(1rem,4vw,2rem) 1.25rem}.calendar-section,.calendar-header,.calendar-weekdays,.calendar-grid,.calendar-selected-events{max-width:600px!important}}@media (orientation:landscape) and (min-width:768px) and (max-width:1366px){.app-main{max-width:100%;padding:0 2.5rem 1.5rem}.top-nav-row{max-width:calc(100% - 3rem)}.card-list,.home-list{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.25rem;display:grid}.card,.group-card,.home-card{margin-bottom:0}.calendar-section,.calendar-header,.calendar-weekdays,.calendar-grid,.calendar-selected-events{max-width:700px!important}}@media (orientation:landscape) and (min-width:1024px){.app-main{max-width:100%;padding:0 3rem 1.5rem}.top-nav-row{max-width:calc(100% - 4rem)}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@media print{.top-app-bar,.hamburger-btn,.side-drawer,.backdrop,.profile-icon-link{display:none!important}body{background:#fff}.app-main{max-width:100%;padding:0}}.document-browser{width:100%}.doc-browser-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.doc-browser-toolbar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.view-toggle{background:var(--pill-bg);border-radius:8px;gap:.25rem;padding:.25rem;display:flex}.view-toggle button{cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.4rem .75rem;font-size:1.2rem;transition:background .2s}.view-toggle button.active{background:var(--fvhbc-primary)}.view-toggle button:hover:not(.active){background:#0000000d}.doc-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;display:grid}.doc-card{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:12px;padding:1rem;transition:transform .2s,box-shadow .2s}.doc-card:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000001a}.doc-card-icon{background:var(--bg-light);border-radius:8px;justify-content:center;align-items:center;width:100%;height:120px;margin-bottom:.75rem;display:flex;overflow:hidden}.doc-card-icon img{object-fit:cover;width:100%;height:100%}.doc-card-name{text-overflow:ellipsis;white-space:nowrap;margin-bottom:.25rem;font-size:.9rem;font-weight:600;overflow:hidden}.doc-card-meta{color:#6b7280;font-size:.75rem}.doc-list{flex-direction:column;gap:.5rem;display:flex}.doc-list-item{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem 1rem;transition:background .2s;display:flex}.doc-list-item:hover{background:var(--bg-light)}.doc-list-name{text-overflow:ellipsis;white-space:nowrap;font-size:.95rem;font-weight:600;overflow:hidden}.doc-list-meta{color:#6b7280;margin-top:.15rem;font-size:.8rem}.doc-list-link{background:var(--fvhbc-primary);color:#000;white-space:nowrap;border-radius:6px;padding:.35rem .75rem;font-size:.85rem;font-weight:600;text-decoration:none;transition:background .2s}.doc-list-link:hover{background:var(--fvhbc-primary-dark)}.modal-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:900px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.file-preview-modal{padding:1.5rem}.modal-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.modal-close-btn{cursor:pointer;color:#6b7280;background:0 0;border:none;flex-shrink:0;padding:.25rem;font-size:1.5rem}.modal-close-btn:hover{color:#000}.file-info-grid{background:var(--bg-light);border-radius:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem;padding:1rem;display:grid}.file-info-item{flex-direction:column;gap:.25rem;display:flex}.file-info-label{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.file-info-value{font-size:.9rem;font-weight:500}.file-preview-container{margin-bottom:1.5rem}.image-preview{background:#f3f4f6;border-radius:8px;justify-content:center;align-items:center;width:100%;max-height:500px;display:flex;overflow:hidden}.image-preview img{object-fit:contain;max-width:100%;max-height:500px}.doc-preview-iframe{border:1px solid var(--border);border-radius:8px;width:100%;height:600px}.modal-actions{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:.75rem;padding-top:1rem;display:flex}.export-links{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.export-link-btn{color:#374151;background:#e5e7eb;border-radius:6px;padding:.4rem .75rem;font-size:.85rem;font-weight:600;text-decoration:none;transition:background .2s}.export-link-btn:hover{background:#d1d5db}@media (max-width:768px){.doc-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}.doc-card-icon{height:100px}.doc-browser-toolbar{flex-direction:column;align-items:stretch}.doc-browser-toolbar .text-input,.doc-browser-toolbar .admin-select{width:100%}.file-info-grid{grid-template-columns:1fr}.doc-preview-iframe{height:400px}.modal-actions{flex-direction:column;align-items:stretch}.export-links{justify-content:space-between;width:100%}}.admin-wrap{max-width:1100px;margin:0 auto;padding:1rem}.admin-header{justify-content:space-between;align-items:flex-end;margin-bottom:1rem;display:flex}.admin-title{margin:0;font-size:1.4rem;font-weight:700}.admin-subtitle{color:#6b7280;margin:.25rem 0 0}.admin-alert{color:#7f1d1d;background:#fee2e2;border:1px solid #fecaca;border-radius:12px;margin-bottom:1rem;padding:.75rem .9rem}.admin-grid{grid-template-columns:320px 1fr;gap:1rem;display:grid}.admin-panel{background:#ffffffe6;border:1px solid #e5e7ebe6;border-radius:16px;overflow:hidden;box-shadow:0 8px 18px #0000000f}.admin-panel-head{border-bottom:1px solid #e5e7ebe6;padding:.85rem}.admin-panel-title{margin-bottom:.5rem;font-weight:700}.admin-search{border:1px solid #d1d5db;border-radius:12px;outline:none;width:100%;padding:.55rem .7rem}.admin-search:focus{border-color:#3b82f6cc}.admin-userlist{max-height:70vh;overflow:auto}.admin-userrow{text-align:left;cursor:pointer;background:0 0;border:0;border-bottom:1px solid #e5e7ebb3;width:100%;padding:.65rem .85rem}.admin-userrow:hover{background:#f3f4f699}.admin-userrow.active{background:#dbeafeb3}.admin-userrow-name{margin-bottom:.35rem;font-weight:700}.admin-userrow-badges{flex-wrap:wrap;gap:.35rem;display:flex}.badge{text-transform:uppercase;letter-spacing:.04em;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:999px;padding:.18rem .45rem;font-size:.72rem}.badge-admin{background:#fee2e2;border-color:#fca5a5}.badge-user{background:#f3f4f6}.badge-event{background:#ede9fe;border-color:#c4b5fd}.badge-group{background:#dbeafe;border-color:#93c5fd}.admin-editor{position:relative}.admin-editor-head{border-bottom:1px solid #e5e7ebe6;grid-template-columns:1fr 240px;gap:1rem;padding:1rem;display:grid}.admin-editor-name{font-size:1.25rem;font-weight:800}.admin-editor-meta{color:#6b7280;margin-top:.35rem;font-size:.85rem}.admin-label{color:#6b7280;margin-bottom:.25rem;font-size:.8rem;display:block}.admin-select{border:1px solid #d1d5db;border-radius:12px;width:100%;padding:.55rem .7rem}.admin-help{color:#6b7280;margin-top:.4rem;font-size:.8rem}.admin-section{border-bottom:1px solid #e5e7ebe6;padding:1rem}.admin-section-title{margin-bottom:.25rem;font-weight:800}.admin-section-subtitle{color:#6b7280;margin-bottom:.75rem;font-size:.85rem}.admin-gcards{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;display:grid}.admin-gcard{background:#f9fafbe6;border:1px solid #e5e7eb;border-radius:14px;padding:.8rem}.admin-gcard-title{margin-bottom:.55rem;font-weight:700}.admin-gcard-toggles{flex-wrap:wrap;gap:.85rem;display:flex}.toggle{align-items:center;gap:.4rem;font-size:.9rem;display:inline-flex}.toggle input{width:16px;height:16px}.toggle.disabled{opacity:.5}.admin-perms .perm{background:#f9fafbe6;border:1px solid #e5e7eb;border-radius:14px;align-items:flex-start;gap:.6rem;padding:.8rem;display:flex}.perm-title{font-weight:800}.perm-desc{color:#6b7280;margin-top:.15rem;font-size:.85rem}.admin-savebar{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffffeb;border-top:1px solid #e5e7ebe6;justify-content:flex-end;gap:.6rem;padding:.9rem 1rem;display:flex;position:sticky;bottom:0}@media (max-width:900px){.admin-grid{grid-template-columns:1fr}.admin-userlist{max-height:260px}.admin-editor-head,.admin-gcards{grid-template-columns:1fr}}
