:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--primary-color: #2e7d32;--secondary-color: #66bb6a;--accent-color: #fdd835;--text-dark: #1b5e20;--text-light: #fff;--bg-light: #f1f8e9;--bg-dark: #1b5e20;--shadow: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .15)}*{box-sizing:border-box}html{scroll-behavior:smooth}html,body,#root{margin:0;padding:0;width:100%;min-width:320px;overflow-x:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text-dark);line-height:1.6}.App{width:100%;min-width:320px;overflow-x:hidden}main{width:100%;overflow-x:hidden}.container{margin:0 auto;padding:0 60px;width:100%;max-width:100%}.app-header{background:var(--primary-color);color:var(--text-light);padding:1rem 0;position:sticky;top:0;z-index:1000;box-shadow:var(--shadow)}.app-header .container{display:flex;justify-content:space-between;align-items:center}.logo{display:flex;align-items:center;gap:12px;font-size:1.5rem;font-weight:700}.logo-icon{font-size:2rem}.logo img.logo-icon{width:26px!important;height:26px!important;min-width:26px;min-height:26px;max-width:26px!important;max-height:26px!important;border-radius:50%;object-fit:cover;border:none;display:block;flex-shrink:0}.nav{display:flex;gap:2rem}.nav a{color:var(--text-light);text-decoration:none;font-weight:500;transition:opacity .3s}.nav a:hover{opacity:.8}.nav-buttons{display:flex;gap:1rem}.nav-button{background:#fff3;border:2px solid rgba(255,255,255,.3);color:var(--text-light);padding:.6rem 1.5rem;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s}.nav-button:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px)}.nav-button:active{transform:translateY(0)}.home-container{max-width:1100px;margin:0 auto;padding:0 24px}.home-section{padding:72px 0}.hero{background:url(/ballongrass.jpg) center center / cover no-repeat;position:relative;color:var(--text-light);padding:88px 0 72px;width:100%}.hero-content{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center;position:relative;z-index:1}.hero-text{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.hero-brand-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}.hero-brand-name{font-size:1.1rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;opacity:.9}.hero-title-icon{width:48px;height:48px;border-radius:50%;object-fit:cover}.hero-headline{font-size:clamp(1.75rem,3.2vw,2.45rem);line-height:1.25;margin:0 0 1rem;font-weight:800;max-width:18ch}.hero-subheadline{font-size:1.08rem;line-height:1.7;margin:0 0 1.25rem;opacity:.95;max-width:42rem}.hero-review{margin:0 0 1.5rem;padding:1rem 1.25rem;max-width:36rem;background:#ffffff24;border:1px solid rgba(255,255,255,.28);border-radius:12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.hero-review-stars{margin:0 0 .5rem;color:#ffd54f;font-size:.9rem;letter-spacing:.05em}.hero-review-quote{margin:0 0 .5rem;font-size:.98rem;line-height:1.6;font-style:italic}.hero-review-author{margin:0;font-size:.85rem;opacity:.9}.hero-cta-block{display:flex;flex-direction:column;align-items:flex-start;gap:.75rem;margin-bottom:1rem}.hero-secondary-links{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.hero-text-link{background:none;border:none;color:#fff;text-decoration:underline;cursor:pointer;font-size:.95rem;padding:0}.hero-link-divider{opacity:.7}.hero-cta-label{margin:0;font-size:1.05rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.hero-image{display:flex;align-items:flex-start}.phone-mockup{max-width:241px;max-height:428px;margin:0 auto;overflow:visible;transform:perspective(1000px) rotateY(-5deg);transition:transform .3s}.phone-mockup:hover{transform:perspective(1000px) rotateY(0)}.phone-mockup img{width:100%;height:auto;object-fit:contain;display:block}.download-buttons{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.download-buttons{justify-content:flex-start}.download-button{display:inline-block;transition:transform .3s,box-shadow .3s}.download-button:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.download-button img,.download-button svg{height:50px;width:auto}section{width:100%}.section-title{font-size:2.5rem;text-align:center;margin-bottom:1rem;color:var(--primary-color)}.section-subtitle{text-align:center;font-size:1.2rem;color:#666;margin-bottom:3rem;max-width:46rem;margin-left:auto;margin-right:auto;line-height:1.7}.section-title-left{text-align:left}.section-subtitle-spaced{margin-top:3.5rem}.benefits-strip{background:#fff}.benefits-strip-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1.25rem}.benefit-strip-card{background:var(--bg-light);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow)}.benefit-strip-icon{font-size:2rem;margin-bottom:.75rem}.benefit-strip-card h3{margin:0 0 .5rem;color:var(--text-dark);font-size:1.15rem}.benefit-strip-card p{margin:0;color:#555;line-height:1.6}.societies-section{background:var(--bg-light)}.societies-section-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}.societies-lead{font-size:1.1rem;line-height:1.75;color:#444;margin-bottom:1.5rem}.societies-benefits-list{list-style:none;padding:0;margin:0}.societies-benefits-list li{position:relative;padding-left:1.5rem;margin-bottom:.9rem;line-height:1.6;color:#333}.societies-benefits-list li:before{content:"⛳";position:absolute;left:0;top:0}.societies-section-visual{text-align:center}.societies-screenshot{width:100%;max-width:280px;border-radius:20px;box-shadow:var(--shadow-lg)}.societies-caption{margin-top:.75rem;color:#666;font-size:.95rem}.formats-section{background:var(--bg-light)}.formats-panel{background:#fff;border-radius:16px;padding:2rem;box-shadow:var(--shadow)}.formats-highlight{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.5rem}.formats-highlight-icon{font-size:2rem;line-height:1}.formats-highlight h3{margin:0 0 .5rem;color:var(--text-dark)}.formats-highlight p{margin:0;color:#555;line-height:1.6}.formats-list-heading{margin:0 0 .75rem;font-size:1rem;color:var(--text-dark)}.formats-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem 1.5rem}.formats-list li{position:relative;padding-left:1.25rem;color:#333;line-height:1.5}.formats-list li:before{content:"✓";position:absolute;left:0;color:var(--primary-color);font-weight:700}.differentiators-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem 2rem}.differentiator-item{display:flex;gap:.85rem;align-items:flex-start}.differentiator-icon{font-size:1.5rem;line-height:1.2}.differentiator-item h3{margin:0 0 .35rem;font-size:1.05rem;color:var(--text-dark)}.differentiator-item p{margin:0;color:#555;line-height:1.55;font-size:.95rem}.screenshots{background:var(--bg-light)}.screenshots-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1.25rem}.screenshot-card{margin:0;text-align:center}.screenshot-card img{width:100%;border-radius:16px;box-shadow:var(--shadow);display:block}.screenshot-card figcaption{margin-top:.65rem;font-weight:600;color:var(--text-dark);font-size:.92rem}.social-proof-section{background:#fff}.social-proof-rating{text-align:center;margin:0 0 2rem;color:#444;font-weight:600}.social-proof-reviews{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem;margin-bottom:2rem}.social-proof-card{background:var(--bg-light);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow);text-align:left}.social-proof-stars{margin:0 0 .75rem;color:#e6a700;letter-spacing:.05em;font-size:1rem}.social-proof-quote{font-size:1rem;line-height:1.65;color:var(--text-dark);margin:0 0 .75rem;font-style:italic}.social-proof-attribution{margin:0;color:#666;font-size:.9rem}.social-proof-invite{margin:0 auto;max-width:720px;text-align:center;color:#444;line-height:1.6;font-weight:600}.cta-section{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff}.cta-section-inner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1.5rem}.cta-copy h2{margin:0 0 .75rem;font-size:2rem}.cta-copy p{margin:0 0 .5rem;line-height:1.7;font-size:1.05rem}.cta-store-line{opacity:.95}.cta-actions .download-buttons{justify-content:center}.features{background:var(--bg-light);width:100%}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:3rem;width:100%}.feature-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:var(--shadow);text-align:center;transition:transform .3s,box-shadow .3s}.feature-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-title{font-size:1.5rem;margin-bottom:1rem;color:var(--primary-color)}.feature-description{color:#666;line-height:1.6}.screenshots{background:#fff}.screenshots-carousel{display:flex;gap:2rem;overflow-x:auto;padding:2rem 0;scroll-snap-type:x mandatory}.screenshot-item{flex:0 0 300px;scroll-snap-align:center}.screenshot-title{font-size:1.2rem;font-weight:700;color:var(--primary-color);text-align:center;margin-bottom:12px}.screenshot-item img{width:100%;border-radius:20px;box-shadow:var(--shadow-lg);transition:transform .3s}.screenshot-item img:hover{transform:scale(1.05)}.leaderboard{background:var(--bg-light)}.leaderboard-controls{display:flex;justify-content:center;gap:3rem;margin:2rem 0;flex-wrap:wrap}.leaderboard-filters{display:flex;align-items:center;gap:.75rem}.filter-select{padding:.55rem .9rem;border:2px solid var(--primary-color);background:#fff;color:var(--primary-color);font-weight:600;border-radius:8px;cursor:pointer;font-size:.95rem}.filter-select:disabled{opacity:.6;cursor:not-allowed}.filter-label{font-weight:600;color:var(--primary-color);font-size:1rem}.filter-btn{padding:.6rem 1.2rem;border:2px solid var(--primary-color);background:#fff;color:var(--primary-color);font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s;font-size:.95rem}.filter-btn:hover{background:var(--bg-light);transform:translateY(-2px)}.filter-btn.active{background:var(--primary-color);color:#fff}.leaderboard-loading,.leaderboard-error{text-align:center;padding:3rem}.spinner{border:4px solid #f3f3f3;border-top:4px solid var(--primary-color);border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.leaderboard-table{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001f;overflow:hidden;border:2px solid #f0f0f0}.leaderboard-table table{width:100%;border-collapse:collapse}.leaderboard-table th{background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;padding:1.25rem 1rem;text-align:left;font-weight:700;font-size:1.1rem;text-transform:uppercase;letter-spacing:.5px}.leaderboard-table td{padding:1.25rem 1rem;border-bottom:1px solid #e5e7eb;transition:all .3s ease}.leaderboard-table tr:hover{background:linear-gradient(135deg,#f8fafc,#e2e8f0);transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.leaderboard-table tr.top-1{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#92400e;font-weight:700;box-shadow:0 4px 16px #fbbf244d}.leaderboard-table tr.top-1:hover{background:linear-gradient(135deg,#f59e0b,#d97706);transform:translateY(-2px);box-shadow:0 8px 24px #fbbf2466}.leaderboard-table tr.top-2{background:linear-gradient(135deg,#e5e7eb,#d1d5db);color:#374151;font-weight:600;box-shadow:0 2px 8px #0000001a}.leaderboard-table tr.top-2:hover{background:linear-gradient(135deg,#d1d5db,#9ca3af);transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.leaderboard-table tr.top-3{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#92400e;font-weight:600;box-shadow:0 2px 8px #fbbf2433}.leaderboard-table tr.top-3:hover{background:linear-gradient(135deg,#f59e0b,#d97706);transform:translateY(-1px);box-shadow:0 4px 12px #fbbf244d}.player-name{font-weight:600}.rank-badge{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff;width:35px;height:35px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;box-shadow:0 4px 12px #dc26264d;border:2px solid #fef2f2;transition:all .3s ease}.rank-badge:hover{transform:scale(1.1);box-shadow:0 6px 16px #dc262666}.club-name{font-weight:600;color:var(--primary-color)}.course-name{font-size:.9rem;color:#666}.points-badge{background:linear-gradient(135deg,#059669,#10b981);color:#fff;padding:.75rem 1.25rem;border-radius:25px;font-weight:700;font-size:1.1rem;box-shadow:0 4px 12px #0596694d;border:2px solid #ecfdf5;transition:all .3s ease;text-shadow:0 1px 2px rgba(0,0,0,.1)}.points-badge:hover{transform:scale(1.05);box-shadow:0 6px 16px #05966966}.no-scores{text-align:center;padding:3rem;color:#666}.app-footer{background:var(--bg-dark);color:var(--text-light);padding:2.5rem 0}.footer-inner{display:flex;flex-direction:column;gap:1.25rem;align-items:center;text-align:center}.footer-brand p{margin:.35rem 0}.footer-tagline{font-weight:600;opacity:.95}.footer-links{display:flex;gap:1.25rem 2rem;justify-content:center;flex-wrap:wrap}.footer-links a{color:var(--text-light);text-decoration:none;transition:opacity .3s}.footer-links a:hover{opacity:.7}@media (max-width: 968px){.container{padding:0 30px}.hero{padding:60px 0}.hero-content{grid-template-columns:1fr;gap:2rem}.hero-text{align-items:center;text-align:center}.hero-cta-block,.download-buttons{align-items:center;justify-content:center}.hero-secondary-links{justify-content:center}.hero-review{text-align:left}.benefits-strip-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.differentiators-grid,.formats-list{grid-template-columns:1fr}.screenshots-row{grid-template-columns:repeat(2,minmax(0,1fr))}.societies-section-inner{grid-template-columns:1fr}.section-title-left{text-align:center}.phone-mockup{max-width:250px;max-height:540px}.nav{gap:1rem;font-size:.9rem}.nav-buttons{gap:.75rem}.nav-button{padding:.5rem 1rem;font-size:.9rem}.home-section{padding:56px 0}.leaderboard-controls{gap:1.5rem}.leaderboard-filters{gap:.5rem}.filter-label{font-size:.9rem}.filter-btn{padding:.6rem 1rem;font-size:.9rem}.leaderboard-table{overflow-x:auto;-webkit-overflow-scrolling:touch}.leaderboard-table table{font-size:.9rem;min-width:600px}.leaderboard-table th,.leaderboard-table td{padding:.75rem .5rem}}@media (max-width: 640px){.container{padding:0 20px}.hero{padding:40px 0;min-height:auto}.hero-content{gap:1.5rem}.benefits-strip-grid,.screenshots-row{grid-template-columns:1fr}.cta-copy h2{font-size:1.7rem}.phone-mockup{max-width:200px;max-height:430px}.section-title{font-size:1.8rem}.section-subtitle{font-size:1rem}.nav{display:flex;gap:.75rem;font-size:.95rem}.nav-buttons{gap:.5rem;flex-wrap:wrap}.nav-button{padding:.5rem .75rem;font-size:.85rem}.logo{font-size:1.2rem}.logo-icon{font-size:1.5rem}.logo img.logo-icon{width:22px!important;height:22px!important;max-width:22px!important;max-height:22px!important}.download-buttons{justify-content:center;flex-direction:column;align-items:center}.download-button img,.download-button svg{height:45px}.feature-card{padding:1.5rem}.feature-icon{font-size:2.5rem}.feature-title{font-size:1.3rem}.screenshot-item{flex:0 0 200px}.screenshot-title{font-size:1rem;margin-bottom:10px}section{padding:40px 0}.leaderboard-table th,.leaderboard-table td{padding:.5rem .25rem;font-size:.85rem}.rank-badge{width:25px;height:25px;font-size:.8rem}.points-badge{padding:.4rem .8rem;font-size:1rem}.footer-links,.leaderboard-controls{flex-direction:column;gap:1rem}.leaderboard-filters{flex-wrap:wrap;justify-content:center;gap:.5rem}.filter-label{width:100%;text-align:center;margin-bottom:.25rem}.filter-btn{padding:.5rem .75rem;font-size:.85rem}.app-footer{font-size:.9rem}}@media (max-width: 380px){.hero-title-icon{width:35px;height:35px}.container,.hero-content{padding:0 15px}.phone-mockup{max-width:180px;max-height:390px}.section-title{font-size:1.5rem}}.legal-page{min-height:100vh;background-color:#f5f5f5}.legal-header{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);padding:20px 0;box-shadow:0 2px 4px #0000001a}.back-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:1rem;margin:0 auto;display:block;transition:background .3s}.back-button:hover{background:#ffffff4d}.legal-content{max-width:900px;margin:0 auto;padding:40px 20px;background:#fff;min-height:calc(100vh - 100px)}.legal-content h1{color:var(--primary-color);font-size:2.5rem;margin-bottom:30px;text-align:center}.legal-content h2{color:var(--primary-color);font-size:1.5rem;margin-top:30px;margin-bottom:15px}.legal-content p{color:#333;font-size:1rem;line-height:1.8;margin-bottom:20px;text-align:left}.legal-content ul.links-list{list-style:none;padding-left:0;margin:20px 0}.legal-content ul.links-list li{margin:10px 0}.legal-content a{color:var(--primary-color);text-decoration:none;border-bottom:1px solid transparent;transition:border-bottom .3s}.legal-content a:hover{border-bottom:1px solid var(--primary-color)}.contact-section{padding:20px 0}.contact-info{background:#f9f9f9;padding:20px;border-radius:8px;margin:20px 0}.contact-info p{margin:10px 0}.company-info{background:linear-gradient(135deg,#4caf501a,#8bc34a1a);padding:20px;border-radius:8px;margin:20px 0;border-left:4px solid var(--primary-color)}.company-info p{margin:8px 0}.footer-links a{cursor:pointer}@media (max-width: 768px){.legal-content h1{font-size:2rem}.legal-content h2{font-size:1.3rem}.legal-content{padding:30px 15px}}.news-list{display:flex;flex-direction:column;gap:2rem;margin-top:2rem}.news-item{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000001a;transition:transform .3s,box-shadow .3s}.news-item:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.news-item-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--bg-light)}.news-item-title{color:var(--primary-color);font-size:1.8rem;margin:0 0 .5rem;font-weight:700}.news-item-date{color:#666;font-size:.9rem;margin:0;font-style:italic}.news-item-image{width:100%;max-width:600px;height:auto;border-radius:8px;margin:1.5rem 0;box-shadow:0 2px 8px #0000001a}.news-item-content{font-size:1.1rem;line-height:1.8;color:#333;margin-top:1rem}.news-item-content p{margin-bottom:1rem}.news-item-content a{color:var(--primary-color);text-decoration:underline;word-break:break-all}.news-item-content a:hover{color:var(--text-dark);text-decoration:none}@media (max-width: 768px){.news-item{padding:1.5rem}.news-item-title{font-size:1.5rem}.news-item-content{font-size:1rem}}.portal-page{min-height:100vh;background-color:#f5f5f5}.portal-header{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);padding:20px 0;box-shadow:0 2px 4px #0000001a}.portal-header-inner{max-width:960px;margin:0 auto;padding:0 20px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px}.portal-header-title{margin:0;color:#fff;font-size:1.4rem;text-align:center}.portal-header-actions{display:flex;justify-content:flex-end}.portal-content{max-width:960px;margin:0 auto;padding:32px 20px 48px}.portal-content-narrow{max-width:480px}.portal-intro,.portal-status,.portal-footnote,.portal-privacy-note{color:#444;line-height:1.7}.portal-form{display:flex;flex-direction:column;gap:12px;margin-top:24px;background:#fff;padding:24px;border-radius:12px;box-shadow:var(--shadow)}.portal-label{font-weight:600;color:var(--text-dark)}.portal-input{border:1px solid #d0d7de;border-radius:8px;padding:12px 14px;font-size:1rem}.portal-button{border:none;border-radius:8px;padding:12px 18px;font-size:1rem;font-weight:600;cursor:pointer}.portal-button-primary{background:var(--primary-color);color:#fff}.portal-button-secondary{background:#fff;color:var(--primary-color);border:1px solid var(--primary-color)}.portal-button:disabled{opacity:.7;cursor:not-allowed}.portal-link-button,.portal-inline-link{background:transparent;border:none;color:#fff;text-decoration:underline;cursor:pointer;font-size:.95rem}.portal-inline-link{color:var(--primary-color);padding:0}.portal-error{color:#b42318;margin:0}.portal-panel{background:#fff;border-radius:12px;padding:24px;box-shadow:var(--shadow)}.portal-panel-error{border:1px solid #f5c2c0}.society-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.society-card{background:#fff;border-radius:12px;padding:20px;box-shadow:var(--shadow)}.society-card-clickable{cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.society-card-clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.society-detail-hero{display:flex;gap:16px;align-items:center;margin-bottom:16px}.society-detail-title{margin:0 0 8px;font-size:1.6rem;color:var(--text-dark)}.portal-intro-compact{margin-bottom:24px}.portal-section{background:#fff;border-radius:12px;padding:24px;box-shadow:var(--shadow);margin-bottom:20px}.portal-section-title{margin:0 0 8px;color:var(--primary-color);font-size:1.25rem}.portal-section-subtitle{margin:0 0 16px;color:#555}.finance-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px}.finance-summary-card{background:var(--bg-light);border-radius:10px;padding:14px}.finance-summary-label{display:block;font-size:.85rem;color:#666;margin-bottom:6px}.finance-summary-value{font-size:1.15rem;font-weight:700;color:var(--text-dark)}.finance-subheading{margin:20px 0 10px;font-size:1rem;color:var(--text-dark)}.finance-list{list-style:none;margin:0;padding:0}.finance-line{display:flex;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid #e9ecef}.finance-line:last-child{border-bottom:none}.finance-line-title{margin:0 0 4px;font-weight:600;color:var(--text-dark)}.finance-line-meta{margin:0;font-size:.9rem;color:#666}.finance-line-amount{font-weight:700;white-space:nowrap}.finance-line-amount-owe{color:#c62828}.finance-line-amount-credit{color:var(--primary-color)}.member-balance-table-wrap{overflow-x:auto;margin-bottom:20px}.member-balance-table{width:100%;border-collapse:collapse}.member-balance-table th,.member-balance-table td{padding:10px 12px;text-align:left;border-bottom:1px solid #e9ecef}.member-balance-table th{font-size:.85rem;color:#666}.member-link-button{background:none;border:none;padding:0;color:var(--primary-color);font-weight:600;cursor:pointer;text-decoration:underline}.portal-empty-note{color:#666;margin:0}.society-card-header{display:flex;gap:14px;align-items:center}.society-card-icon{width:56px;height:56px;border-radius:50%;object-fit:cover;flex-shrink:0}.society-card-icon-fallback{display:flex;align-items:center;justify-content:center;background:var(--bg-light);color:var(--primary-color);font-size:1.4rem;font-weight:700}.society-card-title{margin:0 0 6px;font-size:1.2rem;color:var(--text-dark)}.society-role-badge{display:inline-block;padding:4px 10px;border-radius:999px;background:#e8f5e9;color:var(--primary-color);font-size:.8rem;font-weight:600}.society-role-badge-admin{background:#fff3cd;color:#8a6d00}.society-card-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:18px 0 0}.society-card-meta dt{font-size:.8rem;color:#666;margin-bottom:4px}.society-card-meta dd{margin:0;font-weight:600;color:var(--text-dark)}.society-card-note{margin:16px 0 0;font-size:.92rem;color:#555;line-height:1.6}@media (max-width: 768px){.portal-header-inner{grid-template-columns:1fr;text-align:center}.portal-header-actions{justify-content:center}}
