.oc-public{max-width:1080px;margin:0 auto;font-family:-apple-system,Segoe UI,sans-serif;}
.oc-about{font-size:16px;line-height:1.7;color:#333;}
.oc-benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin:24px 0;}
.oc-benefit{background:#fff;border:1px solid #eee;border-radius:14px;padding:28px 24px;text-align:center;box-shadow:0 1px 6px rgba(0,0,0,.04);}
.oc-benefit-icon{font-size:34px;margin-bottom:12px;}
.oc-benefit h3{margin:0 0 8px;font-size:17px;}
.oc-benefit p{margin:0;color:#666;font-size:14px;line-height:1.6;}
.oc-events-public{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;}
.oc-event-public{background:#fff;border:1px solid #eee;border-radius:14px;overflow:hidden;box-shadow:0 1px 6px rgba(0,0,0,.04);}
.oc-event-cover{height:160px;background-size:cover;background-position:center;}
.oc-event-body{padding:20px;}
.oc-event-date{font-size:12px;color:#999;text-transform:uppercase;letter-spacing:.05em;}
.oc-event-body h3{margin:6px 0;font-size:18px;}
.oc-event-loc{font-size:13px;color:#888;margin:4px 0;}
.oc-event-desc{font-size:14px;color:#666;line-height:1.6;margin-top:8px;}
.oc-form-wrap{max-width:540px;margin:32px auto;}
.oc-member-form{background:#fff;border:1px solid #eee;border-radius:14px;padding:32px;box-shadow:0 1px 8px rgba(0,0,0,.05);}
.oc-member-form h2{margin:0 0 8px;font-size:22px;}
.oc-portal-greet{color:#888;font-size:14px;margin-bottom:20px;}
.oc-fr{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.oc-ff{margin-bottom:16px;}
.oc-ff label{display:block;font-size:12px;color:#666;margin-bottom:5px;}
.oc-ff input,.oc-ff select,.oc-ff textarea{width:100%;box-sizing:border-box;padding:11px 13px;border:1px solid #e0e0e0;border-radius:9px;font-size:14px;}
.oc-ff input:focus,.oc-ff select:focus{outline:none;border-color:#1a1a2e;}
.oc-submit{width:100%;padding:13px;background:#1a1a2e;color:#fff;border:none;border-radius:9px;font-size:15px;font-weight:600;cursor:pointer;margin-top:8px;}
.oc-submit:hover{background:#2d2d4e;}
.oc-msg{padding:12px 16px;border-radius:9px;margin-bottom:16px;font-size:14px;}
.oc-msg-ok{background:#edfce8;color:#2e7d32;}
.oc-msg-err{background:#fcebeb;color:#b32d2e;}
.oc-rsvp-wrap{max-width:520px;margin:40px auto;}
.oc-rsvp-card{background:#fff;border:1px solid #eee;border-radius:16px;overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.06);}
.oc-rsvp-head{background:#1a1a2e;color:#fff;padding:36px 32px;text-align:center;}
.oc-rsvp-club{font-size:11px;letter-spacing:.15em;opacity:.6;text-transform:uppercase;}
.oc-rsvp-head h2{margin:10px 0 8px;font-size:24px;}
.oc-rsvp-date,.oc-rsvp-loc{margin:4px 0;font-size:14px;opacity:.85;}
.oc-rsvp-desc{padding:24px 32px;font-size:14px;color:#555;line-height:1.6;border-bottom:1px solid #f0f0f0;}
.oc-rsvp-form{padding:28px 32px;}
.oc-rsvp-q{text-align:center;font-size:16px;margin:0 0 16px;color:#333;}
.oc-rsvp-btns{display:flex;flex-direction:column;gap:10px;}
.oc-rsvp-btn{padding:13px;border:2px solid #e0e0e0;border-radius:10px;background:#fff;font-size:15px;font-weight:600;cursor:pointer;color:#555;}
.oc-rsvp-btn.oc-rsvp-yes{border-color:#1a8d3a;color:#1a8d3a;}
.oc-rsvp-btn.oc-rsvp-yes.active{background:#1a8d3a;color:#fff;}
.oc-rsvp-btn.oc-rsvp-no.active{background:#b32d2e;color:#fff;border-color:#b32d2e;}
.oc-rsvp-btn.oc-rsvp-maybe.active{background:#888;color:#fff;border-color:#888;}

/* Marka ayricaliklari */
.oc-benefits-wrap{margin:24px 0;}
.oc-benefit-cat{margin-bottom:36px;}
.oc-benefit-cat-title{font-size:20px;margin:0 0 16px;padding-bottom:10px;border-bottom:2px solid #1a1a2e;display:inline-block;}
.oc-benefits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;}
.oc-brand-card{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid #eee;border-radius:14px;padding:18px;text-decoration:none;color:inherit;box-shadow:0 1px 6px rgba(0,0,0,.04);transition:transform .15s,box-shadow .15s;}
a.oc-brand-card:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,.1);}
.oc-brand-logo{width:64px;height:64px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#f8f8f8;overflow:hidden;}
.oc-brand-logo img{max-width:100%;max-height:100%;object-fit:contain;}
.oc-brand-noimg{font-size:26px;font-weight:700;color:#1a1a2e;}
.oc-brand-name{font-size:16px;font-weight:600;}
.oc-brand-discount{display:inline-block;background:#edfce8;color:#1a8d3a;font-size:13px;font-weight:600;padding:2px 10px;border-radius:20px;margin-top:4px;}
.oc-brand-desc{font-size:13px;color:#888;margin-top:6px;line-height:1.5;}

/* RSVP kapak gorsel */
.oc-rsvp-cover{width:100%;display:block;background:#0f0f1e;}
.oc-rsvp-cover img{width:100%;height:auto;display:block;}
.oc-rsvp-cover.bg{background-size:contain;background-repeat:no-repeat;background-position:center;aspect-ratio:16/9;}

/* +1 box */
.oc-rsvp-body{padding:24px 32px;}
.oc-plus-box{margin-top:20px;padding-top:20px;border-top:1px solid #f0f0f0;}
.oc-plus-label{font-size:14px;color:#555;margin:0 0 10px;text-align:center;}
.oc-plus-form input{width:100%;box-sizing:border-box;padding:11px 13px;border:1px solid #e0e0e0;border-radius:9px;font-size:14px;margin-bottom:10px;}
.oc-plus-btn{width:100%;padding:11px;background:#185fa5;color:#fff;border:none;border-radius:9px;font-size:14px;font-weight:600;cursor:pointer;}
.oc-plus-status{text-align:center;padding:12px;border-radius:9px;font-size:14px;font-weight:500;}
.oc-plus-ok{background:#edfce8;color:#1a8d3a;}
.oc-plus-pending{background:#fff4e5;color:#b45309;}
.oc-plus-rej{background:#fcebeb;color:#b32d2e;}
.oc-cb{display:block;font-size:14px;margin-bottom:6px;font-weight:normal;}
